From 1837d78aa611c261998a130b1e5e2b2a9d729f12 Mon Sep 17 00:00:00 2001 From: Felix Tjahyadi <felix.tjahyadi@ui.ac.id> Date: Sat, 24 Feb 2024 20:45:17 +0700 Subject: [PATCH] Read by Id --- .../filters => detail_item}/__init__.py | 0 detail_item/admin.py | 3 + detail_item/apps.py | 6 + .../migrations/__init__.py | 0 detail_item/models.py | 8 + detail_item/templates/template.html | 3 + detail_item/tests.py | 3 + detail_item/urls.py | 8 + detail_item/views.py | 10 + .../pip-21.1.3.dist-info/INSTALLER | 1 - .../pip-21.1.3.dist-info/LICENSE.txt | 20 - .../pip-21.1.3.dist-info/METADATA | 91 - .../site-packages/pip-21.1.3.dist-info/RECORD | 797 -- .../site-packages/pip-21.1.3.dist-info/WHEEL | 5 - .../pip-21.1.3.dist-info/entry_points.txt | 5 - .../pip-21.1.3.dist-info/top_level.txt | 1 - env/Lib/site-packages/pip/__init__.py | 5 +- env/Lib/site-packages/pip/__main__.py | 7 - .../pip/__pycache__/__init__.cpython-39.pyc | Bin 618 -> 0 bytes .../pip/__pycache__/__main__.cpython-39.pyc | Bin 615 -> 0 bytes .../site-packages/pip/_internal/__init__.py | 8 +- .../__pycache__/__init__.cpython-39.pyc | Bin 667 -> 0 bytes .../__pycache__/build_env.cpython-39.pyc | Bin 8980 -> 0 bytes .../__pycache__/cache.cpython-39.pyc | Bin 7870 -> 0 bytes .../__pycache__/configuration.cpython-39.pyc | Bin 10722 -> 0 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 15671 -> 0 bytes .../_internal/__pycache__/main.cpython-39.pyc | Bin 604 -> 0 bytes .../__pycache__/pyproject.cpython-39.pyc | Bin 3482 -> 0 bytes .../self_outdated_check.cpython-39.pyc | Bin 4367 -> 0 bytes .../__pycache__/wheel_builder.cpython-39.pyc | Bin 8305 -> 0 bytes .../site-packages/pip/_internal/build_env.py | 301 +- env/Lib/site-packages/pip/_internal/cache.py | 175 +- .../cli/__pycache__/__init__.cpython-39.pyc | Bin 300 -> 0 bytes .../__pycache__/autocompletion.cpython-39.pyc | Bin 4998 -> 0 bytes .../__pycache__/base_command.cpython-39.pyc | Bin 5821 -> 0 bytes .../cli/__pycache__/cmdoptions.cpython-39.pyc | Bin 21055 -> 0 bytes .../command_context.cpython-39.pyc | Bin 1249 -> 0 bytes .../cli/__pycache__/main.cpython-39.pyc | Bin 1349 -> 0 bytes .../__pycache__/main_parser.cpython-39.pyc | Bin 2130 -> 0 bytes .../cli/__pycache__/parser.cpython-39.pyc | Bin 9394 -> 0 bytes .../__pycache__/progress_bars.cpython-39.pyc | Bin 7466 -> 0 bytes .../__pycache__/req_command.cpython-39.pyc | Bin 11309 -> 0 bytes .../cli/__pycache__/spinners.cpython-39.pyc | Bin 4637 -> 0 bytes .../__pycache__/status_codes.cpython-39.pyc | Bin 379 -> 0 bytes .../pip/_internal/cli/autocompletion.py | 33 +- .../pip/_internal/cli/base_command.py | 173 +- .../pip/_internal/cli/cmdoptions.py | 460 +- .../pip/_internal/cli/command_context.py | 11 +- .../site-packages/pip/_internal/cli/main.py | 12 +- .../pip/_internal/cli/main_parser.py | 55 +- .../site-packages/pip/_internal/cli/parser.py | 71 +- .../pip/_internal/cli/progress_bars.py | 309 +- .../pip/_internal/cli/req_command.py | 192 +- .../pip/_internal/cli/spinners.py | 63 +- .../pip/_internal/commands/__init__.py | 174 +- .../__pycache__/__init__.cpython-39.pyc | Bin 2893 -> 0 bytes .../commands/__pycache__/cache.cpython-39.pyc | Bin 5775 -> 0 bytes .../commands/__pycache__/check.cpython-39.pyc | Bin 1541 -> 0 bytes .../__pycache__/completion.cpython-39.pyc | Bin 3097 -> 0 bytes .../__pycache__/configuration.cpython-39.pyc | Bin 8078 -> 0 bytes .../commands/__pycache__/debug.cpython-39.pyc | Bin 6462 -> 0 bytes .../__pycache__/download.cpython-39.pyc | Bin 3948 -> 0 bytes .../__pycache__/freeze.cpython-39.pyc | Bin 2946 -> 0 bytes .../commands/__pycache__/hash.cpython-39.pyc | Bin 2058 -> 0 bytes .../commands/__pycache__/help.cpython-39.pyc | Bin 1277 -> 0 bytes .../__pycache__/install.cpython-39.pyc | Bin 16724 -> 0 bytes .../commands/__pycache__/list.cpython-39.pyc | Bin 8835 -> 0 bytes .../__pycache__/search.cpython-39.pyc | Bin 4934 -> 0 bytes .../commands/__pycache__/show.cpython-39.pyc | Bin 6333 -> 0 bytes .../__pycache__/uninstall.cpython-39.pyc | Bin 2882 -> 0 bytes .../commands/__pycache__/wheel.cpython-39.pyc | Bin 4821 -> 0 bytes .../pip/_internal/commands/cache.py | 148 +- .../pip/_internal/commands/check.py | 18 +- .../pip/_internal/commands/completion.py | 98 +- .../pip/_internal/commands/configuration.py | 142 +- .../pip/_internal/commands/debug.py | 130 +- .../pip/_internal/commands/download.py | 42 +- .../pip/_internal/commands/freeze.py | 106 +- .../pip/_internal/commands/hash.py | 31 +- .../pip/_internal/commands/help.py | 5 +- .../pip/_internal/commands/install.py | 520 +- .../pip/_internal/commands/list.py | 307 +- .../pip/_internal/commands/search.py | 116 +- .../pip/_internal/commands/show.py | 232 +- .../pip/_internal/commands/uninstall.py | 73 +- .../pip/_internal/commands/wheel.py | 79 +- .../pip/_internal/configuration.py | 188 +- .../pip/_internal/distributions/__init__.py | 5 +- .../__pycache__/__init__.cpython-39.pyc | Bin 796 -> 0 bytes .../__pycache__/base.cpython-39.pyc | Bin 1852 -> 0 bytes .../__pycache__/installed.cpython-39.pyc | Bin 1197 -> 0 bytes .../__pycache__/sdist.cpython-39.pyc | Bin 3460 -> 0 bytes .../__pycache__/wheel.cpython-39.pyc | Bin 1541 -> 0 bytes .../pip/_internal/distributions/base.py | 18 +- .../pip/_internal/distributions/installed.py | 17 +- .../pip/_internal/distributions/sdist.py | 127 +- .../pip/_internal/distributions/wheel.py | 36 +- .../site-packages/pip/_internal/exceptions.py | 598 +- .../index/__pycache__/__init__.cpython-39.pyc | Bin 254 -> 0 bytes .../__pycache__/collector.cpython-39.pyc | Bin 15110 -> 0 bytes .../__pycache__/package_finder.cpython-39.pyc | Bin 26637 -> 0 bytes .../index/__pycache__/sources.cpython-39.pyc | Bin 7219 -> 0 bytes .../pip/_internal/index/collector.py | 473 +- .../pip/_internal/index/package_finder.py | 521 +- .../pip/_internal/index/sources.py | 1 - .../pip/_internal/locations/__init__.py | 431 +- .../__pycache__/__init__.cpython-39.pyc | Bin 3710 -> 0 bytes .../__pycache__/_distutils.cpython-39.pyc | Bin 3907 -> 0 bytes .../__pycache__/_sysconfig.cpython-39.pyc | Bin 4525 -> 0 bytes .../locations/__pycache__/base.cpython-39.pyc | Bin 1238 -> 0 bytes .../pip/_internal/locations/_distutils.py | 103 +- .../pip/_internal/locations/_sysconfig.py | 97 +- .../pip/_internal/locations/base.py | 45 +- env/Lib/site-packages/pip/_internal/main.py | 3 +- .../pip/_internal/metadata/__init__.py | 114 +- .../__pycache__/__init__.cpython-39.pyc | Bin 1753 -> 0 bytes .../metadata/__pycache__/base.cpython-39.pyc | Bin 5327 -> 0 bytes .../__pycache__/pkg_resources.cpython-39.pyc | Bin 4281 -> 0 bytes .../pip/_internal/metadata/base.py | 628 +- .../pip/_internal/metadata/pkg_resources.py | 258 +- .../__pycache__/__init__.cpython-39.pyc | Bin 288 -> 0 bytes .../__pycache__/candidate.cpython-39.pyc | Bin 1401 -> 0 bytes .../__pycache__/direct_url.cpython-39.pyc | Bin 6314 -> 0 bytes .../__pycache__/format_control.cpython-39.pyc | Bin 2558 -> 0 bytes .../models/__pycache__/index.cpython-39.pyc | Bin 1211 -> 0 bytes .../models/__pycache__/link.cpython-39.pyc | Bin 7215 -> 0 bytes .../models/__pycache__/scheme.cpython-39.pyc | Bin 966 -> 0 bytes .../__pycache__/search_scope.cpython-39.pyc | Bin 3367 -> 0 bytes .../selection_prefs.cpython-39.pyc | Bin 1601 -> 0 bytes .../__pycache__/target_python.cpython-39.pyc | Bin 3298 -> 0 bytes .../models/__pycache__/wheel.cpython-39.pyc | Bin 4213 -> 0 bytes .../pip/_internal/models/candidate.py | 24 +- .../pip/_internal/models/direct_url.py | 130 +- .../pip/_internal/models/format_control.py | 64 +- .../pip/_internal/models/index.py | 22 +- .../pip/_internal/models/link.py | 533 +- .../pip/_internal/models/scheme.py | 14 +- .../pip/_internal/models/search_scope.py | 67 +- .../pip/_internal/models/selection_prefs.py | 22 +- .../pip/_internal/models/target_python.py | 36 +- .../pip/_internal/models/wheel.py | 51 +- .../__pycache__/__init__.cpython-39.pyc | Bin 276 -> 0 bytes .../network/__pycache__/auth.cpython-39.pyc | Bin 7073 -> 0 bytes .../network/__pycache__/cache.cpython-39.pyc | Bin 2755 -> 0 bytes .../__pycache__/download.cpython-39.pyc | Bin 5115 -> 0 bytes .../__pycache__/lazy_wheel.cpython-39.pyc | Bin 7940 -> 0 bytes .../__pycache__/session.cpython-39.pyc | Bin 9523 -> 0 bytes .../network/__pycache__/utils.cpython-39.pyc | Bin 1342 -> 0 bytes .../network/__pycache__/xmlrpc.cpython-39.pyc | Bin 1921 -> 0 bytes .../pip/_internal/network/auth.py | 431 +- .../pip/_internal/network/cache.py | 25 +- .../pip/_internal/network/download.py | 88 +- .../pip/_internal/network/lazy_wheel.py | 122 +- .../pip/_internal/network/session.py | 302 +- .../pip/_internal/network/utils.py | 27 +- .../pip/_internal/network/xmlrpc.py | 27 +- .../__pycache__/__init__.cpython-39.pyc | Bin 224 -> 0 bytes .../__pycache__/check.cpython-39.pyc | Bin 3720 -> 0 bytes .../__pycache__/freeze.cpython-39.pyc | Bin 5673 -> 0 bytes .../__pycache__/prepare.cpython-39.pyc | Bin 14260 -> 0 bytes .../build/__pycache__/__init__.cpython-39.pyc | Bin 230 -> 0 bytes .../build/__pycache__/metadata.cpython-39.pyc | Bin 1176 -> 0 bytes .../metadata_legacy.cpython-39.pyc | Bin 1950 -> 0 bytes .../build/__pycache__/wheel.cpython-39.pyc | Bin 1155 -> 0 bytes .../__pycache__/wheel_legacy.cpython-39.pyc | Bin 2549 -> 0 bytes .../_internal/operations/build/metadata.py | 26 +- .../operations/build/metadata_legacy.py | 62 +- .../pip/_internal/operations/build/wheel.py | 19 +- .../operations/build/wheel_legacy.py | 68 +- .../pip/_internal/operations/check.py | 136 +- .../pip/_internal/operations/freeze.py | 277 +- .../__pycache__/__init__.cpython-39.pyc | Bin 288 -> 0 bytes .../editable_legacy.cpython-39.pyc | Bin 1331 -> 0 bytes .../install/__pycache__/legacy.cpython-39.pyc | Bin 3219 -> 0 bytes .../install/__pycache__/wheel.cpython-39.pyc | Bin 20841 -> 0 bytes .../operations/install/editable_legacy.py | 29 +- .../_internal/operations/install/legacy.py | 125 - .../pip/_internal/operations/install/wheel.py | 433 +- .../pip/_internal/operations/prepare.py | 552 +- .../site-packages/pip/_internal/pyproject.py | 104 +- .../pip/_internal/req/__init__.py | 50 +- .../req/__pycache__/__init__.cpython-39.pyc | Bin 2371 -> 0 bytes .../__pycache__/constructors.cpython-39.pyc | Bin 11031 -> 0 bytes .../req/__pycache__/req_file.cpython-39.pyc | Bin 12464 -> 0 bytes .../__pycache__/req_install.cpython-39.pyc | Bin 20542 -> 0 bytes .../req/__pycache__/req_set.cpython-39.pyc | Bin 5708 -> 0 bytes .../__pycache__/req_tracker.cpython-39.pyc | Bin 4053 -> 0 bytes .../__pycache__/req_uninstall.cpython-39.pyc | Bin 17489 -> 0 bytes .../pip/_internal/req/constructors.py | 308 +- .../pip/_internal/req/req_file.py | 261 +- .../pip/_internal/req/req_install.py | 700 +- .../pip/_internal/req/req_set.py | 214 +- .../pip/_internal/req/req_tracker.py | 140 - .../pip/_internal/req/req_uninstall.py | 506 +- .../__pycache__/__init__.cpython-39.pyc | Bin 224 -> 0 bytes .../__pycache__/base.cpython-39.pyc | Bin 967 -> 0 bytes .../pip/_internal/resolution/base.py | 16 +- .../__pycache__/__init__.cpython-39.pyc | Bin 231 -> 0 bytes .../__pycache__/resolver.cpython-39.pyc | Bin 11504 -> 0 bytes .../_internal/resolution/legacy/resolver.py | 280 +- .../__pycache__/__init__.cpython-39.pyc | Bin 235 -> 0 bytes .../__pycache__/base.cpython-39.pyc | Bin 6337 -> 0 bytes .../__pycache__/candidates.cpython-39.pyc | Bin 17917 -> 0 bytes .../__pycache__/factory.cpython-39.pyc | Bin 16384 -> 0 bytes .../found_candidates.cpython-39.pyc | Bin 4683 -> 0 bytes .../__pycache__/provider.cpython-39.pyc | Bin 6603 -> 0 bytes .../__pycache__/reporter.cpython-39.pyc | Bin 3167 -> 0 bytes .../__pycache__/requirements.cpython-39.pyc | Bin 7072 -> 0 bytes .../__pycache__/resolver.cpython-39.pyc | Bin 8079 -> 0 bytes .../_internal/resolution/resolvelib/base.py | 72 +- .../resolution/resolvelib/candidates.py | 357 +- .../resolution/resolvelib/factory.py | 287 +- .../resolution/resolvelib/found_candidates.py | 56 +- .../resolution/resolvelib/provider.py | 226 +- .../resolution/resolvelib/reporter.py | 60 +- .../resolution/resolvelib/requirements.py | 101 +- .../resolution/resolvelib/resolver.py | 212 +- .../pip/_internal/self_outdated_check.py | 243 +- .../utils/__pycache__/__init__.cpython-39.pyc | Bin 219 -> 0 bytes .../utils/__pycache__/appdirs.cpython-39.pyc | Bin 1284 -> 0 bytes .../utils/__pycache__/compat.cpython-39.pyc | Bin 1486 -> 0 bytes .../compatibility_tags.cpython-39.pyc | Bin 3862 -> 0 bytes .../utils/__pycache__/datetime.cpython-39.pyc | Bin 490 -> 0 bytes .../__pycache__/deprecation.cpython-39.pyc | Bin 2785 -> 0 bytes .../direct_url_helpers.cpython-39.pyc | Bin 2539 -> 0 bytes .../__pycache__/distutils_args.cpython-39.pyc | Bin 1084 -> 0 bytes .../utils/__pycache__/encoding.cpython-39.pyc | Bin 1249 -> 0 bytes .../__pycache__/entrypoints.cpython-39.pyc | Bin 1288 -> 0 bytes .../__pycache__/filesystem.cpython-39.pyc | Bin 4958 -> 0 bytes .../__pycache__/filetypes.cpython-39.pyc | Bin 831 -> 0 bytes .../utils/__pycache__/glibc.cpython-39.pyc | Bin 1641 -> 0 bytes .../utils/__pycache__/hashes.cpython-39.pyc | Bin 5023 -> 0 bytes .../inject_securetransport.cpython-39.pyc | Bin 992 -> 0 bytes .../utils/__pycache__/logging.cpython-39.pyc | Bin 8943 -> 0 bytes .../utils/__pycache__/misc.cpython-39.pyc | Bin 21547 -> 0 bytes .../utils/__pycache__/models.cpython-39.pyc | Bin 1923 -> 0 bytes .../__pycache__/packaging.cpython-39.pyc | Bin 2547 -> 0 bytes .../utils/__pycache__/parallel.cpython-39.pyc | Bin 3064 -> 0 bytes .../__pycache__/pkg_resources.cpython-39.pyc | Bin 1745 -> 0 bytes .../setuptools_build.cpython-39.pyc | Bin 2989 -> 0 bytes .../__pycache__/subprocess.cpython-39.pyc | Bin 5712 -> 0 bytes .../utils/__pycache__/temp_dir.cpython-39.pyc | Bin 6863 -> 0 bytes .../__pycache__/unpacking.cpython-39.pyc | Bin 6484 -> 0 bytes .../utils/__pycache__/urls.cpython-39.pyc | Bin 1375 -> 0 bytes .../__pycache__/virtualenv.cpython-39.pyc | Bin 3242 -> 0 bytes .../utils/__pycache__/wheel.cpython-39.pyc | Bin 5993 -> 0 bytes .../pip/_internal/utils/appdirs.py | 48 +- .../pip/_internal/utils/compat.py | 6 +- .../pip/_internal/utils/compatibility_tags.py | 45 +- .../pip/_internal/utils/datetime.py | 3 +- .../pip/_internal/utils/deprecation.py | 84 +- .../pip/_internal/utils/direct_url_helpers.py | 56 +- .../pip/_internal/utils/distutils_args.py | 43 - .../pip/_internal/utils/encoding.py | 9 +- .../pip/_internal/utils/entrypoints.py | 60 +- .../pip/_internal/utils/filesystem.py | 64 +- .../pip/_internal/utils/filetypes.py | 13 +- .../pip/_internal/utils/glibc.py | 20 +- .../pip/_internal/utils/hashes.py | 56 +- .../_internal/utils/inject_securetransport.py | 3 +- .../pip/_internal/utils/logging.py | 259 +- .../site-packages/pip/_internal/utils/misc.py | 490 +- .../pip/_internal/utils/models.py | 24 +- .../pip/_internal/utils/packaging.py | 80 +- .../pip/_internal/utils/parallel.py | 101 - .../pip/_internal/utils/pkg_resources.py | 40 - .../pip/_internal/utils/setuptools_build.py | 161 +- .../pip/_internal/utils/subprocess.py | 155 +- .../pip/_internal/utils/temp_dir.py | 58 +- .../pip/_internal/utils/unpacking.py | 38 +- .../site-packages/pip/_internal/utils/urls.py | 29 +- .../pip/_internal/utils/virtualenv.py | 29 +- .../pip/_internal/utils/wheel.py | 67 +- .../pip/_internal/vcs/__init__.py | 1 + .../vcs/__pycache__/__init__.cpython-39.pyc | Bin 512 -> 0 bytes .../vcs/__pycache__/bazaar.cpython-39.pyc | Bin 3028 -> 0 bytes .../vcs/__pycache__/git.cpython-39.pyc | Bin 10004 -> 0 bytes .../vcs/__pycache__/mercurial.cpython-39.pyc | Bin 4649 -> 0 bytes .../vcs/__pycache__/subversion.cpython-39.pyc | Bin 7983 -> 0 bytes .../__pycache__/versioncontrol.cpython-39.pyc | Bin 19128 -> 0 bytes .../site-packages/pip/_internal/vcs/bazaar.py | 84 +- .../site-packages/pip/_internal/vcs/git.py | 312 +- .../pip/_internal/vcs/mercurial.py | 107 +- .../pip/_internal/vcs/subversion.py | 165 +- .../pip/_internal/vcs/versioncontrol.py | 362 +- .../pip/_internal/wheel_builder.py | 217 +- env/Lib/site-packages/pip/_vendor/__init__.py | 17 +- .../__pycache__/__init__.cpython-39.pyc | Bin 2974 -> 0 bytes .../__pycache__/appdirs.cpython-39.pyc | Bin 21427 -> 0 bytes .../_vendor/__pycache__/distro.cpython-39.pyc | Bin 36906 -> 0 bytes .../__pycache__/pyparsing.cpython-39.pyc | Bin 240463 -> 0 bytes .../_vendor/__pycache__/six.cpython-39.pyc | Bin 26973 -> 0 bytes env/Lib/site-packages/pip/_vendor/appdirs.py | 633 -- .../pip/_vendor/cachecontrol/__init__.py | 9 +- .../__pycache__/__init__.cpython-39.pyc | Bin 577 -> 0 bytes .../__pycache__/_cmd.cpython-39.pyc | Bin 1598 -> 0 bytes .../__pycache__/adapter.cpython-39.pyc | Bin 3103 -> 0 bytes .../__pycache__/cache.cpython-39.pyc | Bin 1850 -> 0 bytes .../__pycache__/compat.cpython-39.pyc | Bin 774 -> 0 bytes .../__pycache__/controller.cpython-39.pyc | Bin 7791 -> 0 bytes .../__pycache__/filewrapper.cpython-39.pyc | Bin 2199 -> 0 bytes .../__pycache__/heuristics.cpython-39.pyc | Bin 4731 -> 0 bytes .../__pycache__/serialize.cpython-39.pyc | Bin 4250 -> 0 bytes .../__pycache__/wrapper.cpython-39.pyc | Bin 701 -> 0 bytes .../pip/_vendor/cachecontrol/_cmd.py | 4 + .../pip/_vendor/cachecontrol/adapter.py | 10 +- .../pip/_vendor/cachecontrol/cache.py | 30 +- .../_vendor/cachecontrol/caches/__init__.py | 11 +- .../__pycache__/__init__.cpython-39.pyc | Bin 321 -> 0 bytes .../__pycache__/file_cache.cpython-39.pyc | Bin 3337 -> 0 bytes .../__pycache__/redis_cache.cpython-39.pyc | Bin 1593 -> 0 bytes .../_vendor/cachecontrol/caches/file_cache.py | 58 +- .../cachecontrol/caches/redis_cache.py | 8 +- .../pip/_vendor/cachecontrol/compat.py | 5 +- .../pip/_vendor/cachecontrol/controller.py | 111 +- .../pip/_vendor/cachecontrol/filewrapper.py | 39 +- .../pip/_vendor/cachecontrol/heuristics.py | 4 + .../pip/_vendor/cachecontrol/serialize.py | 52 +- .../pip/_vendor/cachecontrol/wrapper.py | 4 + .../pip/_vendor/certifi/__init__.py | 3 +- .../__pycache__/__init__.cpython-39.pyc | Bin 303 -> 0 bytes .../__pycache__/__main__.cpython-39.pyc | Bin 480 -> 0 bytes .../certifi/__pycache__/core.cpython-39.pyc | Bin 1571 -> 0 bytes .../pip/_vendor/certifi/cacert.pem | 1824 +++-- .../site-packages/pip/_vendor/certifi/core.py | 86 +- .../pip/_vendor/chardet/__init__.py | 100 +- .../__pycache__/__init__.cpython-39.pyc | Bin 1927 -> 0 bytes .../__pycache__/big5freq.cpython-39.pyc | Bin 27206 -> 0 bytes .../__pycache__/big5prober.cpython-39.pyc | Bin 1161 -> 0 bytes .../chardistribution.cpython-39.pyc | Bin 6247 -> 0 bytes .../charsetgroupprober.cpython-39.pyc | Bin 2288 -> 0 bytes .../__pycache__/charsetprober.cpython-39.pyc | Bin 3510 -> 0 bytes .../codingstatemachine.cpython-39.pyc | Bin 2937 -> 0 bytes .../chardet/__pycache__/compat.cpython-39.pyc | Bin 426 -> 0 bytes .../__pycache__/cp949prober.cpython-39.pyc | Bin 1168 -> 0 bytes .../chardet/__pycache__/enums.cpython-39.pyc | Bin 2675 -> 0 bytes .../__pycache__/escprober.cpython-39.pyc | Bin 2660 -> 0 bytes .../chardet/__pycache__/escsm.cpython-39.pyc | Bin 7109 -> 0 bytes .../__pycache__/eucjpprober.cpython-39.pyc | Bin 2474 -> 0 bytes .../__pycache__/euckrfreq.cpython-39.pyc | Bin 12090 -> 0 bytes .../__pycache__/euckrprober.cpython-39.pyc | Bin 1169 -> 0 bytes .../__pycache__/euctwfreq.cpython-39.pyc | Bin 27210 -> 0 bytes .../__pycache__/euctwprober.cpython-39.pyc | Bin 1169 -> 0 bytes .../__pycache__/gb2312freq.cpython-39.pyc | Bin 19134 -> 0 bytes .../__pycache__/gb2312prober.cpython-39.pyc | Bin 1177 -> 0 bytes .../__pycache__/hebrewprober.cpython-39.pyc | Bin 3046 -> 0 bytes .../__pycache__/jisfreq.cpython-39.pyc | Bin 22162 -> 0 bytes .../chardet/__pycache__/jpcntx.cpython-39.pyc | Bin 37635 -> 0 bytes .../langbulgarianmodel.cpython-39.pyc | Bin 21837 -> 0 bytes .../__pycache__/langgreekmodel.cpython-39.pyc | Bin 20513 -> 0 bytes .../langhebrewmodel.cpython-39.pyc | Bin 20581 -> 0 bytes .../langhungarianmodel.cpython-39.pyc | Bin 21782 -> 0 bytes .../langrussianmodel.cpython-39.pyc | Bin 26385 -> 0 bytes .../__pycache__/langthaimodel.cpython-39.pyc | Bin 20757 -> 0 bytes .../langturkishmodel.cpython-39.pyc | Bin 20597 -> 0 bytes .../__pycache__/latin1prober.cpython-39.pyc | Bin 2982 -> 0 bytes .../mbcharsetprober.cpython-39.pyc | Bin 2289 -> 0 bytes .../mbcsgroupprober.cpython-39.pyc | Bin 1158 -> 0 bytes .../chardet/__pycache__/mbcssm.cpython-39.pyc | Bin 15745 -> 0 bytes .../sbcharsetprober.cpython-39.pyc | Bin 3142 -> 0 bytes .../sbcsgroupprober.cpython-39.pyc | Bin 1727 -> 0 bytes .../__pycache__/sjisprober.cpython-39.pyc | Bin 2510 -> 0 bytes .../universaldetector.cpython-39.pyc | Bin 5858 -> 0 bytes .../__pycache__/utf8prober.cpython-39.pyc | Bin 2019 -> 0 bytes .../__pycache__/version.cpython-39.pyc | Bin 466 -> 0 bytes .../pip/_vendor/chardet/big5freq.py | 6 +- .../pip/_vendor/chardet/big5prober.py | 12 +- .../pip/_vendor/chardet/chardistribution.py | 148 +- .../pip/_vendor/chardet/charsetgroupprober.py | 45 +- .../pip/_vendor/chardet/charsetprober.py | 74 +- .../pip/_vendor/chardet/cli/__init__.py | 1 - .../cli/__pycache__/__init__.cpython-39.pyc | Bin 223 -> 0 bytes .../cli/__pycache__/chardetect.cpython-39.pyc | Bin 2717 -> 0 bytes .../pip/_vendor/chardet/cli/chardetect.py | 90 +- .../pip/_vendor/chardet/codingstatemachine.py | 32 +- .../pip/_vendor/chardet/compat.py | 36 - .../pip/_vendor/chardet/cp949prober.py | 8 +- .../pip/_vendor/chardet/enums.py | 23 +- .../pip/_vendor/chardet/escprober.py | 45 +- .../pip/_vendor/chardet/escsm.py | 385 +- .../pip/_vendor/chardet/eucjpprober.py | 60 +- .../pip/_vendor/chardet/euckrfreq.py | 3 +- .../pip/_vendor/chardet/euckrprober.py | 12 +- .../pip/_vendor/chardet/euctwfreq.py | 677 +- .../pip/_vendor/chardet/euctwprober.py | 13 +- .../pip/_vendor/chardet/gb2312freq.py | 3 +- .../pip/_vendor/chardet/gb2312prober.py | 13 +- .../pip/_vendor/chardet/hebrewprober.py | 110 +- .../pip/_vendor/chardet/jisfreq.py | 4 +- .../pip/_vendor/chardet/jpcntx.py | 219 +- .../pip/_vendor/chardet/langbulgarianmodel.py | 1061 ++- .../pip/_vendor/chardet/langgreekmodel.py | 1061 ++- .../pip/_vendor/chardet/langhebrewmodel.py | 533 +- .../pip/_vendor/chardet/langhungarianmodel.py | 1061 ++- .../pip/_vendor/chardet/langrussianmodel.py | 3173 ++++---- .../pip/_vendor/chardet/langthaimodel.py | 533 +- .../pip/_vendor/chardet/langturkishmodel.py | 533 +- .../pip/_vendor/chardet/latin1prober.py | 44 +- .../pip/_vendor/chardet/mbcharsetprober.py | 62 +- .../pip/_vendor/chardet/mbcsgroupprober.py | 19 +- .../pip/_vendor/chardet/mbcssm.py | 813 +- .../__pycache__/__init__.cpython-39.pyc | Bin 228 -> 0 bytes .../__pycache__/languages.cpython-39.pyc | Bin 7959 -> 0 bytes .../pip/_vendor/chardet/metadata/languages.py | 574 +- .../pip/_vendor/chardet/sbcharsetprober.py | 95 +- .../pip/_vendor/chardet/sbcsgroupprober.py | 33 +- .../pip/_vendor/chardet/sjisprober.py | 65 +- .../pip/_vendor/chardet/universaldetector.py | 236 +- .../pip/_vendor/chardet/utf8prober.py | 32 +- .../pip/_vendor/chardet/version.py | 6 +- .../pip/_vendor/colorama/__init__.py | 5 +- .../__pycache__/__init__.cpython-39.pyc | Bin 471 -> 0 bytes .../colorama/__pycache__/ansi.cpython-39.pyc | Bin 3256 -> 0 bytes .../__pycache__/ansitowin32.cpython-39.pyc | Bin 7722 -> 0 bytes .../__pycache__/initialise.cpython-39.pyc | Bin 1738 -> 0 bytes .../colorama/__pycache__/win32.cpython-39.pyc | Bin 3970 -> 0 bytes .../__pycache__/winterm.cpython-39.pyc | Bin 4692 -> 0 bytes .../pip/_vendor/colorama/ansitowin32.py | 27 +- .../pip/_vendor/colorama/initialise.py | 51 +- .../pip/_vendor/colorama/win32.py | 28 + .../pip/_vendor/colorama/winterm.py | 28 +- .../pip/_vendor/distlib/__init__.py | 4 +- .../__pycache__/__init__.cpython-39.pyc | Bin 1084 -> 0 bytes .../distlib/__pycache__/compat.cpython-39.pyc | Bin 32186 -> 0 bytes .../__pycache__/database.cpython-39.pyc | Bin 42508 -> 0 bytes .../distlib/__pycache__/index.cpython-39.pyc | Bin 17529 -> 0 bytes .../__pycache__/locators.cpython-39.pyc | Bin 38517 -> 0 bytes .../__pycache__/manifest.cpython-39.pyc | Bin 10220 -> 0 bytes .../__pycache__/markers.cpython-39.pyc | Bin 4511 -> 0 bytes .../__pycache__/metadata.cpython-39.pyc | Bin 26437 -> 0 bytes .../__pycache__/resources.cpython-39.pyc | Bin 11050 -> 0 bytes .../__pycache__/scripts.cpython-39.pyc | Bin 10958 -> 0 bytes .../distlib/__pycache__/util.cpython-39.pyc | Bin 48230 -> 0 bytes .../__pycache__/version.cpython-39.pyc | Bin 20335 -> 0 bytes .../distlib/__pycache__/wheel.cpython-39.pyc | Bin 26419 -> 0 bytes .../pip/_vendor/distlib/_backport/__init__.py | 6 - .../__pycache__/__init__.cpython-39.pyc | Bin 511 -> 0 bytes .../_backport/__pycache__/misc.cpython-39.pyc | Bin 1131 -> 0 bytes .../__pycache__/shutil.cpython-39.pyc | Bin 21705 -> 0 bytes .../__pycache__/sysconfig.cpython-39.pyc | Bin 15995 -> 0 bytes .../__pycache__/tarfile.cpython-39.pyc | Bin 62759 -> 0 bytes .../pip/_vendor/distlib/_backport/misc.py | 41 - .../pip/_vendor/distlib/_backport/shutil.py | 764 -- .../_vendor/distlib/_backport/sysconfig.cfg | 84 - .../_vendor/distlib/_backport/sysconfig.py | 786 -- .../pip/_vendor/distlib/_backport/tarfile.py | 2607 ------ .../pip/_vendor/distlib/compat.py | 52 +- .../pip/_vendor/distlib/database.py | 67 +- .../pip/_vendor/distlib/index.py | 40 +- .../pip/_vendor/distlib/locators.py | 26 +- .../pip/_vendor/distlib/markers.py | 29 +- .../pip/_vendor/distlib/metadata.py | 54 +- .../pip/_vendor/distlib/resources.py | 7 +- .../pip/_vendor/distlib/scripts.py | 46 +- .../site-packages/pip/_vendor/distlib/t32.exe | Bin 96768 -> 97792 bytes .../site-packages/pip/_vendor/distlib/t64.exe | Bin 105984 -> 108032 bytes .../site-packages/pip/_vendor/distlib/util.py | 295 +- .../pip/_vendor/distlib/version.py | 5 +- .../site-packages/pip/_vendor/distlib/w32.exe | Bin 90112 -> 91648 bytes .../site-packages/pip/_vendor/distlib/w64.exe | Bin 99840 -> 101888 bytes .../pip/_vendor/distlib/wheel.py | 96 +- env/Lib/site-packages/pip/_vendor/distro.py | 1230 --- .../pip/_vendor/html5lib/__init__.py | 35 - .../__pycache__/__init__.cpython-39.pyc | Bin 1330 -> 0 bytes .../__pycache__/_ihatexml.cpython-39.pyc | Bin 13799 -> 0 bytes .../__pycache__/_inputstream.cpython-39.pyc | Bin 21658 -> 0 bytes .../__pycache__/_tokenizer.cpython-39.pyc | Bin 39753 -> 0 bytes .../__pycache__/_utils.cpython-39.pyc | Bin 4830 -> 0 bytes .../__pycache__/constants.cpython-39.pyc | Bin 66368 -> 0 bytes .../__pycache__/html5parser.cpython-39.pyc | Bin 91039 -> 0 bytes .../__pycache__/serializer.cpython-39.pyc | Bin 10841 -> 0 bytes .../pip/_vendor/html5lib/_ihatexml.py | 289 - .../pip/_vendor/html5lib/_inputstream.py | 918 --- .../pip/_vendor/html5lib/_tokenizer.py | 1735 ---- .../pip/_vendor/html5lib/_trie/__init__.py | 5 - .../_trie/__pycache__/__init__.cpython-39.pyc | Bin 380 -> 0 bytes .../_trie/__pycache__/_base.cpython-39.pyc | Bin 1624 -> 0 bytes .../_trie/__pycache__/py.cpython-39.pyc | Bin 2285 -> 0 bytes .../pip/_vendor/html5lib/_trie/_base.py | 40 - .../pip/_vendor/html5lib/_trie/py.py | 67 - .../pip/_vendor/html5lib/_utils.py | 159 - .../pip/_vendor/html5lib/constants.py | 2946 ------- .../__pycache__/__init__.cpython-39.pyc | Bin 228 -> 0 bytes .../alphabeticalattributes.cpython-39.pyc | Bin 1350 -> 0 bytes .../filters/__pycache__/base.cpython-39.pyc | Bin 898 -> 0 bytes .../inject_meta_charset.cpython-39.pyc | Bin 1904 -> 0 bytes .../filters/__pycache__/lint.cpython-39.pyc | Bin 2646 -> 0 bytes .../__pycache__/optionaltags.cpython-39.pyc | Bin 2791 -> 0 bytes .../__pycache__/sanitizer.cpython-39.pyc | Bin 16914 -> 0 bytes .../__pycache__/whitespace.cpython-39.pyc | Bin 1396 -> 0 bytes .../filters/alphabeticalattributes.py | 29 - .../pip/_vendor/html5lib/filters/base.py | 12 - .../html5lib/filters/inject_meta_charset.py | 73 - .../pip/_vendor/html5lib/filters/lint.py | 93 - .../_vendor/html5lib/filters/optionaltags.py | 207 - .../pip/_vendor/html5lib/filters/sanitizer.py | 916 --- .../_vendor/html5lib/filters/whitespace.py | 38 - .../pip/_vendor/html5lib/html5parser.py | 2795 ------- .../pip/_vendor/html5lib/serializer.py | 409 - .../_vendor/html5lib/treeadapters/__init__.py | 30 - .../__pycache__/__init__.cpython-39.pyc | Bin 965 -> 0 bytes .../__pycache__/genshi.cpython-39.pyc | Bin 1573 -> 0 bytes .../__pycache__/sax.cpython-39.pyc | Bin 1492 -> 0 bytes .../_vendor/html5lib/treeadapters/genshi.py | 54 - .../pip/_vendor/html5lib/treeadapters/sax.py | 50 - .../_vendor/html5lib/treebuilders/__init__.py | 88 - .../__pycache__/__init__.cpython-39.pyc | Bin 3360 -> 0 bytes .../__pycache__/base.cpython-39.pyc | Bin 11344 -> 0 bytes .../__pycache__/dom.cpython-39.pyc | Bin 9481 -> 0 bytes .../__pycache__/etree.cpython-39.pyc | Bin 11849 -> 0 bytes .../__pycache__/etree_lxml.cpython-39.pyc | Bin 13032 -> 0 bytes .../pip/_vendor/html5lib/treebuilders/base.py | 417 - .../pip/_vendor/html5lib/treebuilders/dom.py | 239 - .../_vendor/html5lib/treebuilders/etree.py | 343 - .../html5lib/treebuilders/etree_lxml.py | 392 - .../_vendor/html5lib/treewalkers/__init__.py | 154 - .../__pycache__/__init__.cpython-39.pyc | Bin 4026 -> 0 bytes .../__pycache__/base.cpython-39.pyc | Bin 7025 -> 0 bytes .../__pycache__/dom.cpython-39.pyc | Bin 1760 -> 0 bytes .../__pycache__/etree.cpython-39.pyc | Bin 3522 -> 0 bytes .../__pycache__/etree_lxml.cpython-39.pyc | Bin 6659 -> 0 bytes .../__pycache__/genshi.cpython-39.pyc | Bin 1916 -> 0 bytes .../pip/_vendor/html5lib/treewalkers/base.py | 252 - .../pip/_vendor/html5lib/treewalkers/dom.py | 43 - .../pip/_vendor/html5lib/treewalkers/etree.py | 131 - .../html5lib/treewalkers/etree_lxml.py | 215 - .../_vendor/html5lib/treewalkers/genshi.py | 69 - .../pip/_vendor/idna/__init__.py | 44 +- .../idna/__pycache__/__init__.cpython-39.pyc | Bin 285 -> 0 bytes .../idna/__pycache__/codec.cpython-39.pyc | Bin 2819 -> 0 bytes .../idna/__pycache__/compat.cpython-39.pyc | Bin 657 -> 0 bytes .../idna/__pycache__/core.cpython-39.pyc | Bin 9113 -> 0 bytes .../idna/__pycache__/idnadata.cpython-39.pyc | Bin 22166 -> 0 bytes .../idna/__pycache__/intranges.cpython-39.pyc | Bin 1837 -> 0 bytes .../__pycache__/package_data.cpython-39.pyc | Bin 239 -> 0 bytes .../idna/__pycache__/uts46data.cpython-39.pyc | Bin 146174 -> 0 bytes .../site-packages/pip/_vendor/idna/codec.py | 32 +- .../site-packages/pip/_vendor/idna/compat.py | 7 +- .../site-packages/pip/_vendor/idna/core.py | 124 +- .../pip/_vendor/idna/idnadata.py | 165 +- .../pip/_vendor/idna/intranges.py | 9 +- .../pip/_vendor/idna/package_data.py | 2 +- .../pip/_vendor/idna/uts46data.py | 922 ++- .../pip/_vendor/msgpack/__init__.py | 5 +- .../__pycache__/__init__.cpython-39.pyc | Bin 1442 -> 0 bytes .../__pycache__/_version.cpython-39.pyc | Bin 246 -> 0 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 1880 -> 0 bytes .../msgpack/__pycache__/ext.cpython-39.pyc | Bin 6308 -> 0 bytes .../__pycache__/fallback.cpython-39.pyc | Bin 26754 -> 0 bytes .../pip/_vendor/msgpack/_version.py | 1 - .../site-packages/pip/_vendor/msgpack/ext.py | 10 +- .../pip/_vendor/msgpack/fallback.py | 291 +- .../pip/_vendor/packaging/__about__.py | 3 +- .../pip/_vendor/packaging/__init__.py | 1 - .../__pycache__/__about__.cpython-39.pyc | Bin 717 -> 0 bytes .../__pycache__/__init__.cpython-39.pyc | Bin 573 -> 0 bytes .../__pycache__/_compat.cpython-39.pyc | Bin 1171 -> 0 bytes .../__pycache__/_structures.cpython-39.pyc | Bin 2925 -> 0 bytes .../__pycache__/_typing.cpython-39.pyc | Bin 1528 -> 0 bytes .../__pycache__/markers.cpython-39.pyc | Bin 9299 -> 0 bytes .../__pycache__/requirements.cpython-39.pyc | Bin 4172 -> 0 bytes .../__pycache__/specifiers.cpython-39.pyc | Bin 20954 -> 0 bytes .../packaging/__pycache__/tags.cpython-39.pyc | Bin 18571 -> 0 bytes .../__pycache__/utils.cpython-39.pyc | Bin 3639 -> 0 bytes .../__pycache__/version.cpython-39.pyc | Bin 12703 -> 0 bytes .../pip/_vendor/packaging/_compat.py | 38 - .../pip/_vendor/packaging/_structures.py | 61 +- .../pip/_vendor/packaging/_typing.py | 48 - .../pip/_vendor/packaging/markers.py | 118 +- .../pip/_vendor/packaging/requirements.py | 60 +- .../pip/_vendor/packaging/specifiers.py | 312 +- .../pip/_vendor/packaging/tags.py | 563 +- .../pip/_vendor/packaging/utils.py | 76 +- .../pip/_vendor/packaging/version.py | 236 +- .../pip/_vendor/pep517/__init__.py | 6 - .../__pycache__/__init__.cpython-39.pyc | Bin 341 -> 0 bytes .../pep517/__pycache__/build.cpython-39.pyc | Bin 3590 -> 0 bytes .../pep517/__pycache__/check.cpython-39.pyc | Bin 5125 -> 0 bytes .../__pycache__/colorlog.cpython-39.pyc | Bin 2966 -> 0 bytes .../pep517/__pycache__/compat.cpython-39.pyc | Bin 1143 -> 0 bytes .../__pycache__/dirtools.cpython-39.pyc | Bin 1375 -> 0 bytes .../__pycache__/envbuild.cpython-39.pyc | Bin 4508 -> 0 bytes .../pep517/__pycache__/meta.cpython-39.pyc | Bin 2948 -> 0 bytes .../__pycache__/wrappers.cpython-39.pyc | Bin 10508 -> 0 bytes .../site-packages/pip/_vendor/pep517/build.py | 127 - .../site-packages/pip/_vendor/pep517/check.py | 206 - .../pip/_vendor/pep517/colorlog.py | 115 - .../pip/_vendor/pep517/compat.py | 34 - .../pip/_vendor/pep517/dirtools.py | 44 - .../pip/_vendor/pep517/envbuild.py | 167 - .../pip/_vendor/pep517/in_process/__init__.py | 17 - .../__pycache__/__init__.cpython-39.pyc | Bin 943 -> 0 bytes .../__pycache__/_in_process.cpython-39.pyc | Bin 8305 -> 0 bytes .../_vendor/pep517/in_process/_in_process.py | 280 - .../site-packages/pip/_vendor/pep517/meta.py | 92 - .../pip/_vendor/pep517/wrappers.py | 318 - .../pip/_vendor/pkg_resources/__init__.py | 857 +- .../__pycache__/__init__.cpython-39.pyc | Bin 100359 -> 0 bytes .../__pycache__/py31compat.cpython-39.pyc | Bin 678 -> 0 bytes .../pip/_vendor/pkg_resources/py31compat.py | 23 - .../pip/_vendor/progress/__init__.py | 177 - .../__pycache__/__init__.cpython-39.pyc | Bin 5685 -> 0 bytes .../progress/__pycache__/bar.cpython-39.pyc | Bin 2667 -> 0 bytes .../__pycache__/counter.cpython-39.pyc | Bin 1501 -> 0 bytes .../__pycache__/spinner.cpython-39.pyc | Bin 1418 -> 0 bytes .../site-packages/pip/_vendor/progress/bar.py | 91 - .../pip/_vendor/progress/counter.py | 41 - .../pip/_vendor/progress/spinner.py | 43 - .../site-packages/pip/_vendor/pyparsing.py | 7107 ----------------- .../pip/_vendor/requests/__init__.py | 122 +- .../__pycache__/__init__.cpython-39.pyc | Bin 3697 -> 0 bytes .../__pycache__/__version__.cpython-39.pyc | Bin 583 -> 0 bytes .../_internal_utils.cpython-39.pyc | Bin 1330 -> 0 bytes .../__pycache__/adapters.cpython-39.pyc | Bin 17001 -> 0 bytes .../requests/__pycache__/api.cpython-39.pyc | Bin 6787 -> 0 bytes .../requests/__pycache__/auth.cpython-39.pyc | Bin 8359 -> 0 bytes .../requests/__pycache__/certs.cpython-39.pyc | Bin 661 -> 0 bytes .../__pycache__/compat.cpython-39.pyc | Bin 1640 -> 0 bytes .../__pycache__/cookies.cpython-39.pyc | Bin 18850 -> 0 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 5273 -> 0 bytes .../requests/__pycache__/help.cpython-39.pyc | Bin 2744 -> 0 bytes .../requests/__pycache__/hooks.cpython-39.pyc | Bin 1018 -> 0 bytes .../__pycache__/models.cpython-39.pyc | Bin 23967 -> 0 bytes .../__pycache__/packages.cpython-39.pyc | Bin 530 -> 0 bytes .../__pycache__/sessions.cpython-39.pyc | Bin 19872 -> 0 bytes .../__pycache__/status_codes.cpython-39.pyc | Bin 4267 -> 0 bytes .../__pycache__/structures.cpython-39.pyc | Bin 4488 -> 0 bytes .../requests/__pycache__/utils.cpython-39.pyc | Bin 22645 -> 0 bytes .../pip/_vendor/requests/__version__.py | 20 +- .../pip/_vendor/requests/_internal_utils.py | 26 +- .../pip/_vendor/requests/adapters.py | 265 +- .../site-packages/pip/_vendor/requests/api.py | 26 +- .../pip/_vendor/requests/auth.py | 156 +- .../pip/_vendor/requests/certs.py | 12 +- .../pip/_vendor/requests/compat.py | 89 +- .../pip/_vendor/requests/cookies.py | 152 +- .../pip/_vendor/requests/exceptions.py | 36 +- .../pip/_vendor/requests/help.py | 106 +- .../pip/_vendor/requests/hooks.py | 7 +- .../pip/_vendor/requests/models.py | 364 +- .../pip/_vendor/requests/sessions.py | 292 +- .../pip/_vendor/requests/status_codes.py | 169 +- .../pip/_vendor/requests/structures.py | 12 +- .../pip/_vendor/requests/utils.py | 462 +- .../pip/_vendor/resolvelib/__init__.py | 4 +- .../__pycache__/__init__.cpython-39.pyc | Bin 634 -> 0 bytes .../__pycache__/providers.cpython-39.pyc | Bin 6554 -> 0 bytes .../__pycache__/reporters.cpython-39.pyc | Bin 2330 -> 0 bytes .../__pycache__/resolvers.cpython-39.pyc | Bin 15225 -> 0 bytes .../__pycache__/structs.cpython-39.pyc | Bin 6948 -> 0 bytes .../__pycache__/__init__.cpython-39.pyc | Bin 229 -> 0 bytes .../collections_abc.cpython-39.pyc | Bin 403 -> 0 bytes .../pip/_vendor/resolvelib/providers.py | 25 +- .../pip/_vendor/resolvelib/reporters.py | 8 +- .../pip/_vendor/resolvelib/resolvers.py | 141 +- .../pip/_vendor/resolvelib/structs.py | 25 +- env/Lib/site-packages/pip/_vendor/six.py | 18 +- .../pip/_vendor/tenacity/__init__.py | 463 +- .../__pycache__/__init__.cpython-39.pyc | Bin 14706 -> 0 bytes .../__pycache__/_asyncio.cpython-39.pyc | Bin 2231 -> 0 bytes .../__pycache__/_utils.cpython-39.pyc | Bin 3979 -> 0 bytes .../tenacity/__pycache__/after.cpython-39.pyc | Bin 1006 -> 0 bytes .../__pycache__/before.cpython-39.pyc | Bin 902 -> 0 bytes .../__pycache__/before_sleep.cpython-39.pyc | Bin 1250 -> 0 bytes .../__pycache__/compat.cpython-39.pyc | Bin 986 -> 0 bytes .../tenacity/__pycache__/nap.cpython-39.pyc | Bin 1055 -> 0 bytes .../tenacity/__pycache__/retry.cpython-39.pyc | Bin 7440 -> 0 bytes .../tenacity/__pycache__/stop.cpython-39.pyc | Bin 3816 -> 0 bytes .../__pycache__/tornadoweb.cpython-39.pyc | Bin 1370 -> 0 bytes .../tenacity/__pycache__/wait.cpython-39.pyc | Bin 7373 -> 0 bytes .../pip/_vendor/tenacity/_asyncio.py | 45 +- .../pip/_vendor/tenacity/_utils.py | 109 +- .../pip/_vendor/tenacity/after.py | 33 +- .../pip/_vendor/tenacity/before.py | 23 +- .../pip/_vendor/tenacity/before_sleep.py | 42 +- .../pip/_vendor/tenacity/compat.py | 23 - .../site-packages/pip/_vendor/tenacity/nap.py | 13 +- .../pip/_vendor/tenacity/retry.py | 180 +- .../pip/_vendor/tenacity/stop.py | 48 +- .../pip/_vendor/tenacity/tornadoweb.py | 24 +- .../pip/_vendor/tenacity/wait.py | 121 +- .../pip/_vendor/toml/__init__.py | 25 - .../toml/__pycache__/__init__.cpython-39.pyc | Bin 760 -> 0 bytes .../toml/__pycache__/decoder.cpython-39.pyc | Bin 23252 -> 0 bytes .../toml/__pycache__/encoder.cpython-39.pyc | Bin 9435 -> 0 bytes .../toml/__pycache__/ordered.cpython-39.pyc | Bin 999 -> 0 bytes .../toml/__pycache__/tz.cpython-39.pyc | Bin 1301 -> 0 bytes .../site-packages/pip/_vendor/toml/decoder.py | 1057 --- .../site-packages/pip/_vendor/toml/encoder.py | 304 - .../site-packages/pip/_vendor/toml/ordered.py | 15 - env/Lib/site-packages/pip/_vendor/toml/tz.py | 24 - .../pip/_vendor/urllib3/__init__.py | 17 + .../__pycache__/__init__.cpython-39.pyc | Bin 2217 -> 0 bytes .../__pycache__/_collections.cpython-39.pyc | Bin 10812 -> 0 bytes .../__pycache__/_version.cpython-39.pyc | Bin 241 -> 0 bytes .../__pycache__/connection.cpython-39.pyc | Bin 13397 -> 0 bytes .../__pycache__/connectionpool.cpython-39.pyc | Bin 24496 -> 0 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 11674 -> 0 bytes .../urllib3/__pycache__/fields.cpython-39.pyc | Bin 8189 -> 0 bytes .../__pycache__/filepost.cpython-39.pyc | Bin 2790 -> 0 bytes .../__pycache__/poolmanager.cpython-39.pyc | Bin 15192 -> 0 bytes .../__pycache__/request.cpython-39.pyc | Bin 5653 -> 0 bytes .../__pycache__/response.cpython-39.pyc | Bin 20864 -> 0 bytes .../pip/_vendor/urllib3/_version.py | 2 +- .../pip/_vendor/urllib3/connection.py | 61 +- .../pip/_vendor/urllib3/connectionpool.py | 97 +- .../__pycache__/__init__.cpython-39.pyc | Bin 227 -> 0 bytes .../_appengine_environ.cpython-39.pyc | Bin 1447 -> 0 bytes .../__pycache__/appengine.cpython-39.pyc | Bin 8300 -> 0 bytes .../__pycache__/ntlmpool.cpython-39.pyc | Bin 3292 -> 0 bytes .../__pycache__/pyopenssl.cpython-39.pyc | Bin 15559 -> 0 bytes .../securetransport.cpython-39.pyc | Bin 21871 -> 0 bytes .../contrib/__pycache__/socks.cpython-39.pyc | Bin 5663 -> 0 bytes .../__pycache__/__init__.cpython-39.pyc | Bin 244 -> 0 bytes .../__pycache__/bindings.cpython-39.pyc | Bin 10751 -> 0 bytes .../__pycache__/low_level.cpython-39.pyc | Bin 9200 -> 0 bytes .../contrib/_securetransport/bindings.py | 2 +- .../contrib/_securetransport/low_level.py | 1 + .../pip/_vendor/urllib3/contrib/appengine.py | 4 +- .../pip/_vendor/urllib3/contrib/ntlmpool.py | 13 +- .../pip/_vendor/urllib3/contrib/pyopenssl.py | 23 +- .../urllib3/contrib/securetransport.py | 9 +- .../pip/_vendor/urllib3/contrib/socks.py | 2 +- .../pip/_vendor/urllib3/packages/__init__.py | 5 - .../__pycache__/__init__.cpython-39.pyc | Bin 341 -> 0 bytes .../packages/__pycache__/six.cpython-39.pyc | Bin 26545 -> 0 bytes .../__pycache__/__init__.cpython-39.pyc | Bin 238 -> 0 bytes .../__pycache__/makefile.cpython-39.pyc | Bin 1336 -> 0 bytes .../pip/_vendor/urllib3/packages/six.py | 125 +- .../packages/ssl_match_hostname/__init__.py | 22 - .../__pycache__/__init__.cpython-39.pyc | Bin 578 -> 0 bytes .../_implementation.cpython-39.pyc | Bin 3331 -> 0 bytes .../ssl_match_hostname/_implementation.py | 160 - .../pip/_vendor/urllib3/poolmanager.py | 3 +- .../pip/_vendor/urllib3/response.py | 72 +- .../util/__pycache__/__init__.cpython-39.pyc | Bin 1137 -> 0 bytes .../__pycache__/connection.cpython-39.pyc | Bin 3491 -> 0 bytes .../util/__pycache__/proxy.cpython-39.pyc | Bin 1373 -> 0 bytes .../util/__pycache__/queue.cpython-39.pyc | Bin 1092 -> 0 bytes .../util/__pycache__/request.cpython-39.pyc | Bin 3480 -> 0 bytes .../util/__pycache__/response.cpython-39.pyc | Bin 2377 -> 0 bytes .../util/__pycache__/retry.cpython-39.pyc | Bin 15994 -> 0 bytes .../util/__pycache__/ssl_.cpython-39.pyc | Bin 11055 -> 0 bytes .../__pycache__/ssltransport.cpython-39.pyc | Bin 7543 -> 0 bytes .../util/__pycache__/timeout.cpython-39.pyc | Bin 8975 -> 0 bytes .../util/__pycache__/url.cpython-39.pyc | Bin 10651 -> 0 bytes .../util/__pycache__/wait.cpython-39.pyc | Bin 3160 -> 0 bytes .../pip/_vendor/urllib3/util/connection.py | 5 +- .../pip/_vendor/urllib3/util/proxy.py | 1 + .../pip/_vendor/urllib3/util/request.py | 6 - .../pip/_vendor/urllib3/util/retry.py | 34 +- .../pip/_vendor/urllib3/util/ssl_.py | 43 +- .../pip/_vendor/urllib3/util/ssltransport.py | 6 +- .../pip/_vendor/urllib3/util/timeout.py | 9 +- .../pip/_vendor/urllib3/util/url.py | 17 +- .../pip/_vendor/urllib3/util/wait.py | 1 - env/Lib/site-packages/pip/_vendor/vendor.txt | 43 +- .../__pycache__/__init__.cpython-39.pyc | Bin 9751 -> 0 bytes .../__pycache__/labels.cpython-39.pyc | Bin 3865 -> 0 bytes .../__pycache__/mklabels.cpython-39.pyc | Bin 1935 -> 0 bytes .../__pycache__/tests.cpython-39.pyc | Bin 5099 -> 0 bytes .../__pycache__/x_user_defined.cpython-39.pyc | Bin 2695 -> 0 bytes env/Lib/site-packages/pip/py.typed | 2 +- env/Scripts/Activate.ps1 | 411 +- env/Scripts/activate | 16 +- env/Scripts/activate.bat | 3 +- env/Scripts/deactivate.bat | 1 + env/Scripts/pip.exe | Bin 106410 -> 108400 bytes env/Scripts/pip3.9.exe | Bin 106410 -> 0 bytes env/Scripts/pip3.exe | Bin 106410 -> 108400 bytes env/Scripts/python.exe | Bin 543464 -> 270616 bytes env/Scripts/pythonw.exe | Bin 542440 -> 259352 bytes env/pyvenv.cfg | 6 +- project_a4_logistik/urls.py | 3 +- 774 files changed, 23382 insertions(+), 50298 deletions(-) rename {env/Lib/site-packages/pip/_vendor/html5lib/filters => detail_item}/__init__.py (100%) create mode 100644 detail_item/admin.py create mode 100644 detail_item/apps.py rename env/Lib/site-packages/pip-21.1.3.dist-info/REQUESTED => detail_item/migrations/__init__.py (100%) create mode 100644 detail_item/models.py create mode 100644 detail_item/templates/template.html create mode 100644 detail_item/tests.py create mode 100644 detail_item/urls.py create mode 100644 detail_item/views.py delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/INSTALLER delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/LICENSE.txt delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/METADATA delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/RECORD delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/WHEEL delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/entry_points.txt delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/top_level.txt delete mode 100644 env/Lib/site-packages/pip/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/__pycache__/__main__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/build_env.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/cache.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/exceptions.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/main.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/debug.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/download.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/hash.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/help.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/show.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/index/__pycache__/collector.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/locations/__pycache__/base.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/metadata/__pycache__/base.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/format_control.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/link.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/wheel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/cache.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/session.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/legacy.py delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/constructors.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_file.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_install.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_set.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/req/req_tracker.py delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/compatibility_tags.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/distutils_args.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/logging.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/misc.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/parallel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/pkg_resources.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/urls.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/utils/distutils_args.py delete mode 100644 env/Lib/site-packages/pip/_internal/utils/parallel.py delete mode 100644 env/Lib/site-packages/pip/_internal/utils/pkg_resources.py delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/git.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/appdirs.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/distro.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/pyparsing.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/appdirs.py delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/compat.py delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/misc.py delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/shutil.py delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.py delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/tarfile.py delete mode 100644 env/Lib/site-packages/pip/_vendor/distro.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_ihatexml.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_inputstream.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_tokenizer.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/_base.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/py.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_utils.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/constants.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/base.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/lint.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/optionaltags.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/sanitizer.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/html5parser.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/serializer.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/sax.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/base.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/dom.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/base.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/dom.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/_version.py delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_typing.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/tags.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/_compat.py delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/_typing.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/dirtools.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/meta.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/build.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/check.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/colorlog.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/compat.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/dirtools.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/envbuild.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/in_process/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/_in_process.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/in_process/_in_process.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/meta.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/wrappers.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/pkg_resources/py31compat.py delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/bar.py delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/counter.py delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/spinner.py delete mode 100644 env/Lib/site-packages/pip/_vendor/pyparsing.py delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/api.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/help.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/compat.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/compat.py delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/decoder.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/encoder.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/ordered.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/tz.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/decoder.py delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/encoder.py delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/ordered.py delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/tz.py delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-39.pyc delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-39.pyc delete mode 100644 env/Scripts/pip3.9.exe diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__init__.py b/detail_item/__init__.py similarity index 100% rename from env/Lib/site-packages/pip/_vendor/html5lib/filters/__init__.py rename to detail_item/__init__.py diff --git a/detail_item/admin.py b/detail_item/admin.py new file mode 100644 index 00000000..8c38f3f3 --- /dev/null +++ b/detail_item/admin.py @@ -0,0 +1,3 @@ +from django.contrib import admin + +# Register your models here. diff --git a/detail_item/apps.py b/detail_item/apps.py new file mode 100644 index 00000000..29c5f55b --- /dev/null +++ b/detail_item/apps.py @@ -0,0 +1,6 @@ +from django.apps import AppConfig + + +class DetailItemConfig(AppConfig): + default_auto_field = 'django.db.models.BigAutoField' + name = 'detail_item' diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/REQUESTED b/detail_item/migrations/__init__.py similarity index 100% rename from env/Lib/site-packages/pip-21.1.3.dist-info/REQUESTED rename to detail_item/migrations/__init__.py diff --git a/detail_item/models.py b/detail_item/models.py new file mode 100644 index 00000000..f94ad44e --- /dev/null +++ b/detail_item/models.py @@ -0,0 +1,8 @@ +from django.db import models + +# Create your models here. + +class Item(models.Model): + id = models.IntegerField() + nama = models.CharField(max_length=100) + deskripsi = models.TextField() \ No newline at end of file diff --git a/detail_item/templates/template.html b/detail_item/templates/template.html new file mode 100644 index 00000000..a2507bef --- /dev/null +++ b/detail_item/templates/template.html @@ -0,0 +1,3 @@ +<div> +{{item}} +</div> \ No newline at end of file diff --git a/detail_item/tests.py b/detail_item/tests.py new file mode 100644 index 00000000..7ce503c2 --- /dev/null +++ b/detail_item/tests.py @@ -0,0 +1,3 @@ +from django.test import TestCase + +# Create your tests here. diff --git a/detail_item/urls.py b/detail_item/urls.py new file mode 100644 index 00000000..dbb9a996 --- /dev/null +++ b/detail_item/urls.py @@ -0,0 +1,8 @@ +from django.urls import path +from detail_item.views import * + +app_name = 'purchase_requisiton' + +urlpatterns = [ + path('', show_detail, name='show_detail'), +] \ No newline at end of file diff --git a/detail_item/views.py b/detail_item/views.py new file mode 100644 index 00000000..d76dfc8a --- /dev/null +++ b/detail_item/views.py @@ -0,0 +1,10 @@ +from django.shortcuts import render +from detail_item.models import Item + +# Create your views here. +def show_detail(request, id): + item = Item.objects.get(id=id) + context = { + 'item': item + } + return render(request, "template.html", context) \ No newline at end of file diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/INSTALLER b/env/Lib/site-packages/pip-21.1.3.dist-info/INSTALLER deleted file mode 100644 index a1b589e3..00000000 --- a/env/Lib/site-packages/pip-21.1.3.dist-info/INSTALLER +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/LICENSE.txt b/env/Lib/site-packages/pip-21.1.3.dist-info/LICENSE.txt deleted file mode 100644 index 00addc27..00000000 --- a/env/Lib/site-packages/pip-21.1.3.dist-info/LICENSE.txt +++ /dev/null @@ -1,20 +0,0 @@ -Copyright (c) 2008-2021 The pip developers (see AUTHORS.txt file) - -Permission is hereby granted, free of charge, to any person obtaining -a copy of this software and associated documentation files (the -"Software"), to deal in the Software without restriction, including -without limitation the rights to use, copy, modify, merge, publish, -distribute, sublicense, and/or sell copies of the Software, and to -permit persons to whom the Software is furnished to do so, subject to -the following conditions: - -The above copyright notice and this permission notice shall be -included in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND -NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE -LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION -OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION -WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/METADATA b/env/Lib/site-packages/pip-21.1.3.dist-info/METADATA deleted file mode 100644 index 7625ce6d..00000000 --- a/env/Lib/site-packages/pip-21.1.3.dist-info/METADATA +++ /dev/null @@ -1,91 +0,0 @@ -Metadata-Version: 2.1 -Name: pip -Version: 21.1.3 -Summary: The PyPA recommended tool for installing Python packages. -Home-page: https://pip.pypa.io/ -Author: The pip developers -Author-email: distutils-sig@python.org -License: MIT -Project-URL: Documentation, https://pip.pypa.io -Project-URL: Source, https://github.com/pypa/pip -Project-URL: Changelog, https://pip.pypa.io/en/stable/news/ -Platform: UNKNOWN -Classifier: Development Status :: 5 - Production/Stable -Classifier: Intended Audience :: Developers -Classifier: License :: OSI Approved :: MIT License -Classifier: Topic :: Software Development :: Build Tools -Classifier: Programming Language :: Python -Classifier: Programming Language :: Python :: 3 -Classifier: Programming Language :: Python :: 3 :: Only -Classifier: Programming Language :: Python :: 3.6 -Classifier: Programming Language :: Python :: 3.7 -Classifier: Programming Language :: Python :: 3.8 -Classifier: Programming Language :: Python :: 3.9 -Classifier: Programming Language :: Python :: Implementation :: CPython -Classifier: Programming Language :: Python :: Implementation :: PyPy -Requires-Python: >=3.6 - -pip - The Python Package Installer -================================== - -.. image:: https://img.shields.io/pypi/v/pip.svg - :target: https://pypi.org/project/pip/ - -.. image:: https://readthedocs.org/projects/pip/badge/?version=latest - :target: https://pip.pypa.io/en/latest - -pip is the `package installer`_ for Python. You can use pip to install packages from the `Python Package Index`_ and other indexes. - -Please take a look at our documentation for how to install and use pip: - -* `Installation`_ -* `Usage`_ - -We release updates regularly, with a new version every 3 months. Find more details in our documentation: - -* `Release notes`_ -* `Release process`_ - -In pip 20.3, we've `made a big improvement to the heart of pip`_; `learn more`_. We want your input, so `sign up for our user experience research studies`_ to help us do it right. - -**Note**: pip 21.0, in January 2021, removed Python 2 support, per pip's `Python 2 support policy`_. Please migrate to Python 3. - -If you find bugs, need help, or want to talk to the developers, please use our mailing lists or chat rooms: - -* `Issue tracking`_ -* `Discourse channel`_ -* `User IRC`_ - -If you want to get involved head over to GitHub to get the source code, look at our development documentation and feel free to jump on the developer mailing lists and chat rooms: - -* `GitHub page`_ -* `Development documentation`_ -* `Development mailing list`_ -* `Development IRC`_ - -Code of Conduct ---------------- - -Everyone interacting in the pip project's codebases, issue trackers, chat -rooms, and mailing lists is expected to follow the `PSF Code of Conduct`_. - -.. _package installer: https://packaging.python.org/guides/tool-recommendations/ -.. _Python Package Index: https://pypi.org -.. _Installation: https://pip.pypa.io/en/stable/installing.html -.. _Usage: https://pip.pypa.io/en/stable/ -.. _Release notes: https://pip.pypa.io/en/stable/news.html -.. _Release process: https://pip.pypa.io/en/latest/development/release-process/ -.. _GitHub page: https://github.com/pypa/pip -.. _Development documentation: https://pip.pypa.io/en/latest/development -.. _made a big improvement to the heart of pip: https://pyfound.blogspot.com/2020/11/pip-20-3-new-resolver.html -.. _learn more: https://pip.pypa.io/en/latest/user_guide/#changes-to-the-pip-dependency-resolver-in-20-3-2020 -.. _sign up for our user experience research studies: https://pyfound.blogspot.com/2020/03/new-pip-resolver-to-roll-out-this-year.html -.. _Python 2 support policy: https://pip.pypa.io/en/latest/development/release-process/#python-2-support -.. _Issue tracking: https://github.com/pypa/pip/issues -.. _Discourse channel: https://discuss.python.org/c/packaging -.. _Development mailing list: https://mail.python.org/mailman3/lists/distutils-sig.python.org/ -.. _User IRC: https://webchat.freenode.net/?channels=%23pypa -.. _Development IRC: https://webchat.freenode.net/?channels=%23pypa-dev -.. _PSF Code of Conduct: https://github.com/pypa/.github/blob/main/CODE_OF_CONDUCT.md - - diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/RECORD b/env/Lib/site-packages/pip-21.1.3.dist-info/RECORD deleted file mode 100644 index 128282ab..00000000 --- a/env/Lib/site-packages/pip-21.1.3.dist-info/RECORD +++ /dev/null @@ -1,797 +0,0 @@ -../../Scripts/pip.exe,sha256=ky1cKir6Y6HIL0MVYE3P_6WjqlxF2IKqrUiHiJfGARY,106410 -../../Scripts/pip3.9.exe,sha256=ky1cKir6Y6HIL0MVYE3P_6WjqlxF2IKqrUiHiJfGARY,106410 -../../Scripts/pip3.exe,sha256=ky1cKir6Y6HIL0MVYE3P_6WjqlxF2IKqrUiHiJfGARY,106410 -pip-21.1.3.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -pip-21.1.3.dist-info/LICENSE.txt,sha256=I6c2HCsVgQKLxiO52ivSSZeryqR4Gs5q1ESjeUT42uE,1090 -pip-21.1.3.dist-info/METADATA,sha256=S9OQK4VANzrp6XjVrdlA7h3FxOxK5ArkXGOMK0q8_zM,4103 -pip-21.1.3.dist-info/RECORD,, -pip-21.1.3.dist-info/REQUESTED,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip-21.1.3.dist-info/WHEEL,sha256=OqRkF0eY5GHssMorFjlbTIq072vpHpF60fIQA6lS9xA,92 -pip-21.1.3.dist-info/entry_points.txt,sha256=HtfDOwpUlr9s73jqLQ6wF9V0_0qvUXJwCBz7Vwx0Ue0,125 -pip-21.1.3.dist-info/top_level.txt,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 -pip/__init__.py,sha256=mLA-Prha-ozWaC8iu58VAOzOYpTR4NklaU7Jz1OeRGA,368 -pip/__main__.py,sha256=mXwWDftNLMKfwVqKFWGE_uuBZvGSIiUELhLkeysIuZc,1198 -pip/__pycache__/__init__.cpython-39.pyc,, -pip/__pycache__/__main__.cpython-39.pyc,, -pip/_internal/__init__.py,sha256=XvJ1JIumQnfLNFxVRdf_xrbhkTg1WMUrf2GzrH27F3A,410 -pip/_internal/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/__pycache__/build_env.cpython-39.pyc,, -pip/_internal/__pycache__/cache.cpython-39.pyc,, -pip/_internal/__pycache__/configuration.cpython-39.pyc,, -pip/_internal/__pycache__/exceptions.cpython-39.pyc,, -pip/_internal/__pycache__/main.cpython-39.pyc,, -pip/_internal/__pycache__/pyproject.cpython-39.pyc,, -pip/_internal/__pycache__/self_outdated_check.cpython-39.pyc,, -pip/_internal/__pycache__/wheel_builder.cpython-39.pyc,, -pip/_internal/build_env.py,sha256=2hFtbEoO4vA0FxehN_e2oXZ_3E3tAvKpnVmc8sOYjv0,9746 -pip/_internal/cache.py,sha256=6VONtoReGZbBd7sqY1n6hwkdWC4iz3tmXwXwZjpjZKw,9958 -pip/_internal/cli/__init__.py,sha256=FkHBgpxxb-_gd6r1FjnNhfMOzAUYyXoXKJ6abijfcFU,132 -pip/_internal/cli/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/cli/__pycache__/autocompletion.cpython-39.pyc,, -pip/_internal/cli/__pycache__/base_command.cpython-39.pyc,, -pip/_internal/cli/__pycache__/cmdoptions.cpython-39.pyc,, -pip/_internal/cli/__pycache__/command_context.cpython-39.pyc,, -pip/_internal/cli/__pycache__/main.cpython-39.pyc,, -pip/_internal/cli/__pycache__/main_parser.cpython-39.pyc,, -pip/_internal/cli/__pycache__/parser.cpython-39.pyc,, -pip/_internal/cli/__pycache__/progress_bars.cpython-39.pyc,, -pip/_internal/cli/__pycache__/req_command.cpython-39.pyc,, -pip/_internal/cli/__pycache__/spinners.cpython-39.pyc,, -pip/_internal/cli/__pycache__/status_codes.cpython-39.pyc,, -pip/_internal/cli/autocompletion.py,sha256=r2GQSaHHim1LwPhMaO9MPeKdsSv5H8S9ElVsmByQNew,6350 -pip/_internal/cli/base_command.py,sha256=26MHnlzZSC-Wk2j2OGsBDs5cl2ladrovJyVy1_2g0Zk,7741 -pip/_internal/cli/cmdoptions.py,sha256=52JIyP5C6yT8DpT1O2ZseAY-vMvLTb8FqO0g85OFYMs,28999 -pip/_internal/cli/command_context.py,sha256=k2JF5WPsP1MNKaXWK8jZFbJhYffzkdvGaPsL53tZbDU,815 -pip/_internal/cli/main.py,sha256=G_OsY66FZRtmLrMJ4k3m77tmtsRRRQd3_-qle1lvmng,2483 -pip/_internal/cli/main_parser.py,sha256=G70Z1fXLYzeJuuotgwKwq-daCJ0jCmmHxx6aFHz6WAQ,2642 -pip/_internal/cli/parser.py,sha256=rx4w6IgD0Obi7t1k9mV0zlYhy_DuCoaDCqhkUKMOFNU,11097 -pip/_internal/cli/progress_bars.py,sha256=ck_ILji6aRTG0zxXajnPWIpQTGxTzm3nscZOxwNmTWo,8576 -pip/_internal/cli/req_command.py,sha256=jf1fe9MVmFaZJCloIvlL5UgeJtsvlVUQObjQLLT7-HQ,16965 -pip/_internal/cli/spinners.py,sha256=VLdSWCvyk3KokujLyBf_QKYcGbrePQoPB4v7jqG7xyA,5347 -pip/_internal/cli/status_codes.py,sha256=sEFHUaUJbqv8iArL3HAtcztWZmGOFX01hTesSytDEh0,116 -pip/_internal/commands/__init__.py,sha256=v-xml8oMwrQhCpmApkpcMOE97Mp8QaBxoRObnGS43_8,3659 -pip/_internal/commands/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/commands/__pycache__/cache.cpython-39.pyc,, -pip/_internal/commands/__pycache__/check.cpython-39.pyc,, -pip/_internal/commands/__pycache__/completion.cpython-39.pyc,, -pip/_internal/commands/__pycache__/configuration.cpython-39.pyc,, -pip/_internal/commands/__pycache__/debug.cpython-39.pyc,, -pip/_internal/commands/__pycache__/download.cpython-39.pyc,, -pip/_internal/commands/__pycache__/freeze.cpython-39.pyc,, -pip/_internal/commands/__pycache__/hash.cpython-39.pyc,, -pip/_internal/commands/__pycache__/help.cpython-39.pyc,, -pip/_internal/commands/__pycache__/install.cpython-39.pyc,, -pip/_internal/commands/__pycache__/list.cpython-39.pyc,, -pip/_internal/commands/__pycache__/search.cpython-39.pyc,, -pip/_internal/commands/__pycache__/show.cpython-39.pyc,, -pip/_internal/commands/__pycache__/uninstall.cpython-39.pyc,, -pip/_internal/commands/__pycache__/wheel.cpython-39.pyc,, -pip/_internal/commands/cache.py,sha256=AELf98RWR_giU9wl0RSXf-MsTyO5G_iwO0iHoF4Fbmc,7414 -pip/_internal/commands/check.py,sha256=Dt0w7NqFp8o_45J7w32GQrKezsz2vwo_U8UmsHD9YNI,1587 -pip/_internal/commands/completion.py,sha256=UxS09s8rEnU08AAiN3gHdQIjU4XGSlv5SJ3rIJdTyhA,2951 -pip/_internal/commands/configuration.py,sha256=X1fdVdEg8MHFtArU-3bM6WBNax1E7Z7qszPEdlK1zqo,9206 -pip/_internal/commands/debug.py,sha256=yntOplw93VZoQAVBB3BXPKuqbam4mT6TErastFwFy3s,6806 -pip/_internal/commands/download.py,sha256=zv8S_DN2-k6K0VSR3yCPLSrLehoYkj3IvyO1Ho8t8V4,4993 -pip/_internal/commands/freeze.py,sha256=vPVguwBb15ubv8Es9oPSyWePBe2cq39QxjU4KizeTwk,3431 -pip/_internal/commands/hash.py,sha256=ip64AsJ6EFUEaWKDvsZmdQHks1JTEgrDjH5byl-IYyc,1713 -pip/_internal/commands/help.py,sha256=6Mnzrak_j-yE3psDCqi2GxISJqIZJ04DObKU9QhnxME,1149 -pip/_internal/commands/install.py,sha256=aFvZQfPrMrHDb6jjbmrVlyvDxMIeX3ZcZKSQvY6c0KI,27135 -pip/_internal/commands/list.py,sha256=jfqDS4xvm6WV8rHVSmvpaI811ukvD4OiPZwGGKMwwkI,11331 -pip/_internal/commands/search.py,sha256=EwcGPkDDTwFMpi2PBKhPuWX2YBMPcy7Ox1WFcWnouaw,5598 -pip/_internal/commands/show.py,sha256=sz2vbxh4l7Bj4jKlkDGTHYD6I8_duSpSUFVxUiH44xQ,6866 -pip/_internal/commands/uninstall.py,sha256=EDcx3a03l3U8tpZ2p4ffIdn45hY2YFEmq9yoeccF2ow,3216 -pip/_internal/commands/wheel.py,sha256=wKGSksuYjjhgOYa_jD6ulaKpPXaUzPiyzfRNNT4DOio,6233 -pip/_internal/configuration.py,sha256=QBLfhv-sbP-oR08NFxSYnv_mLB-SgtNOsWXAF9tDEcM,13725 -pip/_internal/distributions/__init__.py,sha256=ow1iPW_Qp-TOyOU-WghOKC8vAv1_Syk1zETZVO_vKEE,864 -pip/_internal/distributions/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/distributions/__pycache__/base.cpython-39.pyc,, -pip/_internal/distributions/__pycache__/installed.cpython-39.pyc,, -pip/_internal/distributions/__pycache__/sdist.cpython-39.pyc,, -pip/_internal/distributions/__pycache__/wheel.cpython-39.pyc,, -pip/_internal/distributions/base.py,sha256=UVndaok0jOHrLH0JqN0YzlxVEnvFQumYy37diY3ZCuE,1245 -pip/_internal/distributions/installed.py,sha256=uaTMPvY3hr_M1BCy107vJHWspKMJgrPxv30W3_zZZ0Q,667 -pip/_internal/distributions/sdist.py,sha256=co8fNR8qIhHRLBncwV92oJ7e8IOCGPgEsbEFdNPk1Yk,3900 -pip/_internal/distributions/wheel.py,sha256=n9MqNoWyMqNscfbNeeqh1bztoZUiB5x1H9h4tFfiJUw,1205 -pip/_internal/exceptions.py,sha256=2JQJSS68oggR_ZIOA-h1U2DRADURbkQn9Nf4EZWZ834,13170 -pip/_internal/index/__init__.py,sha256=vpt-JeTZefh8a-FC22ZeBSXFVbuBcXSGiILhQZJaNpQ,30 -pip/_internal/index/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/index/__pycache__/collector.cpython-39.pyc,, -pip/_internal/index/__pycache__/package_finder.cpython-39.pyc,, -pip/_internal/index/__pycache__/sources.cpython-39.pyc,, -pip/_internal/index/collector.py,sha256=aEXtHK0La4nGP7mu5N5CQ3tmfjaczLwbGi8Ar4oGz5o,18192 -pip/_internal/index/package_finder.py,sha256=3J9Rzq1NAO2p_zDb4fv33GeBBBOYusV9kXtAn2j6eCU,37294 -pip/_internal/index/sources.py,sha256=SVyPitv08-Qalh2_Bk5diAJ9GAA_d-a93koouQodAG0,6557 -pip/_internal/locations/__init__.py,sha256=9EXRxCpyiMClU87-P5E66tcFxybcA_KzLrzcK2Vt7zs,4826 -pip/_internal/locations/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/locations/__pycache__/_distutils.cpython-39.pyc,, -pip/_internal/locations/__pycache__/_sysconfig.cpython-39.pyc,, -pip/_internal/locations/__pycache__/base.cpython-39.pyc,, -pip/_internal/locations/_distutils.py,sha256=L5flRSr9BH0lBwPUl61cyBc1OnVD06FOENkDMRjyg38,5212 -pip/_internal/locations/_sysconfig.py,sha256=Tt8gkN7shxbqoUlzqM19myiBRzbft9CzkmcSS4YHk1s,5959 -pip/_internal/locations/base.py,sha256=QbkpgmzIbWBnUL2_3qu29sqCNewoqYbkVw8KmigRe2c,1478 -pip/_internal/main.py,sha256=BZ0vkdqgpoteTo1A1Q8ovFe8EzgKFJWOUjPmIUQfGCY,351 -pip/_internal/metadata/__init__.py,sha256=KINR8ZYO_ilc2pkV3t5KcQLzWLNc3GjZDklGWTVJ-zU,1471 -pip/_internal/metadata/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/metadata/__pycache__/base.cpython-39.pyc,, -pip/_internal/metadata/__pycache__/pkg_resources.cpython-39.pyc,, -pip/_internal/metadata/base.py,sha256=6BiB_b3lvNHYIVKbzrDhi0bJmSls5Q1K-iBeHWlKnIw,4750 -pip/_internal/metadata/pkg_resources.py,sha256=4FVPxYFABQ_1tbh_CRBzK4x0_SIgH1uCKx2ZLyhkouQ,4248 -pip/_internal/models/__init__.py,sha256=3DHUd_qxpPozfzouoqa9g9ts1Czr5qaHfFxbnxriepM,63 -pip/_internal/models/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/models/__pycache__/candidate.cpython-39.pyc,, -pip/_internal/models/__pycache__/direct_url.cpython-39.pyc,, -pip/_internal/models/__pycache__/format_control.cpython-39.pyc,, -pip/_internal/models/__pycache__/index.cpython-39.pyc,, -pip/_internal/models/__pycache__/link.cpython-39.pyc,, -pip/_internal/models/__pycache__/scheme.cpython-39.pyc,, -pip/_internal/models/__pycache__/search_scope.cpython-39.pyc,, -pip/_internal/models/__pycache__/selection_prefs.cpython-39.pyc,, -pip/_internal/models/__pycache__/target_python.cpython-39.pyc,, -pip/_internal/models/__pycache__/wheel.cpython-39.pyc,, -pip/_internal/models/candidate.py,sha256=LlyGF2SMGjeet9bLbEAzAWDP82Wcp3342Ysa7tCW_9M,1001 -pip/_internal/models/direct_url.py,sha256=VrnJNOqcPznfNarjQJavsx2tgG7GfcLa6PyZCuf_L7A,6555 -pip/_internal/models/format_control.py,sha256=l2jp47mWsJp7-LxMs05l9T-qFg9Z5PwdyP9R7Xc_VZQ,2629 -pip/_internal/models/index.py,sha256=asMraZVPI0snye404GztEpXgKerj1yAFmZl2p3eN4Bg,1092 -pip/_internal/models/link.py,sha256=5wdHbGDLbafSdYpo2Ky7F9RRo226zRy6ik3cLH_8Kwc,7472 -pip/_internal/models/scheme.py,sha256=iqceC7gKiTn2ZLgCOgGQbcmo49TRg9EnQUSsQH3U-7A,770 -pip/_internal/models/search_scope.py,sha256=4uGNEqYrz4ku6_WzowqivuMvN0fj5XQ03WB14YjcN5U,4613 -pip/_internal/models/selection_prefs.py,sha256=aNRDL97Gz3yWJW3og0yuvOkU02UL8OeNQDuDatZ8SDo,1947 -pip/_internal/models/target_python.py,sha256=SLGG3z9Pj_CiA5jmMnNDv2MN3ST3keVuanVDzTvO5pM,3962 -pip/_internal/models/wheel.py,sha256=MWjxQkBNXI6XOWiTuzMG7uONhFu8xA94OqD_9BuIsVc,3614 -pip/_internal/network/__init__.py,sha256=jf6Tt5nV_7zkARBrKojIXItgejvoegVJVKUbhAa5Ioc,50 -pip/_internal/network/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/network/__pycache__/auth.cpython-39.pyc,, -pip/_internal/network/__pycache__/cache.cpython-39.pyc,, -pip/_internal/network/__pycache__/download.cpython-39.pyc,, -pip/_internal/network/__pycache__/lazy_wheel.cpython-39.pyc,, -pip/_internal/network/__pycache__/session.cpython-39.pyc,, -pip/_internal/network/__pycache__/utils.cpython-39.pyc,, -pip/_internal/network/__pycache__/xmlrpc.cpython-39.pyc,, -pip/_internal/network/auth.py,sha256=d8Df0fy01P1jJlF3XDMM8ACyktR1cN9zURG-ye1ncc0,11833 -pip/_internal/network/cache.py,sha256=J_xpsLWbRrlCSUcQhA5-TuT5LWIlpVtTH4fZ1XSjyb4,2213 -pip/_internal/network/download.py,sha256=8frb2bINOf-jbmFPapKbyEO9sjXJWJG6OJaW4hQ9r3s,6243 -pip/_internal/network/lazy_wheel.py,sha256=XMfrDK1IBy44L3Gx3UZ2B8s90VRXDa96520IOPmzmOU,7924 -pip/_internal/network/session.py,sha256=VHeiorPflYPNWK2pM_q22c-H5gmRBDh9UKCJW3VAUFI,16247 -pip/_internal/network/utils.py,sha256=uqT6QkO9NHUwqTw3gHBWMQFdaYqYabB423QUZuiQD3c,4072 -pip/_internal/network/xmlrpc.py,sha256=CL1WBOTgxPwbcZ6QubZ4pXQXjb7qTTFpTUFe-ZaWkcA,1703 -pip/_internal/operations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/operations/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/operations/__pycache__/check.cpython-39.pyc,, -pip/_internal/operations/__pycache__/freeze.cpython-39.pyc,, -pip/_internal/operations/__pycache__/prepare.cpython-39.pyc,, -pip/_internal/operations/build/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/operations/build/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/operations/build/__pycache__/metadata.cpython-39.pyc,, -pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-39.pyc,, -pip/_internal/operations/build/__pycache__/wheel.cpython-39.pyc,, -pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-39.pyc,, -pip/_internal/operations/build/metadata.py,sha256=jJp05Rrp0AMsQb7izDXbNGC1LtPNwOhHQj7cRM5324c,1165 -pip/_internal/operations/build/metadata_legacy.py,sha256=ECMBhLEPEQv6PUUCpPCXW-wN9QRXdY45PNXJv7BZKTU,1917 -pip/_internal/operations/build/wheel.py,sha256=WYLMxuxqN3ahJTQk2MI9hdmZKBpFyxHeNpUdO0PybxU,1106 -pip/_internal/operations/build/wheel_legacy.py,sha256=NOJhTYMYljdbizFo_WjkaKGWG1SEZ6aByrBdCrrsZB8,3227 -pip/_internal/operations/check.py,sha256=OtMZ2ff0zk8Ghpl7eIXySZ4D8pCUfzPAYNpGTxw1qWU,5245 -pip/_internal/operations/freeze.py,sha256=D-ex0Bwy6E0EVS_gHlixlEpKDpRxFZnUmTy7nf8s7ts,9999 -pip/_internal/operations/install/__init__.py,sha256=mX7hyD2GNBO2mFGokDQ30r_GXv7Y_PLdtxcUv144e-s,51 -pip/_internal/operations/install/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/operations/install/__pycache__/editable_legacy.cpython-39.pyc,, -pip/_internal/operations/install/__pycache__/legacy.cpython-39.pyc,, -pip/_internal/operations/install/__pycache__/wheel.cpython-39.pyc,, -pip/_internal/operations/install/editable_legacy.py,sha256=bjBObfE6sz3UmGI7y4-GCgKa2WmTgnWlFFU7b-i0sQs,1396 -pip/_internal/operations/install/legacy.py,sha256=f59fQbNLO2rvl8bNQm_CuW6dgPvXXQ7y5apulWZi01E,4177 -pip/_internal/operations/install/wheel.py,sha256=1gV2G-owlA2iwcbxYAc4BOTiPRRGB8TzpuU0wuhM2VQ,29960 -pip/_internal/operations/prepare.py,sha256=AXHNg1iGceg1lyqDqbcabmAFIfQ1k1cIfgmVY5JCWoo,24850 -pip/_internal/pyproject.py,sha256=bN_dliFVxorLITxCEzT0UmPYFoSqk_vGBtM1QwiQays,7061 -pip/_internal/req/__init__.py,sha256=lRNHBv0ZAZNbSwmXU-XUdm66gsiNmuiBDi1DFYJ4hIQ,2983 -pip/_internal/req/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/req/__pycache__/constructors.cpython-39.pyc,, -pip/_internal/req/__pycache__/req_file.cpython-39.pyc,, -pip/_internal/req/__pycache__/req_install.cpython-39.pyc,, -pip/_internal/req/__pycache__/req_set.cpython-39.pyc,, -pip/_internal/req/__pycache__/req_tracker.cpython-39.pyc,, -pip/_internal/req/__pycache__/req_uninstall.cpython-39.pyc,, -pip/_internal/req/constructors.py,sha256=4sinGd7srKhI94DV6XO-qRX2M6Kr907OFmsfklKrt64,16267 -pip/_internal/req/req_file.py,sha256=nPIFl2Mi9UDGhrj-K0E3_QugF7tl3UBDty1czbIF7fk,18000 -pip/_internal/req/req_install.py,sha256=JyTkSucNku1uwqkl2Do0SS-EcqA362WoVLtpbu-rPfA,32523 -pip/_internal/req/req_set.py,sha256=AutsaiV2s-2ILwtWtTA4OJW_ZLRg4GXg6wM0Y_hZb1k,7778 -pip/_internal/req/req_tracker.py,sha256=XuPweX1lbJXT2gSkCXICS5hna6byme5PeQp4Ok8-R2o,4391 -pip/_internal/req/req_uninstall.py,sha256=gACinTIcScZGw81qLaFdTj9KGXlVuCpru7XvHGjIE-E,23468 -pip/_internal/resolution/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/resolution/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/resolution/__pycache__/base.cpython-39.pyc,, -pip/_internal/resolution/base.py,sha256=T4QnfShJErpPWe4iOiO7VmXuz1bxe20LLNs33AUslYM,563 -pip/_internal/resolution/legacy/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/resolution/legacy/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/resolution/legacy/__pycache__/resolver.cpython-39.pyc,, -pip/_internal/resolution/legacy/resolver.py,sha256=OF_6Yh4hrFfJ4u0HLF4ZRBlA8lBHUfAaFnhuVKIQhPM,17934 -pip/_internal/resolution/resolvelib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/base.cpython-39.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-39.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-39.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-39.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-39.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-39.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-39.pyc,, -pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-39.pyc,, -pip/_internal/resolution/resolvelib/base.py,sha256=MbakyqSotBGVJpI3kApqqP2fPPZih9DgsfkpuFd-ADM,5677 -pip/_internal/resolution/resolvelib/candidates.py,sha256=dEKSuK9B5M52c1SugB43zXnnxgNWNTa7hCCwItSX61c,19976 -pip/_internal/resolution/resolvelib/factory.py,sha256=taqeDmXk0kAY9EVqSMhEJriY02MSShbZvt9VqEAgkw4,25446 -pip/_internal/resolution/resolvelib/found_candidates.py,sha256=FzxKczhel3GhViOIEfGHUfUQ6rN3U0blMMUuu-blHfU,5410 -pip/_internal/resolution/resolvelib/provider.py,sha256=HYITnjs7hcxDGANCDdL4qg2MJ1aw1jA9cMyxNP2mLrk,7673 -pip/_internal/resolution/resolvelib/reporter.py,sha256=xgaCtXLj791A_qRfV9Y1nXGeaWVq3JE0ygIA3YNRWq0,2765 -pip/_internal/resolution/resolvelib/requirements.py,sha256=fF2RH6VCanTuF-iwu8tZY8Bh0FakDBTw7tkDJyTsy9E,6047 -pip/_internal/resolution/resolvelib/resolver.py,sha256=3hlnrZklszFUwGQFF33nLkEO8kxz4vZ3_uKp_L8YvmE,12085 -pip/_internal/self_outdated_check.py,sha256=ivoUYaGuq-Ra_DvlZvPtHhgbY97NKHYuPGzrgN2G1A8,6484 -pip/_internal/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_internal/utils/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/utils/__pycache__/appdirs.cpython-39.pyc,, -pip/_internal/utils/__pycache__/compat.cpython-39.pyc,, -pip/_internal/utils/__pycache__/compatibility_tags.cpython-39.pyc,, -pip/_internal/utils/__pycache__/datetime.cpython-39.pyc,, -pip/_internal/utils/__pycache__/deprecation.cpython-39.pyc,, -pip/_internal/utils/__pycache__/direct_url_helpers.cpython-39.pyc,, -pip/_internal/utils/__pycache__/distutils_args.cpython-39.pyc,, -pip/_internal/utils/__pycache__/encoding.cpython-39.pyc,, -pip/_internal/utils/__pycache__/entrypoints.cpython-39.pyc,, -pip/_internal/utils/__pycache__/filesystem.cpython-39.pyc,, -pip/_internal/utils/__pycache__/filetypes.cpython-39.pyc,, -pip/_internal/utils/__pycache__/glibc.cpython-39.pyc,, -pip/_internal/utils/__pycache__/hashes.cpython-39.pyc,, -pip/_internal/utils/__pycache__/inject_securetransport.cpython-39.pyc,, -pip/_internal/utils/__pycache__/logging.cpython-39.pyc,, -pip/_internal/utils/__pycache__/misc.cpython-39.pyc,, -pip/_internal/utils/__pycache__/models.cpython-39.pyc,, -pip/_internal/utils/__pycache__/packaging.cpython-39.pyc,, -pip/_internal/utils/__pycache__/parallel.cpython-39.pyc,, -pip/_internal/utils/__pycache__/pkg_resources.cpython-39.pyc,, -pip/_internal/utils/__pycache__/setuptools_build.cpython-39.pyc,, -pip/_internal/utils/__pycache__/subprocess.cpython-39.pyc,, -pip/_internal/utils/__pycache__/temp_dir.cpython-39.pyc,, -pip/_internal/utils/__pycache__/unpacking.cpython-39.pyc,, -pip/_internal/utils/__pycache__/urls.cpython-39.pyc,, -pip/_internal/utils/__pycache__/virtualenv.cpython-39.pyc,, -pip/_internal/utils/__pycache__/wheel.cpython-39.pyc,, -pip/_internal/utils/appdirs.py,sha256=HCCFaOrZOnMLzRDpKXcMiFh_2kWZ-PzFdN8peLiwkNY,1222 -pip/_internal/utils/compat.py,sha256=I58tTZ3qqGZqeGVP_mERM8N7QPu71niLpxfO3Ij2jfQ,1912 -pip/_internal/utils/compatibility_tags.py,sha256=IcQEHCZJvdfKciACmXGCKt39Yog2_Q2XQKMHojA_2pg,5589 -pip/_internal/utils/datetime.py,sha256=biZdEJEQBGq8A-N7ooposipeGzmSHdI0WX60kll_AEs,255 -pip/_internal/utils/deprecation.py,sha256=CD9gU1zmDtC3Nk2TM14FVpAa_bxCMd03Kx5t3LoFwkg,3277 -pip/_internal/utils/direct_url_helpers.py,sha256=-chZUxdJkFRG-pA2MY7_Wii5U5o18o5K4AqBsWd92-c,3935 -pip/_internal/utils/distutils_args.py,sha256=KxWTaz07A_1ukCyw_pNah-i6sBvrVtdMsnF8jguDNYQ,1262 -pip/_internal/utils/encoding.py,sha256=T0cQTkGB7-s3wivLlHcKbKqvJoM0yLdo8ot89LlGdz0,1190 -pip/_internal/utils/entrypoints.py,sha256=m4UXkLZTnPsdSisQzNFiHM1CZcMK8N1CA98g4ORex2c,1066 -pip/_internal/utils/filesystem.py,sha256=a3rnoUB_HTdEbDaAUHSNMPIHqHds4UA-mLQ5bvgOjSQ,6045 -pip/_internal/utils/filetypes.py,sha256=weviVbapHWVQ_8-K-PTQ_TnYL66kZi4SrVBTmRYZXLc,761 -pip/_internal/utils/glibc.py,sha256=GM1Y2hWkOf_tumySGFg-iNbc7oilBQQrjczb_705CF8,3170 -pip/_internal/utils/hashes.py,sha256=o1qQEkqe2AqsRm_JhLoM4hkxmVtewH0ZZpQ6EBObHuU,5167 -pip/_internal/utils/inject_securetransport.py,sha256=tGl9Bgyt2IHKtB3b0B-6r3W2yYF3Og-PBe0647S3lZs,810 -pip/_internal/utils/logging.py,sha256=Bkp3QSjur3ekkunAInsGJ6ls7KF8ANTtBgGhjY0vltg,12133 -pip/_internal/utils/misc.py,sha256=F7LDb6PQIwniYwLczhU2pSAyHZ9bnTVT1yI_OduYh3w,23315 -pip/_internal/utils/models.py,sha256=qCgYyUw2mIH1pombsJ3YQsMtONZgyJ4BGwO5MJnSC4c,1329 -pip/_internal/utils/packaging.py,sha256=I1938AB7FprcVJJd6C0vSiMuCVajmrxZF55vX5j0bMo,2900 -pip/_internal/utils/parallel.py,sha256=RZF4JddPEWVbkkPCknfvpqaLfm3Pmqd_ABoCHmV4lXs,3224 -pip/_internal/utils/pkg_resources.py,sha256=jwH5JViPe-JlXLvLC0-ASfTTCRYvm0u9CwQGcWjxStI,1106 -pip/_internal/utils/setuptools_build.py,sha256=xk9sRBjUyNTHs_TvEWebVWs1GfLPN208MzpSXr9Ok_A,5047 -pip/_internal/utils/subprocess.py,sha256=uxaP3IzPiBYhG0MbdfPK_uchZAh27uZ3wO3q5hRfEyo,10036 -pip/_internal/utils/temp_dir.py,sha256=9gs3N9GQeVXRVWjJIalSpH1uj8yQXPTzarb5n1_HMVo,7950 -pip/_internal/utils/unpacking.py,sha256=PioYYwfTCn_VeYer80onhrO9Y1ggetqOPSOroG38bRQ,9032 -pip/_internal/utils/urls.py,sha256=XzjQsHGd2YDmJhoCogspPTqh6Kl5tGENRHPcwjS0JC4,1256 -pip/_internal/utils/virtualenv.py,sha256=iRTK-sD6bWpHqXcZ0ECfdpFLWatMOHFUVCIRa0L6Gu0,3564 -pip/_internal/utils/wheel.py,sha256=DOIVZaXN7bMOAeMEqzIOZHGl4OFO-KGrEqBUB848DPo,6290 -pip/_internal/vcs/__init__.py,sha256=CjyxHCgdt19l21j0tJGiQ_6Yk8m-KWmQThmYvljd1eo,571 -pip/_internal/vcs/__pycache__/__init__.cpython-39.pyc,, -pip/_internal/vcs/__pycache__/bazaar.cpython-39.pyc,, -pip/_internal/vcs/__pycache__/git.cpython-39.pyc,, -pip/_internal/vcs/__pycache__/mercurial.cpython-39.pyc,, -pip/_internal/vcs/__pycache__/subversion.cpython-39.pyc,, -pip/_internal/vcs/__pycache__/versioncontrol.cpython-39.pyc,, -pip/_internal/vcs/bazaar.py,sha256=Ay_vN-87vYSEzBqXT3RVwl40vlk56j3jy_AfQbMj4uo,2962 -pip/_internal/vcs/git.py,sha256=URUz1kSqhDhqJsr9ulaFTewP8Zjwf7oVPP7skdj9SMQ,15431 -pip/_internal/vcs/mercurial.py,sha256=2X3eIyeAWQWI2TxoPT-xuVsD6fxr7YSyHw4MR9EWz4M,5043 -pip/_internal/vcs/subversion.py,sha256=lPfCu841JAMRG_jTX_TbRZrBpKdId5eQ8t7_xI7w3L0,11876 -pip/_internal/vcs/versioncontrol.py,sha256=N60TSMbTr79ADzR61BCrk8YogUQcBBnNaLgJPTfXsfc,23086 -pip/_internal/wheel_builder.py,sha256=hW63ZmABr65rOiSRBHXu1jBUdEZw5LZiw0LaQBbz0lI,11740 -pip/_vendor/__init__.py,sha256=gCrQwPBY2OZBeedvKOLdRZ3W1LIRM60fG6d4mgW_-9Y,4760 -pip/_vendor/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/__pycache__/appdirs.cpython-39.pyc,, -pip/_vendor/__pycache__/distro.cpython-39.pyc,, -pip/_vendor/__pycache__/pyparsing.cpython-39.pyc,, -pip/_vendor/__pycache__/six.cpython-39.pyc,, -pip/_vendor/appdirs.py,sha256=M6IYRJtdZgmSPCXCSMBRB0VT3P8MdFbWCDbSLrB2Ebg,25907 -pip/_vendor/cachecontrol/__init__.py,sha256=pJtAaUxOsMPnytI1A3juAJkXYDr8krdSnsg4Yg3OBEg,302 -pip/_vendor/cachecontrol/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-39.pyc,, -pip/_vendor/cachecontrol/__pycache__/adapter.cpython-39.pyc,, -pip/_vendor/cachecontrol/__pycache__/cache.cpython-39.pyc,, -pip/_vendor/cachecontrol/__pycache__/compat.cpython-39.pyc,, -pip/_vendor/cachecontrol/__pycache__/controller.cpython-39.pyc,, -pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-39.pyc,, -pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-39.pyc,, -pip/_vendor/cachecontrol/__pycache__/serialize.cpython-39.pyc,, -pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-39.pyc,, -pip/_vendor/cachecontrol/_cmd.py,sha256=URGE0KrA87QekCG3SGPatlSPT571dZTDjNa-ZXX3pDc,1295 -pip/_vendor/cachecontrol/adapter.py,sha256=sSwaSYd93IIfCFU4tOMgSo6b2LCt_gBSaQUj8ktJFOA,4882 -pip/_vendor/cachecontrol/cache.py,sha256=1fc4wJP8HYt1ycnJXeEw5pCpeBL2Cqxx6g9Fb0AYDWQ,805 -pip/_vendor/cachecontrol/caches/__init__.py,sha256=-gHNKYvaeD0kOk5M74eOrsSgIKUtC6i6GfbmugGweEo,86 -pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-39.pyc,, -pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-39.pyc,, -pip/_vendor/cachecontrol/caches/file_cache.py,sha256=nYVKsJtXh6gJXvdn1iWyrhxvkwpQrK-eKoMRzuiwkKk,4153 -pip/_vendor/cachecontrol/caches/redis_cache.py,sha256=HxelMpNCo-dYr2fiJDwM3hhhRmxUYtB5tXm1GpAAT4Y,856 -pip/_vendor/cachecontrol/compat.py,sha256=kHNvMRdt6s_Xwqq_9qJmr9ou3wYMOMUMxPPcwNxT8Mc,695 -pip/_vendor/cachecontrol/controller.py,sha256=CWEX3pedIM9s60suf4zZPtm_JvVgnvogMGK_OiBG5F8,14149 -pip/_vendor/cachecontrol/filewrapper.py,sha256=vACKO8Llzu_ZWyjV1Fxn1MA4TGU60N5N3GSrAFdAY2Q,2533 -pip/_vendor/cachecontrol/heuristics.py,sha256=BFGHJ3yQcxvZizfo90LLZ04T_Z5XSCXvFotrp7Us0sc,4070 -pip/_vendor/cachecontrol/serialize.py,sha256=vIa4jvq4x_KSOLdEIedoknX2aXYHQujLDFV4-F21Dno,7091 -pip/_vendor/cachecontrol/wrapper.py,sha256=5LX0uJwkNQUtYSEw3aGmGu9WY8wGipd81mJ8lG0d0M4,690 -pip/_vendor/certifi/__init__.py,sha256=SsmdmFHjHCY4VLtqwpp9P_jsOcAuHj-5c5WqoEz-oFg,62 -pip/_vendor/certifi/__main__.py,sha256=1k3Cr95vCxxGRGDljrW3wMdpZdL3Nhf0u1n-k2qdsCY,255 -pip/_vendor/certifi/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/certifi/__pycache__/__main__.cpython-39.pyc,, -pip/_vendor/certifi/__pycache__/core.cpython-39.pyc,, -pip/_vendor/certifi/cacert.pem,sha256=u3fxPT--yemLvyislQRrRBlsfY9Vq3cgBh6ZmRqCkZc,263774 -pip/_vendor/certifi/core.py,sha256=gOFd0zHYlx4krrLEn982esOtmz3djiG0BFSDhgjlvcI,2840 -pip/_vendor/chardet/__init__.py,sha256=mWZaWmvZkhwfBEAT9O1Y6nRTfKzhT7FHhQTTAujbqUA,3271 -pip/_vendor/chardet/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/big5freq.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/big5prober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/chardistribution.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/charsetprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/compat.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/cp949prober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/enums.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/escprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/escsm.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/eucjpprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/euckrfreq.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/euckrprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/euctwfreq.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/euctwprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/gb2312freq.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/gb2312prober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/hebrewprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/jisfreq.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/jpcntx.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/langthaimodel.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/latin1prober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/mbcssm.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/sjisprober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/universaldetector.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/utf8prober.cpython-39.pyc,, -pip/_vendor/chardet/__pycache__/version.cpython-39.pyc,, -pip/_vendor/chardet/big5freq.py,sha256=D_zK5GyzoVsRes0HkLJziltFQX0bKCLOrFe9_xDvO_8,31254 -pip/_vendor/chardet/big5prober.py,sha256=kBxHbdetBpPe7xrlb-e990iot64g_eGSLd32lB7_h3M,1757 -pip/_vendor/chardet/chardistribution.py,sha256=3woWS62KrGooKyqz4zQSnjFbJpa6V7g02daAibTwcl8,9411 -pip/_vendor/chardet/charsetgroupprober.py,sha256=GZLReHP6FRRn43hvSOoGCxYamErKzyp6RgOQxVeC3kg,3839 -pip/_vendor/chardet/charsetprober.py,sha256=KSmwJErjypyj0bRZmC5F5eM7c8YQgLYIjZXintZNstg,5110 -pip/_vendor/chardet/cli/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1 -pip/_vendor/chardet/cli/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-39.pyc,, -pip/_vendor/chardet/cli/chardetect.py,sha256=XK5zqjUG2a4-y6eLHZ8ThYcp6WWUrdlmELxNypcc2SE,2747 -pip/_vendor/chardet/codingstatemachine.py,sha256=VYp_6cyyki5sHgXDSZnXW4q1oelHc3cu9AyQTX7uug8,3590 -pip/_vendor/chardet/compat.py,sha256=40zr6wICZwknxyuLGGcIOPyve8DTebBCbbvttvnmp5Q,1200 -pip/_vendor/chardet/cp949prober.py,sha256=TZ434QX8zzBsnUvL_8wm4AQVTZ2ZkqEEQL_lNw9f9ow,1855 -pip/_vendor/chardet/enums.py,sha256=Aimwdb9as1dJKZaFNUH2OhWIVBVd6ZkJJ_WK5sNY8cU,1661 -pip/_vendor/chardet/escprober.py,sha256=kkyqVg1Yw3DIOAMJ2bdlyQgUFQhuHAW8dUGskToNWSc,3950 -pip/_vendor/chardet/escsm.py,sha256=RuXlgNvTIDarndvllNCk5WZBIpdCxQ0kcd9EAuxUh84,10510 -pip/_vendor/chardet/eucjpprober.py,sha256=iD8Jdp0ISRjgjiVN7f0e8xGeQJ5GM2oeZ1dA8nbSeUw,3749 -pip/_vendor/chardet/euckrfreq.py,sha256=-7GdmvgWez4-eO4SuXpa7tBiDi5vRXQ8WvdFAzVaSfo,13546 -pip/_vendor/chardet/euckrprober.py,sha256=MqFMTQXxW4HbzIpZ9lKDHB3GN8SP4yiHenTmf8g_PxY,1748 -pip/_vendor/chardet/euctwfreq.py,sha256=No1WyduFOgB5VITUA7PLyC5oJRNzRyMbBxaKI1l16MA,31621 -pip/_vendor/chardet/euctwprober.py,sha256=13p6EP4yRaxqnP4iHtxHOJ6R2zxHq1_m8hTRjzVZ95c,1747 -pip/_vendor/chardet/gb2312freq.py,sha256=JX8lsweKLmnCwmk8UHEQsLgkr_rP_kEbvivC4qPOrlc,20715 -pip/_vendor/chardet/gb2312prober.py,sha256=gGvIWi9WhDjE-xQXHvNIyrnLvEbMAYgyUSZ65HUfylw,1754 -pip/_vendor/chardet/hebrewprober.py,sha256=c3SZ-K7hvyzGY6JRAZxJgwJ_sUS9k0WYkvMY00YBYFo,13838 -pip/_vendor/chardet/jisfreq.py,sha256=vpmJv2Bu0J8gnMVRPHMFefTRvo_ha1mryLig8CBwgOg,25777 -pip/_vendor/chardet/jpcntx.py,sha256=PYlNqRUQT8LM3cT5FmHGP0iiscFlTWED92MALvBungo,19643 -pip/_vendor/chardet/langbulgarianmodel.py,sha256=rk9CJpuxO0bObboJcv6gNgWuosYZmd8qEEds5y7DS_Y,105697 -pip/_vendor/chardet/langgreekmodel.py,sha256=S-uNQ1ihC75yhBvSux24gLFZv3QyctMwC6OxLJdX-bw,99571 -pip/_vendor/chardet/langhebrewmodel.py,sha256=DzPP6TPGG_-PV7tqspu_d8duueqm7uN-5eQ0aHUw1Gg,98776 -pip/_vendor/chardet/langhungarianmodel.py,sha256=RtJH7DZdsmaHqyK46Kkmnk5wQHiJwJPPJSqqIlpeZRc,102498 -pip/_vendor/chardet/langrussianmodel.py,sha256=THqJOhSxiTQcHboDNSc5yofc2koXXQFHFyjtyuntUfM,131180 -pip/_vendor/chardet/langthaimodel.py,sha256=R1wXHnUMtejpw0JnH_JO8XdYasME6wjVqp1zP7TKLgg,103312 -pip/_vendor/chardet/langturkishmodel.py,sha256=rfwanTptTwSycE4-P-QasPmzd-XVYgevytzjlEzBBu8,95946 -pip/_vendor/chardet/latin1prober.py,sha256=S2IoORhFk39FEFOlSFWtgVybRiP6h7BlLldHVclNkU8,5370 -pip/_vendor/chardet/mbcharsetprober.py,sha256=AR95eFH9vuqSfvLQZN-L5ijea25NOBCoXqw8s5O9xLQ,3413 -pip/_vendor/chardet/mbcsgroupprober.py,sha256=h6TRnnYq2OxG1WdD5JOyxcdVpn7dG0q-vB8nWr5mbh4,2012 -pip/_vendor/chardet/mbcssm.py,sha256=SY32wVIF3HzcjY3BaEspy9metbNSKxIIB0RKPn7tjpI,25481 -pip/_vendor/chardet/metadata/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/chardet/metadata/__pycache__/languages.cpython-39.pyc,, -pip/_vendor/chardet/metadata/languages.py,sha256=41tLq3eLSrBEbEVVQpVGFq9K7o1ln9b1HpY1l0hCUQo,19474 -pip/_vendor/chardet/sbcharsetprober.py,sha256=nmyMyuxzG87DN6K3Rk2MUzJLMLR69MrWpdnHzOwVUwQ,6136 -pip/_vendor/chardet/sbcsgroupprober.py,sha256=hqefQuXmiFyDBArOjujH6hd6WFXlOD1kWCsxDhjx5Vc,4309 -pip/_vendor/chardet/sjisprober.py,sha256=IIt-lZj0WJqK4rmUZzKZP4GJlE8KUEtFYVuY96ek5MQ,3774 -pip/_vendor/chardet/universaldetector.py,sha256=DpZTXCX0nUHXxkQ9sr4GZxGB_hveZ6hWt3uM94cgWKs,12503 -pip/_vendor/chardet/utf8prober.py,sha256=IdD8v3zWOsB8OLiyPi-y_fqwipRFxV9Nc1eKBLSuIEw,2766 -pip/_vendor/chardet/version.py,sha256=A4CILFAd8MRVG1HoXPp45iK9RLlWyV73a1EtwE8Tvn8,242 -pip/_vendor/colorama/__init__.py,sha256=pCdErryzLSzDW5P-rRPBlPLqbBtIRNJB6cMgoeJns5k,239 -pip/_vendor/colorama/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/colorama/__pycache__/ansi.cpython-39.pyc,, -pip/_vendor/colorama/__pycache__/ansitowin32.cpython-39.pyc,, -pip/_vendor/colorama/__pycache__/initialise.cpython-39.pyc,, -pip/_vendor/colorama/__pycache__/win32.cpython-39.pyc,, -pip/_vendor/colorama/__pycache__/winterm.cpython-39.pyc,, -pip/_vendor/colorama/ansi.py,sha256=Top4EeEuaQdBWdteKMEcGOTeKeF19Q-Wo_6_Cj5kOzQ,2522 -pip/_vendor/colorama/ansitowin32.py,sha256=yV7CEmCb19MjnJKODZEEvMH_fnbJhwnpzo4sxZuGXmA,10517 -pip/_vendor/colorama/initialise.py,sha256=PprovDNxMTrvoNHFcL2NZjpH2XzDc8BLxLxiErfUl4k,1915 -pip/_vendor/colorama/win32.py,sha256=bJ8Il9jwaBN5BJ8bmN6FoYZ1QYuMKv2j8fGrXh7TJjw,5404 -pip/_vendor/colorama/winterm.py,sha256=2y_2b7Zsv34feAsP67mLOVc-Bgq51mdYGo571VprlrM,6438 -pip/_vendor/distlib/__init__.py,sha256=3veAk2rPznOB2gsK6tjbbh0TQMmGE5P82eE9wXq6NIk,581 -pip/_vendor/distlib/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/compat.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/database.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/index.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/locators.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/manifest.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/markers.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/metadata.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/resources.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/scripts.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/util.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/version.cpython-39.pyc,, -pip/_vendor/distlib/__pycache__/wheel.cpython-39.pyc,, -pip/_vendor/distlib/_backport/__init__.py,sha256=bqS_dTOH6uW9iGgd0uzfpPjo6vZ4xpPZ7kyfZJ2vNaw,274 -pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/distlib/_backport/__pycache__/misc.cpython-39.pyc,, -pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-39.pyc,, -pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-39.pyc,, -pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-39.pyc,, -pip/_vendor/distlib/_backport/misc.py,sha256=KWecINdbFNOxSOP1fGF680CJnaC6S4fBRgEtaYTw0ig,971 -pip/_vendor/distlib/_backport/shutil.py,sha256=IX_G2NPqwecJibkIDje04bqu0xpHkfSQ2GaGdEVqM5Y,25707 -pip/_vendor/distlib/_backport/sysconfig.cfg,sha256=swZKxq9RY5e9r3PXCrlvQPMsvOdiWZBTHLEbqS8LJLU,2617 -pip/_vendor/distlib/_backport/sysconfig.py,sha256=BQHFlb6pubCl_dvT1NjtzIthylofjKisox239stDg0U,26854 -pip/_vendor/distlib/_backport/tarfile.py,sha256=Ihp7rXRcjbIKw8COm9wSePV9ARGXbSF9gGXAMn2Q-KU,92628 -pip/_vendor/distlib/compat.py,sha256=ADA56xiAxar3mU6qemlBhNbsrFPosXRhO44RzsbJPqk,41408 -pip/_vendor/distlib/database.py,sha256=Kl0YvPQKc4OcpVi7k5cFziydM1xOK8iqdxLGXgbZHV4,51059 -pip/_vendor/distlib/index.py,sha256=SXKzpQCERctxYDMp_OLee2f0J0e19ZhGdCIoMlUfUQM,21066 -pip/_vendor/distlib/locators.py,sha256=c9E4cDEacJ_uKbuE5BqAVocoWp6rsuBGTkiNDQq3zV4,52100 -pip/_vendor/distlib/manifest.py,sha256=nQEhYmgoreaBZzyFzwYsXxJARu3fo4EkunU163U16iE,14811 -pip/_vendor/distlib/markers.py,sha256=6Ac3cCfFBERexiESWIOXmg-apIP8l2esafNSX3KMy-8,4387 -pip/_vendor/distlib/metadata.py,sha256=z2KPy3h3tcDnb9Xs7nAqQ5Oz0bqjWAUFmKWcFKRoodg,38962 -pip/_vendor/distlib/resources.py,sha256=2FGv0ZHF14KXjLIlL0R991lyQQGcewOS4mJ-5n-JVnc,10766 -pip/_vendor/distlib/scripts.py,sha256=_MAj3sMuv56kuM8FsiIWXqbT0gmumPGaOR_atOzn4a4,17180 -pip/_vendor/distlib/t32.exe,sha256=NS3xBCVAld35JVFNmb-1QRyVtThukMrwZVeXn4LhaEQ,96768 -pip/_vendor/distlib/t64.exe,sha256=oAqHes78rUWVM0OtVqIhUvequl_PKhAhXYQWnUf7zR0,105984 -pip/_vendor/distlib/util.py,sha256=f2jZCPrcLCt6LcnC0gUy-Fur60tXD8reA7k4rDpHMDw,59845 -pip/_vendor/distlib/version.py,sha256=_n7F6juvQGAcn769E_SHa7fOcf5ERlEVymJ_EjPRwGw,23391 -pip/_vendor/distlib/w32.exe,sha256=lJtnZdeUxTZWya_EW5DZos_K5rswRECGspIl8ZJCIXs,90112 -pip/_vendor/distlib/w64.exe,sha256=0aRzoN2BO9NWW4ENy4_4vHkHR4qZTFZNVSAJJYlODTI,99840 -pip/_vendor/distlib/wheel.py,sha256=v6DnwTqhNHwrEVFr8_YeiTW6G4ftP_evsywNgrmdb2o,41144 -pip/_vendor/distro.py,sha256=xxMIh2a3KmippeWEHzynTdHT3_jZM0o-pos0dAWJROM,43628 -pip/_vendor/html5lib/__init__.py,sha256=BYzcKCqeEii52xDrqBFruhnmtmkiuHXFyFh-cglQ8mk,1160 -pip/_vendor/html5lib/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-39.pyc,, -pip/_vendor/html5lib/__pycache__/_inputstream.cpython-39.pyc,, -pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-39.pyc,, -pip/_vendor/html5lib/__pycache__/_utils.cpython-39.pyc,, -pip/_vendor/html5lib/__pycache__/constants.cpython-39.pyc,, -pip/_vendor/html5lib/__pycache__/html5parser.cpython-39.pyc,, -pip/_vendor/html5lib/__pycache__/serializer.cpython-39.pyc,, -pip/_vendor/html5lib/_ihatexml.py,sha256=ifOwF7pXqmyThIXc3boWc96s4MDezqRrRVp7FwDYUFs,16728 -pip/_vendor/html5lib/_inputstream.py,sha256=jErNASMlkgs7MpOM9Ve_VdLDJyFFweAjLuhVutZz33U,32353 -pip/_vendor/html5lib/_tokenizer.py,sha256=04mgA2sNTniutl2fxFv-ei5bns4iRaPxVXXHh_HrV_4,77040 -pip/_vendor/html5lib/_trie/__init__.py,sha256=nqfgO910329BEVJ5T4psVwQtjd2iJyEXQ2-X8c1YxwU,109 -pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-39.pyc,, -pip/_vendor/html5lib/_trie/__pycache__/py.cpython-39.pyc,, -pip/_vendor/html5lib/_trie/_base.py,sha256=CaybYyMro8uERQYjby2tTeSUatnWDfWroUN9N7ety5w,1013 -pip/_vendor/html5lib/_trie/py.py,sha256=wXmQLrZRf4MyWNyg0m3h81m9InhLR7GJ002mIIZh-8o,1775 -pip/_vendor/html5lib/_utils.py,sha256=Dx9AKntksRjFT1veBj7I362pf5OgIaT0zglwq43RnfU,4931 -pip/_vendor/html5lib/constants.py,sha256=Ll-yzLU_jcjyAI_h57zkqZ7aQWE5t5xA4y_jQgoUUhw,83464 -pip/_vendor/html5lib/filters/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-39.pyc,, -pip/_vendor/html5lib/filters/__pycache__/base.cpython-39.pyc,, -pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-39.pyc,, -pip/_vendor/html5lib/filters/__pycache__/lint.cpython-39.pyc,, -pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-39.pyc,, -pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-39.pyc,, -pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-39.pyc,, -pip/_vendor/html5lib/filters/alphabeticalattributes.py,sha256=lViZc2JMCclXi_5gduvmdzrRxtO5Xo9ONnbHBVCsykU,919 -pip/_vendor/html5lib/filters/base.py,sha256=z-IU9ZAYjpsVsqmVt7kuWC63jR11hDMr6CVrvuao8W0,286 -pip/_vendor/html5lib/filters/inject_meta_charset.py,sha256=egDXUEHXmAG9504xz0K6ALDgYkvUrC2q15YUVeNlVQg,2945 -pip/_vendor/html5lib/filters/lint.py,sha256=jk6q56xY0ojiYfvpdP-OZSm9eTqcAdRqhCoPItemPYA,3643 -pip/_vendor/html5lib/filters/optionaltags.py,sha256=8lWT75J0aBOHmPgfmqTHSfPpPMp01T84NKu0CRedxcE,10588 -pip/_vendor/html5lib/filters/sanitizer.py,sha256=m6oGmkBhkGAnn2nV6D4hE78SCZ6WEnK9rKdZB3uXBIc,26897 -pip/_vendor/html5lib/filters/whitespace.py,sha256=8eWqZxd4UC4zlFGW6iyY6f-2uuT8pOCSALc3IZt7_t4,1214 -pip/_vendor/html5lib/html5parser.py,sha256=anr-aXre_ImfrkQ35c_rftKXxC80vJCREKe06Tq15HA,117186 -pip/_vendor/html5lib/serializer.py,sha256=_PpvcZF07cwE7xr9uKkZqh5f4UEaI8ltCU2xPJzaTpk,15759 -pip/_vendor/html5lib/treeadapters/__init__.py,sha256=A0rY5gXIe4bJOiSGRO_j_tFhngRBO8QZPzPtPw5dFzo,679 -pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-39.pyc,, -pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-39.pyc,, -pip/_vendor/html5lib/treeadapters/genshi.py,sha256=CH27pAsDKmu4ZGkAUrwty7u0KauGLCZRLPMzaO3M5vo,1715 -pip/_vendor/html5lib/treeadapters/sax.py,sha256=BKS8woQTnKiqeffHsxChUqL4q2ZR_wb5fc9MJ3zQC8s,1776 -pip/_vendor/html5lib/treebuilders/__init__.py,sha256=AysSJyvPfikCMMsTVvaxwkgDieELD5dfR8FJIAuq7hY,3592 -pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-39.pyc,, -pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-39.pyc,, -pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-39.pyc,, -pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-39.pyc,, -pip/_vendor/html5lib/treebuilders/base.py,sha256=z-o51vt9r_l2IDG5IioTOKGzZne4Fy3_Fc-7ztrOh4I,14565 -pip/_vendor/html5lib/treebuilders/dom.py,sha256=22whb0C71zXIsai5mamg6qzBEiigcBIvaDy4Asw3at0,8925 -pip/_vendor/html5lib/treebuilders/etree.py,sha256=w5ZFpKk6bAxnrwD2_BrF5EVC7vzz0L3LMi9Sxrbc_8w,12836 -pip/_vendor/html5lib/treebuilders/etree_lxml.py,sha256=9gqDjs-IxsPhBYa5cpvv2FZ1KZlG83Giusy2lFmvIkE,14766 -pip/_vendor/html5lib/treewalkers/__init__.py,sha256=OBPtc1TU5mGyy18QDMxKEyYEz0wxFUUNj5v0-XgmYhY,5719 -pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-39.pyc,, -pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-39.pyc,, -pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-39.pyc,, -pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-39.pyc,, -pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-39.pyc,, -pip/_vendor/html5lib/treewalkers/base.py,sha256=ouiOsuSzvI0KgzdWP8PlxIaSNs9falhbiinAEc_UIJY,7476 -pip/_vendor/html5lib/treewalkers/dom.py,sha256=EHyFR8D8lYNnyDU9lx_IKigVJRyecUGua0mOi7HBukc,1413 -pip/_vendor/html5lib/treewalkers/etree.py,sha256=xo1L5m9VtkfpFJK0pFmkLVajhqYYVisVZn3k9kYpPkI,4551 -pip/_vendor/html5lib/treewalkers/etree_lxml.py,sha256=_b0LAVWLcVu9WaU_-w3D8f0IRSpCbjf667V-3NRdhTw,6357 -pip/_vendor/html5lib/treewalkers/genshi.py,sha256=4D2PECZ5n3ZN3qu3jMl9yY7B81jnQApBQSVlfaIuYbA,2309 -pip/_vendor/idna/__init__.py,sha256=9Nt7xpyet3DmOrPUGooDdAwmHZZu1qUAy2EaJ93kGiQ,58 -pip/_vendor/idna/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/idna/__pycache__/codec.cpython-39.pyc,, -pip/_vendor/idna/__pycache__/compat.cpython-39.pyc,, -pip/_vendor/idna/__pycache__/core.cpython-39.pyc,, -pip/_vendor/idna/__pycache__/idnadata.cpython-39.pyc,, -pip/_vendor/idna/__pycache__/intranges.cpython-39.pyc,, -pip/_vendor/idna/__pycache__/package_data.cpython-39.pyc,, -pip/_vendor/idna/__pycache__/uts46data.cpython-39.pyc,, -pip/_vendor/idna/codec.py,sha256=4RVMhqFquJgyGBKyl40ARqcgDzkDDXZUvyl1EOCRLFE,3027 -pip/_vendor/idna/compat.py,sha256=g-7Ph45nzILe_7xvxdbTebrHZq4mQWxIOH1rjMc6xrs,232 -pip/_vendor/idna/core.py,sha256=VdFGQyiit1eMKUQ2x0mNXoGThrXlRyp070mPDyLX9Yg,11849 -pip/_vendor/idna/idnadata.py,sha256=cl4x9RLdw1ZMtEEbvKwAsX-Id3AdIjO5U3HaoKM6VGs,42350 -pip/_vendor/idna/intranges.py,sha256=TY1lpxZIQWEP6tNqjZkFA5hgoMWOj1OBmnUG8ihT87E,1749 -pip/_vendor/idna/package_data.py,sha256=kxptFveZ37zbPSmKU7KMEA8Pi7h3-sM1-p2agm2PpCI,21 -pip/_vendor/idna/uts46data.py,sha256=4CZEB6ZQgmSNIATBn2V_xdW9PEgVOXAOYRzCeQGsK_E,196224 -pip/_vendor/msgpack/__init__.py,sha256=2gJwcsTIaAtCM0GMi2rU-_Y6kILeeQuqRkrQ22jSANc,1118 -pip/_vendor/msgpack/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/msgpack/__pycache__/_version.cpython-39.pyc,, -pip/_vendor/msgpack/__pycache__/exceptions.cpython-39.pyc,, -pip/_vendor/msgpack/__pycache__/ext.cpython-39.pyc,, -pip/_vendor/msgpack/__pycache__/fallback.cpython-39.pyc,, -pip/_vendor/msgpack/_version.py,sha256=dFR03oACnj4lsKd1RnwD7BPMiVI_FMygdOL1TOBEw_U,20 -pip/_vendor/msgpack/exceptions.py,sha256=dCTWei8dpkrMsQDcjQk74ATl9HsIBH0ybt8zOPNqMYc,1081 -pip/_vendor/msgpack/ext.py,sha256=4l356Y4sVEcvCla2dh_cL57vh4GMhZfa3kuWHFHYz6A,6088 -pip/_vendor/msgpack/fallback.py,sha256=Rpv1Ldey8f8ueRnQznD4ARKBn9dxM2PywVNkXI8IEeE,38026 -pip/_vendor/packaging/__about__.py,sha256=j4B7IMMSqpUnYzcYd5H5WZlILXevD7Zm_n9lj_TROTw,726 -pip/_vendor/packaging/__init__.py,sha256=6enbp5XgRfjBjsI9-bn00HjHf5TH21PDMOKkJW8xw-w,562 -pip/_vendor/packaging/__pycache__/__about__.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/_compat.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/_structures.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/_typing.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/markers.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/requirements.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/tags.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/utils.cpython-39.pyc,, -pip/_vendor/packaging/__pycache__/version.cpython-39.pyc,, -pip/_vendor/packaging/_compat.py,sha256=MXdsGpSE_W-ZrHoC87andI4LV2FAwU7HLL-eHe_CjhU,1128 -pip/_vendor/packaging/_structures.py,sha256=ozkCX8Q8f2qE1Eic3YiQ4buDVfgz2iYevY9e7R2y3iY,2022 -pip/_vendor/packaging/_typing.py,sha256=VgA0AAvsc97KB5nF89zoudOyCMEsV7FlaXzZbYqEkzA,1824 -pip/_vendor/packaging/markers.py,sha256=8DOn1c7oZ_DySBlLom_9o49GzobVGYN8-kpK_nsj8oQ,9472 -pip/_vendor/packaging/requirements.py,sha256=MHqf_FKihHC0VkOB62ZUdUyG8okEL97D4Xy_jK1yFS0,5110 -pip/_vendor/packaging/specifiers.py,sha256=RaxQ-JKyCqI5QBm6gDvboZ2K6jjLVd-pxq0kvYf28kc,32208 -pip/_vendor/packaging/tags.py,sha256=BMEL_3W3E8nXK_AXAWqmlYccsvoznFKkTBkTPR48DB8,29561 -pip/_vendor/packaging/utils.py,sha256=5vUxwCVYSmaNJFgd7KaCBpxHXQN89KIvRLvCsDzao0k,4385 -pip/_vendor/packaging/version.py,sha256=t7FpsZKmDncMn6EG28dEu_5NBZUa9_HVoiG-fsDo3oc,15974 -pip/_vendor/pep517/__init__.py,sha256=mju9elFHLEUJ23rU5Zpdj8nROdY0Vj3bp4ZgvBTs6bg,130 -pip/_vendor/pep517/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/pep517/__pycache__/build.cpython-39.pyc,, -pip/_vendor/pep517/__pycache__/check.cpython-39.pyc,, -pip/_vendor/pep517/__pycache__/colorlog.cpython-39.pyc,, -pip/_vendor/pep517/__pycache__/compat.cpython-39.pyc,, -pip/_vendor/pep517/__pycache__/dirtools.cpython-39.pyc,, -pip/_vendor/pep517/__pycache__/envbuild.cpython-39.pyc,, -pip/_vendor/pep517/__pycache__/meta.cpython-39.pyc,, -pip/_vendor/pep517/__pycache__/wrappers.cpython-39.pyc,, -pip/_vendor/pep517/build.py,sha256=Z49CmRFafX7NjoBModiibwQYa_EYz3E0F31b7D5WVvs,3456 -pip/_vendor/pep517/check.py,sha256=8LJLtfZ99zAcV4vKJ1a-odMxg2sEImD7RMNg_Ere-1Y,6082 -pip/_vendor/pep517/colorlog.py,sha256=Tk9AuYm_cLF3BKTBoSTJt9bRryn0aFojIQOwbfVUTxQ,4098 -pip/_vendor/pep517/compat.py,sha256=M-5s4VNp8rjyT76ZZ_ibnPD44DYVzSQlyCEHayjtDPw,780 -pip/_vendor/pep517/dirtools.py,sha256=2mkAkAL0mRz_elYFjRKuekTJVipH1zTn4tbf1EDev84,1129 -pip/_vendor/pep517/envbuild.py,sha256=szKUFlO50X1ahQfXwz4hD9V2VE_bz9MLVPIeidsFo4w,6041 -pip/_vendor/pep517/in_process/__init__.py,sha256=MyWoAi8JHdcBv7yXuWpUSVADbx6LSB9rZh7kTIgdA8Y,563 -pip/_vendor/pep517/in_process/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/pep517/in_process/__pycache__/_in_process.cpython-39.pyc,, -pip/_vendor/pep517/in_process/_in_process.py,sha256=XrKOTURJdia5R7i3i_OQmS89LASFXE3HQXfX63qZBIE,8438 -pip/_vendor/pep517/meta.py,sha256=8mnM5lDnT4zXQpBTliJbRGfesH7iioHwozbDxALPS9Y,2463 -pip/_vendor/pep517/wrappers.py,sha256=QYZfN1nWoq4Z2krY-UX14JLAxkdNwujYjRGf7qFc914,11044 -pip/_vendor/pkg_resources/__init__.py,sha256=XpGBfvS9fafA6bm5rx7vnxdxs7yqyoc_NnpzKApkJ64,108277 -pip/_vendor/pkg_resources/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-39.pyc,, -pip/_vendor/pkg_resources/py31compat.py,sha256=CRk8fkiPRDLsbi5pZcKsHI__Pbmh_94L8mr9Qy9Ab2U,562 -pip/_vendor/progress/__init__.py,sha256=fcbQQXo5np2CoQyhSH5XprkicwLZNLePR3uIahznSO0,4857 -pip/_vendor/progress/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/progress/__pycache__/bar.cpython-39.pyc,, -pip/_vendor/progress/__pycache__/counter.cpython-39.pyc,, -pip/_vendor/progress/__pycache__/spinner.cpython-39.pyc,, -pip/_vendor/progress/bar.py,sha256=QuDuVNcmXgpxtNtxO0Fq72xKigxABaVmxYGBw4J3Z_E,2854 -pip/_vendor/progress/counter.py,sha256=MznyBrvPWrOlGe4MZAlGUb9q3aODe6_aNYeAE_VNoYA,1372 -pip/_vendor/progress/spinner.py,sha256=k8JbDW94T0-WXuXfxZIFhdoNPYp3jfnpXqBnfRv5fGs,1380 -pip/_vendor/pyparsing.py,sha256=J1b4z3S_KwyJW7hKGnoN-hXW9pgMIzIP6QThyY5yJq4,273394 -pip/_vendor/requests/__init__.py,sha256=ib7nRjDadbCMOeX2sMQLcbXzy982HoKRY2LD_gWqwPM,4458 -pip/_vendor/requests/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/__version__.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/_internal_utils.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/adapters.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/api.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/auth.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/certs.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/compat.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/cookies.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/exceptions.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/help.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/hooks.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/models.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/packages.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/sessions.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/status_codes.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/structures.cpython-39.pyc,, -pip/_vendor/requests/__pycache__/utils.cpython-39.pyc,, -pip/_vendor/requests/__version__.py,sha256=k4J8c1yFRFzwGWwlN7miaDOclFtbcIs1GlnmT17YbXQ,441 -pip/_vendor/requests/_internal_utils.py,sha256=Zx3PnEUccyfsB-ie11nZVAW8qClJy0gx1qNME7rgT18,1096 -pip/_vendor/requests/adapters.py,sha256=e-bmKEApNVqFdylxuMJJfiaHdlmS_zhWhIMEzlHvGuc,21548 -pip/_vendor/requests/api.py,sha256=PlHM-HT3PQ5lyufoeGmV-nJxRi7UnUyGVh7OV7B9XV4,6496 -pip/_vendor/requests/auth.py,sha256=OMoJIVKyRLy9THr91y8rxysZuclwPB-K1Xg1zBomUhQ,10207 -pip/_vendor/requests/certs.py,sha256=nXRVq9DtGmv_1AYbwjTu9UrgAcdJv05ZvkNeaoLOZxY,465 -pip/_vendor/requests/compat.py,sha256=LQWuCR4qXk6w7-qQopXyz0WNHUdAD40k0mKnaAEf1-g,2045 -pip/_vendor/requests/cookies.py,sha256=Y-bKX6TvW3FnYlE6Au0SXtVVWcaNdFvuAwQxw-G0iTI,18430 -pip/_vendor/requests/exceptions.py,sha256=d9fJJw8YFBB9VzG9qhvxLuOx6be3c_Dwbck-dVUEAcs,3173 -pip/_vendor/requests/help.py,sha256=SJPVcoXeo7KfK4AxJN5eFVQCjr0im87tU2n7ubLsksU,3578 -pip/_vendor/requests/hooks.py,sha256=QReGyy0bRcr5rkwCuObNakbYsc7EkiKeBwG4qHekr2Q,757 -pip/_vendor/requests/models.py,sha256=UkkaVuU1tc-BKYB41dds35saisoTpaYJ2YBCFZEEfhM,34373 -pip/_vendor/requests/packages.py,sha256=njJmVifY4aSctuW3PP5EFRCxjEwMRDO6J_feG2dKWsI,695 -pip/_vendor/requests/sessions.py,sha256=BsnR-zYILgoFzJ6yq4T8ht_i0PwwPGVAxWxWaV5dcHg,30137 -pip/_vendor/requests/status_codes.py,sha256=gT79Pbs_cQjBgp-fvrUgg1dn2DQO32bDj4TInjnMPSc,4188 -pip/_vendor/requests/structures.py,sha256=msAtr9mq1JxHd-JRyiILfdFlpbJwvvFuP3rfUQT_QxE,3005 -pip/_vendor/requests/utils.py,sha256=_K9AgkN6efPe-a-zgZurXzds5PBC0CzDkyjAE2oCQFQ,30529 -pip/_vendor/resolvelib/__init__.py,sha256=QWAqNErjxqEMKl-AUccXz10aCKVmO-WmWvxUl3QOlFY,537 -pip/_vendor/resolvelib/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/resolvelib/__pycache__/providers.cpython-39.pyc,, -pip/_vendor/resolvelib/__pycache__/reporters.cpython-39.pyc,, -pip/_vendor/resolvelib/__pycache__/resolvers.cpython-39.pyc,, -pip/_vendor/resolvelib/__pycache__/structs.cpython-39.pyc,, -pip/_vendor/resolvelib/compat/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-39.pyc,, -pip/_vendor/resolvelib/compat/collections_abc.py,sha256=uy8xUZ-NDEw916tugUXm8HgwCGiMO0f-RcdnpkfXfOs,156 -pip/_vendor/resolvelib/providers.py,sha256=bfzFDZd7UqkkAS7lUM_HeYbA-HzjKfDlle_pn_79vio,5638 -pip/_vendor/resolvelib/reporters.py,sha256=hQvvXuuEBOyEWO8KDfLsWKVjX55UFMAUwO0YZMNpzAw,1364 -pip/_vendor/resolvelib/resolvers.py,sha256=P6aq-7pY5E7zROb0zUUWqFIHEA9Lm0MWsx_bYXzUg3A,17292 -pip/_vendor/resolvelib/structs.py,sha256=Z6m4CkKJlWH4ZIKelEsKNeZqKTvyux4hqBNzY4kZzLo,4495 -pip/_vendor/six.py,sha256=U4Z_yv534W5CNyjY9i8V1OXY2SjAny8y2L5vDLhhThM,34159 -pip/_vendor/tenacity/__init__.py,sha256=MVs5n8anwg_rEiX2_QItExciIdgLDwSnukiFDyjChJw,16790 -pip/_vendor/tenacity/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/_asyncio.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/_utils.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/after.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/before.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/before_sleep.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/compat.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/nap.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/retry.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/stop.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-39.pyc,, -pip/_vendor/tenacity/__pycache__/wait.cpython-39.pyc,, -pip/_vendor/tenacity/_asyncio.py,sha256=6C4Sfv9IOUYf1-0vuIoE6OGbmJrJywH0-YslrxmbxKw,2833 -pip/_vendor/tenacity/_utils.py,sha256=W1nujHum1f9i4RQpOSjqsQo9_mQtaUtNznXAmQHsL28,4555 -pip/_vendor/tenacity/after.py,sha256=KNIi2WT83r4eqA3QaXMK1zXQzkbLgVHj5uRanY6HabM,1307 -pip/_vendor/tenacity/before.py,sha256=B9pAXn6_J1UKzwTL9nFtRpOhNg8s5vGSi4bqnx4-laA,1154 -pip/_vendor/tenacity/before_sleep.py,sha256=lZEMHNaFRmdCcws3Moh4EOZ9zeo4MRxskdiUudvNuvY,1784 -pip/_vendor/tenacity/compat.py,sha256=dHonJkJlHwD2cmqLrYHYU0Tdzm2bn1-76QZSt6OCemw,739 -pip/_vendor/tenacity/nap.py,sha256=7VVudOTmuv_-C_XJlvjGcgHbV6_A2HlzymaXu8vj1d8,1280 -pip/_vendor/tenacity/retry.py,sha256=xskLGa15EsNhPPOmIUcKS7CqjaRAtWxGFNPNRjjz9UU,5463 -pip/_vendor/tenacity/stop.py,sha256=4cjSe_YPSawz6iI-QBDN0xFfE_zlKvjhFwx21ZlyD2E,2435 -pip/_vendor/tenacity/tornadoweb.py,sha256=q3XZW2A9Rky1BhUQbNHF61hM1EXQ57dA7wxPnlSOx3s,1729 -pip/_vendor/tenacity/wait.py,sha256=FAoIfIUSNf5OWJYT7nhjFC0uOVijHMBd56AJRyLN230,6017 -pip/_vendor/toml/__init__.py,sha256=kYgYzehhUx1cctsuprmjEKwnSdmQeC53cTxi7nxQrko,747 -pip/_vendor/toml/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/toml/__pycache__/decoder.cpython-39.pyc,, -pip/_vendor/toml/__pycache__/encoder.cpython-39.pyc,, -pip/_vendor/toml/__pycache__/ordered.cpython-39.pyc,, -pip/_vendor/toml/__pycache__/tz.cpython-39.pyc,, -pip/_vendor/toml/decoder.py,sha256=deDPQqpj92SG6pAtwLbgKHrIsly7hAZG-U6g2y7hyGc,38954 -pip/_vendor/toml/encoder.py,sha256=tBe93_GB21K52TlSbMiYuGeIGXH70F2WzAg-lIfVoko,9964 -pip/_vendor/toml/ordered.py,sha256=UWt5Eka90IWVBYdvLgY5PXnkBcVYpHjnw9T67rM85T8,378 -pip/_vendor/toml/tz.py,sha256=-5vg8wkg_atnVi2TnEveexIVE7T_FxBVr_-2WVfO1oA,701 -pip/_vendor/urllib3/__init__.py,sha256=j3yzHIbmW7CS-IKQJ9-PPQf_YKO8EOAey_rMW0UR7us,2763 -pip/_vendor/urllib3/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/_collections.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/_version.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/connection.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/connectionpool.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/exceptions.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/fields.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/filepost.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/poolmanager.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/request.cpython-39.pyc,, -pip/_vendor/urllib3/__pycache__/response.cpython-39.pyc,, -pip/_vendor/urllib3/_collections.py,sha256=Rp1mVyBgc_UlAcp6M3at1skJBXR5J43NawRTvW2g_XY,10811 -pip/_vendor/urllib3/_version.py,sha256=2Bjk_cB49921PTvereWp8ZR3NhLNoCMAyHSGP-OesLk,63 -pip/_vendor/urllib3/connection.py,sha256=q-vf_TM3MyRbZcFn3-VCKZBSf0oEhGjv7BFeZm_7kw4,18748 -pip/_vendor/urllib3/connectionpool.py,sha256=IKoeuJZY9YAYm0GK4q-MXAhyXW0M_FnvabYaNsDIR-E,37133 -pip/_vendor/urllib3/contrib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/_appengine_environ.py,sha256=bDbyOEhW2CKLJcQqAKAyrEHN-aklsyHFKq6vF8ZFsmk,957 -pip/_vendor/urllib3/contrib/_securetransport/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc,, -pip/_vendor/urllib3/contrib/_securetransport/bindings.py,sha256=eRy1Mj-wpg7sR6-OSvnSV4jUbjMT464dLN_CWxbIRVw,17649 -pip/_vendor/urllib3/contrib/_securetransport/low_level.py,sha256=lgIdsSycqfB0Xm5BiJzXGeIKT7ybCQMFPJAgkcwPa1s,13908 -pip/_vendor/urllib3/contrib/appengine.py,sha256=lm86XjaOI7ajbonsN0JLA0ckkgSFWhgxWKLW_Ymt4sI,11034 -pip/_vendor/urllib3/contrib/ntlmpool.py,sha256=6I95h1_71fzxmoMSNtY0gB8lnyCoVtP_DpqFGj14fdU,4160 -pip/_vendor/urllib3/contrib/pyopenssl.py,sha256=kqm9SX4h_6h76QwGDBiNQ7i-ktKZunZuxzTVjjtHDto,16795 -pip/_vendor/urllib3/contrib/securetransport.py,sha256=MEEHa3YqG8ifDPYG0gO12C1tZu2I-HqGF4lC53cHFPg,34303 -pip/_vendor/urllib3/contrib/socks.py,sha256=DcRjM2l0rQMIyhYrN6r-tnVkY6ZTDxHJlM8_usAkGCA,7097 -pip/_vendor/urllib3/exceptions.py,sha256=0Mnno3KHTNfXRfY7638NufOPkUb6mXOm-Lqj-4x2w8A,8217 -pip/_vendor/urllib3/fields.py,sha256=kvLDCg_JmH1lLjUUEY_FLS8UhY7hBvDPuVETbY8mdrM,8579 -pip/_vendor/urllib3/filepost.py,sha256=5b_qqgRHVlL7uLtdAYBzBh-GHmU5AfJVt_2N0XS3PeY,2440 -pip/_vendor/urllib3/packages/__init__.py,sha256=h4BLhD4tLaBx1adaDtKXfupsgqY0wWLXb_f1_yVlV6A,108 -pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/urllib3/packages/__pycache__/six.cpython-39.pyc,, -pip/_vendor/urllib3/packages/backports/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 -pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc,, -pip/_vendor/urllib3/packages/backports/makefile.py,sha256=nbzt3i0agPVP07jqqgjhaYjMmuAi_W5E0EywZivVO8E,1417 -pip/_vendor/urllib3/packages/six.py,sha256=adx4z-eM_D0Vvu0IIqVzFACQ_ux9l64y7DkSEfbxCDs,32536 -pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py,sha256=zppezdEQdpGsYerI6mV6MfUYy495JV4mcOWC_GgbljU,757 -pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc,, -pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py,sha256=6dZ-q074g7XhsJ27MFCgkct8iVNZB3sMZvKhf-KUVy0,5679 -pip/_vendor/urllib3/poolmanager.py,sha256=whzlX6UTEgODMOCy0ZDMUONRBCz5wyIM8Z9opXAY-Lk,19763 -pip/_vendor/urllib3/request.py,sha256=ZFSIqX0C6WizixecChZ3_okyu7BEv0lZu1VT0s6h4SM,5985 -pip/_vendor/urllib3/response.py,sha256=hGhGBh7TkEkh_IQg5C1W_xuPNrgIKv5BUXPyE-q0LuE,28203 -pip/_vendor/urllib3/util/__init__.py,sha256=JEmSmmqqLyaw8P51gUImZh8Gwg9i1zSe-DoqAitn2nc,1155 -pip/_vendor/urllib3/util/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/connection.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/proxy.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/queue.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/request.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/response.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/retry.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/timeout.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/url.cpython-39.pyc,, -pip/_vendor/urllib3/util/__pycache__/wait.cpython-39.pyc,, -pip/_vendor/urllib3/util/connection.py,sha256=_I-ZoF58xXLLjo-Q5IGaJrMxy2IW_exI8K9O9pq7op0,4922 -pip/_vendor/urllib3/util/proxy.py,sha256=FGipAEnvZteyldXNjce4DEB7YzwU-a5lep8y5S0qHQg,1604 -pip/_vendor/urllib3/util/queue.py,sha256=nRgX8_eX-_VkvxoX096QWoz8Ps0QHUAExILCY_7PncM,498 -pip/_vendor/urllib3/util/request.py,sha256=NnzaEKQ1Pauw5MFMV6HmgEMHITf0Aua9fQuzi2uZzGc,4123 -pip/_vendor/urllib3/util/response.py,sha256=GJpg3Egi9qaJXRwBh5wv-MNuRWan5BIu40oReoxWP28,3510 -pip/_vendor/urllib3/util/retry.py,sha256=s3ZNKXO6_t23ZQMg8zlu20PMSqraT495-S_mEY_19ak,21396 -pip/_vendor/urllib3/util/ssl_.py,sha256=dKcH-sqiR_ESWqKP1PJ6SUAUSvqC-fkMQGrTokV4NMY,16281 -pip/_vendor/urllib3/util/ssltransport.py,sha256=vOOCPRn-dODUZ2qtMCfStb0JmjgrgJaKLqJ9qvKucFs,6932 -pip/_vendor/urllib3/util/timeout.py,sha256=QSbBUNOB9yh6AnDn61SrLQ0hg5oz0I9-uXEG91AJuIg,10003 -pip/_vendor/urllib3/util/url.py,sha256=KP_yaHA0TFFAsQSImc_FOHO-Wq3PNHf_bKObKcrgdU4,13981 -pip/_vendor/urllib3/util/wait.py,sha256=3MUKRSAUJDB2tgco7qRUskW0zXGAWYvRRE4Q1_6xlLs,5404 -pip/_vendor/vendor.txt,sha256=yaN2qLLkKuoRmFLCxGJ1LZtZiuV7T7NoisZqwWNRhIU,364 -pip/_vendor/webencodings/__init__.py,sha256=qOBJIuPy_4ByYH6W_bNgJF-qYQ2DoU-dKsDu5yRWCXg,10579 -pip/_vendor/webencodings/__pycache__/__init__.cpython-39.pyc,, -pip/_vendor/webencodings/__pycache__/labels.cpython-39.pyc,, -pip/_vendor/webencodings/__pycache__/mklabels.cpython-39.pyc,, -pip/_vendor/webencodings/__pycache__/tests.cpython-39.pyc,, -pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-39.pyc,, -pip/_vendor/webencodings/labels.py,sha256=4AO_KxTddqGtrL9ns7kAPjb0CcN6xsCIxbK37HY9r3E,8979 -pip/_vendor/webencodings/mklabels.py,sha256=GYIeywnpaLnP0GSic8LFWgd0UVvO_l1Nc6YoF-87R_4,1305 -pip/_vendor/webencodings/tests.py,sha256=OtGLyjhNY1fvkW1GvLJ_FV9ZoqC9Anyjr7q3kxTbzNs,6563 -pip/_vendor/webencodings/x_user_defined.py,sha256=yOqWSdmpytGfUgh_Z6JYgDNhoc-BAHyyeeT15Fr42tM,4307 -pip/py.typed,sha256=l9g-Fc1zgtIZ70tLJDcx6qKeqDutTVVSceIqUod-awg,286 diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/WHEEL b/env/Lib/site-packages/pip-21.1.3.dist-info/WHEEL deleted file mode 100644 index 385faab0..00000000 --- a/env/Lib/site-packages/pip-21.1.3.dist-info/WHEEL +++ /dev/null @@ -1,5 +0,0 @@ -Wheel-Version: 1.0 -Generator: bdist_wheel (0.36.2) -Root-Is-Purelib: true -Tag: py3-none-any - diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/entry_points.txt b/env/Lib/site-packages/pip-21.1.3.dist-info/entry_points.txt deleted file mode 100644 index d48bd8a8..00000000 --- a/env/Lib/site-packages/pip-21.1.3.dist-info/entry_points.txt +++ /dev/null @@ -1,5 +0,0 @@ -[console_scripts] -pip = pip._internal.cli.main:main -pip3 = pip._internal.cli.main:main -pip3.8 = pip._internal.cli.main:main - diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/top_level.txt b/env/Lib/site-packages/pip-21.1.3.dist-info/top_level.txt deleted file mode 100644 index a1b589e3..00000000 --- a/env/Lib/site-packages/pip-21.1.3.dist-info/top_level.txt +++ /dev/null @@ -1 +0,0 @@ -pip diff --git a/env/Lib/site-packages/pip/__init__.py b/env/Lib/site-packages/pip/__init__.py index 75815d8b..6633ef7e 100644 --- a/env/Lib/site-packages/pip/__init__.py +++ b/env/Lib/site-packages/pip/__init__.py @@ -1,10 +1,9 @@ from typing import List, Optional -__version__ = "21.1.3" +__version__ = "23.2.1" -def main(args=None): - # type: (Optional[List[str]]) -> int +def main(args: Optional[List[str]] = None) -> int: """This is an internal API only meant for use by pip's own console scripts. For additional details, see https://github.com/pypa/pip/issues/7498. diff --git a/env/Lib/site-packages/pip/__main__.py b/env/Lib/site-packages/pip/__main__.py index fe34a7b7..59913261 100644 --- a/env/Lib/site-packages/pip/__main__.py +++ b/env/Lib/site-packages/pip/__main__.py @@ -1,6 +1,5 @@ import os import sys -import warnings # Remove '' and current working directory from the first entry # of sys.path, if present to avoid using current directory @@ -20,12 +19,6 @@ if __package__ == "": sys.path.insert(0, path) if __name__ == "__main__": - # Work around the error reported in #9540, pending a proper fix. - # Note: It is essential the warning filter is set *before* importing - # pip, as the deprecation happens at import time, not runtime. - warnings.filterwarnings( - "ignore", category=DeprecationWarning, module=".*packaging\\.version" - ) from pip._internal.cli.main import main as _main sys.exit(_main()) diff --git a/env/Lib/site-packages/pip/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index dc3d1815e1a9ac6e62163d03e139a6282a04e7a4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 618 zcmYe~<>g{vU|^UdaWJ)jk%8ech=Yuo85kHG7#J9el^7TpQW#Pga~N_NqZo6UqL>&N zQkbHcQ`k~iQdnCUqgYaygBdj0UxIXNGTmbF$t*6p#o=F2l9`{Em{Y}OWT<DTXY7~E z2vPvWObiSRAnXjXK?Gz2V+s?<hFV5Oh8o5ihGxcK22JLw=^+`J#R{3l3W<3NnRz9t zMR|!i3XTDu3i)|Cl?u73iFqXoY57G8rNyZVNtFr(nFZ>_3i;)E3d#9-#rZj@3dPAq znFS@qdR$xz3JMBt`9%teDJhu{rzxbQmLz886zeDyr=}`ol#~<{Tj}ekXO?7?Cg~;T z=js<!79{EyWESXW78jSM7VDdvSX$_T4Jrb8Mw9UtM|^ovVnIP_ktWkE`GU*>y?B@_ z^-4=JbBgs+^Gb>;3-UAbN{WkE7#J8p0hCyj4&kh1C}L+|VE9$wY!wq)oLW>IlbVx~ zSrp@+m+DfKS(d7xs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2?CR?p9O4?JU=|Y);1iQ* zqMMVSo>^RynH`gwR~F-wnG{o;S(2(-keHmEn4Vf31M)<Cd}dx|NqoFsLFFx$+{Da0 zHc;S$9L2!K!&Jlxavh_eChIM>lFEY2y!0Ya1QmhO!7c9i__EZZ;>`TK_;|2Fu)C26 c4h9B>TO2mI`6;D2sdk{iDFzuVz{J7~04z76v;Y7A diff --git a/env/Lib/site-packages/pip/__pycache__/__main__.cpython-39.pyc b/env/Lib/site-packages/pip/__pycache__/__main__.cpython-39.pyc deleted file mode 100644 index bd7a243e21c993216c2db568cdbfd2a812a53f8a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 615 zcmYe~<>g{vU|^UdaWHiq3j@Pr5C<8vGB7YWFfcF_&tPC+NMT4}%wdRv(2P-xU_Mh6 zQz~N?a|(kbLkd$W!vdCt3~5Yd3`JHT(FLq23=0_<8B*C&n6jCQQc@YRm=~}^Nsfh# z3mK!B!Rk0u7*d%RGBGlwa-}e5GZjrqWy<1CVM*mlVNGG{Wo87~$)3ZT%NNDZ$dJmo zKp>UB8EkS2V=#jz$4ii#{cbVb;)svWP0Y-TkH5v1nVy$llv*XCr&W-coSm4SnU@}; zSC(2-oSC1e$#jb&Ik6-)J-?{(7F%w9N@-52CgUv@kX}u}TTJ=Ix0s77i*Iq1Cl=*p z=A{?kVkt;0$+*Rqo?4Pzo^p%1Aiv-icYHj=<ka~1TkI*BMR|$2sUR1mW#)i{*fR5q zQ;SMKA|RRg_*;BwnK>n?MQ}rfTv7{)Qj-%)GV}AoAvWC-E66O+i_gp}NiE7t%+X8E z$<zb6s)(I|f#DV_*mt*BQY$h`Rx%VxFfc%fUj@!qF`>n&Ma40xIVqV%G5&d}E=8GT zsS3IZp?;oWu0g?`A&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+Ir-_C#U+{9 zF{ycFF+Q0|F~ylBsk%@f7RMB17U;tQSFfP*7KaTa*z6cV$wP{Pfq{dOgOP(xjFE?h UgH?o)kBNhYg^}$)8#50R09GKi`~Uy| diff --git a/env/Lib/site-packages/pip/_internal/__init__.py b/env/Lib/site-packages/pip/_internal/__init__.py index 41071cd8..6afb5c62 100644 --- a/env/Lib/site-packages/pip/_internal/__init__.py +++ b/env/Lib/site-packages/pip/_internal/__init__.py @@ -1,10 +1,14 @@ from typing import List, Optional import pip._internal.utils.inject_securetransport # noqa +from pip._internal.utils import _log +# init_logging() must be called before any call to logging.getLogger() +# which happens at import of most modules. +_log.init_logging() -def main(args=None): - # type: (Optional[List[str]]) -> int + +def main(args: (Optional[List[str]]) = None) -> int: """This is preserved for old console scripts that may still be referencing it. diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 7fe14dae3c07d62767e554113e942c5938779003..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 667 zcmYe~<>g{vU|^UdaWHijBLl-@5C<7EGcYhXFfcF_t1&Pzq%fo~<}l<kMlt3xMKLjg z_)Iy>Q7kE}Da<J>EsRmDDNMl(nrtsYCTKF<V)4l=F1f|wUr>^npO={9m&^!~fMO;F z1_lsz2AM7bGMzDn31oULBO^l%V+}(yV=#jzbJe_%jLc$%%wmOtqSWHlqO#N!g|z%4 zh5Vcph2;Fa;{2Rch2rF*%z~0)g_4ZK5{2BvN`>N*%$yvBq*R5X)U?#1)V$=(ymT%F z1qFr75<M<3!!5r^Au%N-6XG(3l+=>M%$#B!h2qpyg^ZGtf?_Lu{q)R|jM5~%<osOy zg35wK{esK_{mkOx($r#oa}!GoJ+MJVAU|m`-r|TaFG?&ZNG;N2x+PzbS)do6nOBlp zl$V&JS6Y&pQ>>SoS5j12ke``XQe4Esz`y_spTwec2xlcj5jz6|!>=l5tC-N@)S}{; z)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0e?Qk?Psf;GS6|oQ5Z53DvzUMY zpO{1w-JJaN%;J*F?3mQNvKXJtq?qE&l2qM-#N_P6^wi=QkSE|y(~pnO%*!l^kJl@x zyv356n3=~0iVcwS7}$B3ia0^;Wc1TyyTw*gS&*5RUIdD<B2c2ZrG?FtnR!{M$tCf{ zsmY~9sU<~;dBp|!MJ2bG3o;A9hJk&FL~t-LFx=v>$<0qG%}KQb1!XbFaseg|W&qe8 Bw@m;5 diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/build_env.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/build_env.cpython-39.pyc deleted file mode 100644 index 033a15b6b579e37bf15c82ae533c009683c074b1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8980 zcmYe~<>g{vU|^UdaWGX#je+4Yh=Yt-7#J8F7#J9eLl_wtQW&BbQW#U1au}l+!8B78 z6PRX>Vg}PJQ7mAZHHsBXvqiCiY4#}g6vh<h9FAPhC{9L@87w(mx!h6QU^Z(GPcCm1 zFPP1i!<Wk+#h)t>C6Fr^C73G|C6p^1C7de~C6X%|C7LT1B?eZ<o+F+s5hVd;bL2?o zN<~TKN=HfO%0$V4#W-_hbLFDs!ECM^g<QobMKGH?M=4i1N;y|0N+nk{N);@|lcSca z9;FUu^X6#eYDQ`1YDH-=GNkfPU@QXpkS|9&S0_q`ks+07fo`haLdGb4cZL-H6oD3o z6oF=@D1%hSEW=d6R3k}-6u~)+DMBg2EiBE9QO52JDIzJNEet85%}h}y?hGknDdH^* zDdMRn&CF4zDNMl(ni5skPNkVSDGIK6Wtm0!dAX^1B?_g*sVNF+`9%tu#rZjjC7Jno z3Mr*UnR)37#VMJ^B??I(9hrIQTrWY9<)_Jbi`%~_CABCu#U(SjM3eCrXL@Q$d_iJK zMzJR2E#8o##N^bZ#N_Od%7Ro)j$6DTkpZsp&K|DL-kyH$w>UgYQi~Fka#EqJlKi4u zEIygVCAT>I3qY19=G<ZqPA$2`8d6%2lX{B<Yz*Tq*7A(hqEt=hTiijZg{7HAsUWxC z;txwLD$dN$bI#98%gIbGxy2QpUzDAhmmZu7av4W_d|GBsYJ9vV<1L>2g4DeD;)2Y) zywoC)Ibc`kB$ni4CfyPQbBa>aGAmM3;&U>Sif?g)g-VN3b25`O8E^3?C+6hD7ndd# z6y+zU78h$W-Qo>N%`I@rEJ{r-$uFwB#aoh^Tac1j6rY`$mjVuofW+kN#Pn3R%)FG; zqGV9$A!8<3au;D>U`S<%VoYIxB=Hu8DCQLAU<OT=TkP=xU`Hi`6vH%w*sKf;49=ju z0?IHoj5Q4L3@IRzv4p9FIg2HQDVwQCCWR@FDTTR)v4$~)We!scYcEp@n<PUGLp*B< zTMc6~NIiQBLokCTyPw-Fro56{JO%m1nHBK`U^_LLZm}dK7N_3gD9A}H0kJe0Z?Tjm z78T!OFHSDXEGQ|~<haEGiuhZs#i=Ew1x3sZ3=FrJ@{4b=<R#{&-eOP6%!^OSEGh!| z@D@i-W)g@83ObhJ)SR>;MFs|jl?+813=9mvs-3N3LW@(2iepl9QZkET{PR*>iZaVm z6?7Fs{XD~5gMvLn9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u5>0e-^3yYmOER-# zQuE4Ud@_?_iZe@6bqgSoP#jZ`S)d=EnOBlpl$V&J4^Gwbsd;631(mlr;^Q;(GE3s) zK`ts50tGY^8zUPd6Qckl$3GTkroU_~RRYks(1R)V(_{hZ1bH<+{uWn!d~SY9DJZqw z;)#zhEKSUT$P{TYFhD#B_9=wW1c^y8Ffho2A`uj$985(Zz9!=>wxZOM(xN<+1jEL_ zz`)7CzyJ~~e#XGSP{Oc)v4m+M;{xV|3|TC-3^fc3SQj!BtCg_TFf=oUF@Q>#V1^R* z6s8pBUdH}KwTvYkS)2>FY8bOPQ&<)<)iPx=)H0WFXYr)4X0sMWq_EX6r?A^Fl<;Qp z)i9-Sq%mbO)G#k$>|^Y=sAZ{PSiqmcxscI?Ay%fAwT5MZKn-gR>jJ?VhAftaj0=Po zGAv|bWGJi%XGmdWVPIisW@co_6EI{bUS+_*2!@dij0{j0Fr{!UWCFPmL-h@0)hUd@ z44T|k+ntM26H8JR5*3t+OA_-^5_9tNQWXj^3zQV9G7A(y`CE^ROF=<FAtWOeE~H+p zker`a0xI7!ixo0cQu9hOlM{0kO7ay-GEx<iON)w9^Gb3mb&E>#@<3%>L1uv-*c8ta zh4Rdt9EGG*NXb}|uaKEnT#}fRqfmq>d5RS>^PpydQ<6d|qC|z5<5$IpaIbDbW&tSo zfQp7H{&-Nji!aD5h>zE+$}G@idI`!nFF6<(7~F0N7MB!dCYQvQWag$8mn7yE6yIVj zzs0C^iy35w@GW*wh69yZECGon8Mk;q#^mHDgA49k>_w@?`8j2&x7Z32K_0xtmRStS zbGMj_ONxrbL5WToM1a!yEtahO%)DF7#g)akc*-E<XnbZ~TK+Bes>}jVxZYxq$}Dip z%t^h)T9lrXpLC10yeP9I^%i$gDyX6;ON}qdzr~SQ91kuwG}&&k73Y^0C8yqEFUc(c zTgwh|T~%hmEw=3P#G>@#TTE4Hw^)-iGILTO`2dvni$Iy-mRNi;IHKbbp#};f9Z>!N zWef&(0TvEME=Cq69!3F17Dg^c4n{FXK1K`1A|GhR0Oeaa28AZ5a4e2MDPE(PK{=v@ zA&Mo1C55$xA&NDHErq>>A&M=9BZaetA&NbPD}}p-A&MiFGnFfaCzU&uOOhd#CzUIO zH-&Ew8@MJ0)wjGUyul2bg0}>~H7ZhtTIB{wvBe6Bc_|9HiFt|XsUSAAeoak5PAi}U z2}@p(gp`t6Pz+9p$&7HnFff4HMj#)75=!wuaQ-i0%mTF+n0lEy8A_Pj8PXV2m{V9< zI8s<$7@8raJ4-sav<H)HCF~^}p!~Xkb0JvXg&|g<ma&E*ixpfda4%$JWT;`tVq3sd z!<fYj;uX3;!ls0;nW2QgnIVk{WO6N2i9nX%0-+9uEWs3xg-kUJ@xovcks5|9;f0LF zD@p_wh(g$m3?*V<IUx`~g>xZO3Rg2zzfLW44f6u=5{U(pDclPgv!rU6KsKlF^fH0$ z4QEJUKq*B&pp*-s8jII2M3bpVA5`B6fRbinPEKV!B&<_V0uEHPvNJF+7=zN08Uq7E z4MVJ4En^L12?Hnq7ch4)WHHq+E@WzEOam86g-oC-aV4XlCJVSgE`n#6B3n>>#dM2F z&!9*J#ALk10jl#sDIJoU!3mkuCOtJTwW6TNE&yaFDCSt0nEqGkpeGb~MWSZ|%D_3r zc6xBFnoPIY^74yv6LW5{=a;1x<s?>Ocnj192nJap!N9<f0rHqYEn^8o7UKethZrX@ z6|w|FDjrQ{gfDJ!fXq!!EKb#ADhdPzAPcCTgm?gv9XV}^Q%jQba|`U^KvsZ)k&Tf! zKfp8=fpT7z0Lb*@(&Cc*+{~&}y@JXjP*fz&XJ%jkCv#BA4a1qa1^GoK3i-u43LsrN z3dNPhkg^@70z@k-xMda<m*^;@6y+Cyl$50A>Vni4D}W28)D#6!8CeV|he0}EIKL<} zJu@#cC%(9{7~Eo2um$PY11XQTip6kGc3ysY9#~;9NM&k?h9-s@P|F#lUm-J3p}M%T zxFj_<9_$#!qFO5q)gYIEWc3nLQb2S{W|0O+w~hjmUA9PUObelQfONrJh1Ht;Vz9sT zV9^b>2h%u^i;(?LTnW(^os*iUfe~PuSV9TYObl%bwhGZ$9SQOUxbp#KWacSgXvL~6 zGfe@z_Z0H-OF%J!97q@@U`8~|(+aj&9Dt!;Ss^$zIX^E&M<FpKMIk3MNg)N=3&>2x zlIoNdQuB%-Ju1C|k_>Q@MIo^$RRP+SNKL^^smL)>4Qn{#Oi_u&#i>OlV86q{5#}Qd z$AjV<l=9G1AZ9FTGTq{Vh9gKraS^Ea)RcxaBS2-&El#IUPal_fSHG|#Pyum^6WVo1 zExyGW4{iK|m@p6A;wVZ5wKP&wZn5Nm`h09<i8-aI#kbfJ3kp*6Qi@bT<q=zIMG1%l zvaU!J)Lan;5vb+xElzMQ1C_nE*itJpi%W`cvF2u{WES0G0rm8XK)oYS`CL&_UX)mH zi!CJ;)Cj!AmIf+SOEg)E)WLQ^`Z`5XAP!Sn0i+lV0@(*D%)xDUFHixf2da#jm>Ajq zv$60nG5zCW1$7WW4G;lVHb$=hY|KK8e2hGd5{w*-O#fLV*`8NP;w<n{igHi|0ji-u z4ld4PU;qtSFtsqGFoP;vP{*!@A&W7EA%&rpNs<9vVKbz#NHWwi)i4#=)qo0nrUlF; zELp4z89|jNs3J{gtObd%FW>-)FW{_UT*#Qh3S~1dWK3b6!wgajs_8V@{7{?&ib#-i zz%`2u0|P@QsAds?RGE;vC52%j(_~2P;?Kaq0Igkau|wOyx0usYONv01A0#vpl?s<l zN@g;oR%rqSD#+_>pt?~HOHiePx@z(9NR=a8vnKN`mH@{Pk6Qu(ks%)bet!O;!QdXE z>n$#b2uQZ502HZ=hMHWU#FAK+3Tk#2#e(7%)Q!5uT3nEmSpu#ZA+74-)PkZEkaR9c zBU@=fN@7VWxYmaz7jTdD7Ds+g3b<0Z#Z^#Ql98VW%5&&m<&2MqdY}R1Q*aBGiH(Wr z9|tQRs1?g7#KghG#>mCU#K`rxN(#6ClR<$5N_-#;>IQ<UeQ;W_0=H(e7#1)tWN=}K z)rw)NWvOMYVNGEuWhl}rVaj4&z*55kiY!KkLarKCkVp-S4MQOpDBg>}QO8<T0`e<s zW=U#pF*qoSz@BF=$S=@jgX9s8)QaTzlFEYATkIfKSz-<-$0f&?B;8^!ODqEQa&K{h z!UUX|(F1}bK0dVq)VH1j3I|XdmVsS}k%Liy32O#{s6`p?0HsE52IzRlEO6VmnW2`c zgrS+Cmbr$pXi^EN70cAjSj$oa>Y*0ZvQ{b8uz)hf0@fOEwn$+tWhip0VOqcj;xjUY zGZf0PFqE)Y_AxTlvN1AL8PzZ^U@PIMVawu7VUlE6zy)d}L;1{-44}p#D8qy^L^7l> z*0R;H70N+q0|o<zLb)2|8m2VR2pdb)v><TrUBO79IJKl0wFRIH>Xd>9sz6;%<nE*u zNVP(Knt}$jH;|g5qfnlhSCX2d3F>ziE0lnS!yr8aP!SHox(d0O#l<*{DoQOxsP`)Z zbthhe2u<!=%*ClCMFOCt4r<-qVoA%)ODW<5r-XvUqT<wB%!w%}Mf@NIHXu<JaOaIL zu{a*d(VFa#^uYqM=oUNFEw{Lnp@VUmdFi*9%8PF?7o`^7VoXI(7(&Szsma;M1{N;_ zB@u8|VFQ(}kWL;GqX;7(BOjv(BhP<1rYdEOtb%DyGANIL@(T!qk{k$w^Gpjg&(ttW zGJx_*7Gsf!7ef<c3S$jxJYx-0u@We6lrVvYRr=j(*+6Ax3R5;ikxL0%7N|VsT*z3< zp2t(ewt%aIyO{yRt6^BcQ^Q`vSi@AqTEnuC6_mWtIxuAz9T;YC2gZPbf#D@6eQWX- z#ehOv2^88~;Gv5O@W>>mYei;Ba7kivc99)Ofjx+TSB1COQ!>FBu*d?Wkrz_rK(&MW z#kWM`p(zR_q%}DpamNOV`P8CYJV^0cd`kdQE5;`l$Ad;A^3rdy=cX1HC#I(sWrOTt zPA;i{j68sbPe7x&=#eXe&C)HP=v4s62^S+5BO4<Ns2|VD#mL9R!^pzO1cSe;R52nM zn|Vc&3=9l@nruaLK!GwHM9csYAU76)3W_37t&NfxKxrJF7%~_^<7iooHQ*{2)O)UB z&SFYoP3Nd(En!~3vXG&KHH$5qvB;o?bpd+{8>j?GVRvDOwW<Y`6^vP&HEhjHwd^&l z3%F7^YS<QVr*MMCw!|4yxEJu0@Yb*wq@?g<Fg7zTWK0A1Yzs|l7_<0lIchkH)`4~L z)^McoNiw8^WotN6_#xH23q!0>EhkuoKn*8Ews1xs7uX$wAa~R-X7PhnfyB5{glf2; zs`k||W(k00xWW2`Yq+5@H)<HO1dINF%@Bc_AvA%phz~3x3KjwRlLN})ssXzyMXW@) znIV(0mZwCdhNYRYU#^z7M6`yrhPQ?%MZA|8Ex8LBGE87Bj>1Ur5`MSXp^;c6q^p~m zo|j*gstXlKO{wD4)y>P-EiFzhs^ZYqg(Sc#Nw8pfVo{zhWXM?;)Kdmc6I3zjmT5BG z;>^njH8c~8DsOS;=jBvFIaN%$y0;kPe=+L*V$`W(v&zfQOSP(E(#-^yf<?^?3=CC* zy1J<qB}Iw4pyBxn-O{3*DlV{fV15;kt}ZBV=;mbRWfxcR>FSmgl@^zzrs!tm7nfAA zf}L2!52n&mi*%DR^FWRei4X7$hz|~N^mB3a@%M9$cXka5(PX;C4xM<o#S69*)Di(r zz-WqrbM-B*)QZ&P(h_h^0*}qH<>aTQrxt-HCS23fQj<$E%Tj$(%TjZ0v4f;QWh<+T zt5c|ZQ4%OevZtq(B$kvE-Qt6^Z{tB_Kv8}Uc-jFpELf0}m<(ylfJW(xN>Wp9ae+M= zUs{w?e2WX@*LbjBZ}CEX8V~Ym@h#EBoSgjfc+m7mK~ZW^YEEimacc1`UQiUJ7C{5N zh!>RcKqKcxVxT4=AMQNa0aCdZ>}ZHvi;FgZc-)YX0XquRJ;=+x#R76c(K3*Rr62;_ zk^~dr#`!b`28K(ZG6hseF>r!L2bun|fZJCbj694&j6(l8m_enC5TgL25EH1(5n$qC z6kr6kyFjWzA|PC)hEd*NFE#m!v_b9w4N4a2f*j2rAD@z+93KzvC=^wJBtb3Pq6r|@ zT#yQ$;*!LY%;enEl8pS6B9KdqK&?2)*b>MGNJS^YYrdedV35~9EpQG-7G@4J4iOGs z4q*;CCMHlp37VW>Vr2SN1X2lV&Vq_nI0iN1!GoWmY5_5~MEu}q3QsVDChsi~zkL4! z^suQibyUd9*Uc{g55VYV<|!1Vf|D0$N)FtaN7n)Fgrf8^K<y9^23N|U7A~mT1vg2- z!LgDNTs?u=5CR<GpqUg#Mh1prkpCE%s${V_4?e6$iiJgcKoJHGe=q^I4iufNNY=^W zuntn|#-p^<L4LyHL0E^P7G!N5h^Pk<V7tKt*a4uV#0hr*J5K+mf*aVB`u7%la!zVu zUTJ|4+)Ab@8LWPWDnzMTL2WL$k3lp2payyqBRpa?8E*;u<(GKo7UX~@Z&OoTi;D7# zG+7~0ji|n7f<gjZeS<>+On`#}l%K@lZsVxZ#OgL^m4edT@zdl)%eh56LAHPr6jH9; z3lam_0!edVo52Lw`rQl+41Ym+l81qT0h}jUI9ND1IarE7GMZ)(BPW5(SOp@$tu!+b z3*2(c0I@)s64XM@$pIDV`FX|Afs^9OVo<X=GaWLA$_nak6&HaL(Ji);%7V<i^deCB zLW&MhgRzJMWE>}m0EKlCsDo4la@Z|l&{S4@S!!NNevw{sYEemMS|+%7z9oq)Q;?k= z51K6kP1qC{f!alo_CB~*U<xu<5JZ3qkXuq<jj*{>z2uxsJ!pMaTm&lfZ;7KSfK}4P zMZzF6K-0hAft*`%sOm~fGINUc5R>ZQy5p7%HbwA(cJL$?c=SmLRUNqE(1T9*#)Im! z)FN;T5xhXb2V9>*62S_Pqd?t^TYR8uGPR-vGILM_DV{;oN#J4?9Ix1t!YvM)T<~14 y9Vo#UgW{NlnS&7-@-Tv+1``jX2os1U!pOrYz{JML!^FkR$IHSfBFR_JU;zLiMjB=S diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/cache.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/cache.cpython-39.pyc deleted file mode 100644 index c8bfcdf1b6e6d5cd821d106a50134e3e6c8983c9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7870 zcmYe~<>g{vU|^UdaWM6n8Uw>)5C<8vFfcGUFfcF_^D#0oq%cG=q%fv1<uFDuf@!8G zCNRw$#SErdqF7QGQ<!sDbJ?QUa@nKUb2*|oayg?obGf3p7(seja=3GOqIhz7qj+=q zqWHjKtU3I-0#O2BHd~Hhu27T^n9ZIeoGTI~0%mjMh~|n#iGkUiIpVnzQ4(M_SB_+^ zRFqV%bd)rh&z&QaD;p)t$dJmsKrU5&A!C$63Qr1e3qzEmJ3|Uz3V#bj3V$<Gl#)9` zia?5B3qy)vs!}s^l(IWRicpGh3qy)<s&X@Pl!`k;ib#rR3qy)%GgFkRJ41?Cig*h{ zia1!cS_)GzgQi54pmSn!Myi5uVqRi;YHn&?3D-+d;Q48?-ePvltGvbHl9^m`i^V6i zxa1axe?duReqLhEE#~0V5>4h?%pr;Cw*)ftN>Ymoic(8bi{kSVb5m~#Ba4)!78Pga z=V>zD5=>6a%g@V9PRz-yN(HObWV|KfnOByWlbI5pk(!$0mYI_ZGC`B^7Oz`=QEp<1 zbADb)QGSjlBghGP*_w>ESiveanQrlhq~;d5WEQ0+m*f{!-r_Au%`HgDEQ-(0%u6ZO zWW2>)kXVutUy>hRT9lK_2=WvZGchnQurV+&ID-;}8Uq7E2}2fR4Jc|sNrAbSrIxXT zX#sN$;{uixmW7N985giFWC&)^WUW#UN-ZfZ%2P;GC@x7%%1Koy&PX&eGEvA+Q%F=u z$xH@^PEn;^h$ho7Mx9@bR+`MWIE(X(O5(FqD~oS&6{i*?7A2PC7Zu;)NzE%RElQ0~ zEKbhMyu}KpG}&&kWEJP<-C|8C%`GUt#h#H^oRO26bc+pQ&n>ppyyX0p)LWbxsTC=i z>8ZsfnoPGCQ*JR9uVg4vU|?YQRqkvR6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e z8Wijq;ux&p>F46_=Njzk7!&O3>lz&58l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>b zQ=D0ns#}nloSm4SS{zf5S)d;ej^Mn+9Q|Za>d`Bxyu}p{a%?;(5X3>@3d(g1%tDMs zN(>AP$<UC8Q_N6SF(_lEGDI<^Fo5!56mvU68e<Am3Udob6iW(A3Tq2P6l)4w3VRDf z6k7^M3TF#L6nhF+3U>=b6h}J)3qurVFoPz~Emm+UPHbXiU~tS+NK7g&DN0N(QAo~7 zEG|~iRVXORFUw3xEmi<KS0M$OXfjia71HvH6jBmP5*5;l@^ck(GV`*FxwyC#puh?g zU%3!%@hO=_Rtg~*sR~8;`6Zw@FUd%SNa>+#NCPL{_+&`xwNh}*Q^-%sN=*i9LrK|C zH<sip<YeY%mcR`HIUp%BFR=*Z$fVTFymW=4)Wj5sGjUs-n3I!Vo|+O5aX_(^LU~4J zat6qkxrrskAV;TV=A;%Yz)esn&d4v#Nl_>+$uCMp_yc6UhC0{*mFfzKc_|9&#rdU0 z$*JlJiAAYk?fH2*l?qV%6v`5FN>ht9!Ol+x$2~NLSs54@K(P(N#UbF#*37VgaUlaE zLk(k*TnSSa^8%I{#)XW<a$XEgj5Uk}Dk%DqZrOf?MgY&Fa^4Dsxsk~xE^mZgRv zi+uq{4a-8t8kTIP;sB726j0V=_PfOfao;UAh@&+*Z?P7a7Ni#4;)svW%*!l^kH5u~ zUwn%NR4UwJ%`8q#D!#=DP7k1ny~PI!F<6w{;)nVS7LvDEOY=a*80#&T;?$h9B5ei+ zh9Vshq07L)aEmV<T#CU|uVlQ%86OW$e(~|(oLQs@Qmf9uz@Q1r9(<tSVd7#GVdP?D zV`O9EV65T;r(r#qYm-666i5{agF+ErWVJCcFr+ZnFlI4iGS)KHFlI5PFqJYEY1J@h zF(FtrU>O^R8pbT<A}bJC!<52o!%)J~%uvIW!eYZv!U|@w+Ax%`)i5<P)-u;Hr!b|k zwK7RE)G&i`9hAkM!U1J*q%eV4=`6J@H7vmlnw(Xx?x`gT1&KwF#06p~lw>59DCCwF zmnbBqD&!aIfkIp_D?c+YHASI3vm^tOXF#D2PA;INc8j^RD97&>PjP7yEOS;CaezXM zlYxQZB`7Fff>PB>P#|cs-x4V;%83V=m0wyCpH`HZ4yw6sae|8=Pz7>}1;o51ifkTS z9l~I6;iSo0qz{Th7EtED#hIO284vPC@hvux8L26^SixLKEP@JIa8%wBjZaT4iH9U0 zkPji6OhAz<0*W#YP~`G3vN3Y8b1`zUaj@zzRY^mm7@N*yP!0iU1YwZZL2(YQqDmMT z7-|@@7<d>8gld?;BqI+4D7K1Z(iwt5a*PX@YM2%>f^!HcKd~%iEVcm2r8CsB)-Wt! z1?8|>wh}gQ{$X3lSX5BLwt%ySZ6TuzL#$9OdkyOXt{V0lwlt=NjEoG0F*U5g3@aJ^ zG`SH8{gyDu*=X6K2%P$P!1Y0KD!2l?B?wXn4wAI|qIgiK7HNQ@5|r>kIWHx%=oWiU zW^oCK!IoH1keZjG$pMapA{$Ulh`}2Q@z81q+*-KBo1B;zpO+5}^;_(aEL(hwD>*SQ zB{L<lB(=B*YzZe^06o_Dp|J*29}bEy6;O~fb1<^}XJTUc%f!mU$il?N$n>9unTL^u ziG`7ik%y6wQGl^Z6ea#(W}xI$P*MdoHo!3lYM7QVG&3|YrZ5IGXfjpV!5a|pWUf$> z4=H>h*&;<Dvm`aQSRpe{0aP`CLJv_Y`>kZWCG3}9;+b2J18%IPrnnXr<rl4FLWCZg zkBeLw7#Q+Ez6809fu%|u;s=a4LMgRDc@4KO5+S}QR!9U_m>?e{BD-E8Gfg40L?N{z zv$&*KM<Kr?BekeJvp7|u2;6)E*FNy9UyxW_oSFhQ2+5;GexQ<)1>vn*JSa(lueh|J zAit<2H6^|zF})bg)3=z@Q%gYErWovLt}0Hrr!~25am0g@Q+)g_uK4)e{FKt1)cE*Y zJn`{`rHMJ9(jz|p7JGbrN`7*Dd=aR`E&{buihMz77!;aC!JtIS3oYN1Q*&})Wjwfa zFa)Usm-fmG3=DFhpyy#=VBlb6;o{-uQ05TlU@HR2;BFKdFfcF>+b9Azg4lx@G&ybw z1ZRTM1-N|-_HUK8BP3ct^?o_1femTzq?MMG7Nsg=<`tJD=HwJZf*qy&0hL9d@&`m0 zi@|H{8pax?6vhn3h0Kf$pn7*DlV6c4D598(K<#L7V69|^L>i)k1P2H>XuzQY3ei?j zsDR^!sY(*v+1RT<kW)YyoUuR^Zw<o&25_;)RKt+PSS$i+41k&wS)gVDV+vzBQw`H1 z#vq11Py>M}aWfMG10>yo+v?D611Rl+n?8_$N>M-xCQ#l(GzFbflM_pe!A+l{RB$86 z7g=#)UZp~QUaCTIN@j71jzW1VtkH>V8$8jM<U{NOHKcMCGV^r6O{|iP)I5dc{Ji4Q zoDxVaiYO(@L2^0y`PrbBU}*u|Bya_!kdawZtcP%Gc&Y-pb(Wb|oLU4jDl;z~RHT&T zgDiwvotXyWR4Qa7mZd5b<Rq3BXM(yk(Eb|Sg1pk)q|~Bf9fe|$=EM?^*HZHH)Js4v zElJGH%u6f*hYHkKP_3*`k^#06+!82HElNe0mS3V!nwMEvnyRPZs+X>(pr;Sb*9y6r z=@}&u*QDfErRITKtFSbxkOB%^P>G1tMg}!YlS(slQWO#upw0%RbOSvDJv}{;WM&%3 zwIC%W-~a{(7DzQXmO-(ko&tATYF>&$X@Np%F(`yV?c?Ia+*C*uE2NgC=7CBzurRnC ztdNmdtdNwNnx~MOl39|Pf)x7DP6H_UK>7<H7RX^>-JtXVF4`e2^OB6rVukX|oE%v2 zfwL(jOM+WQY+$z*YqCO0A#k=rRHrPUc9kYH%YiD-B70Er1I}$=0-WVQrB){>%Ym9t z3<6w?TufC;7}*Ygl>n;CK#ehQ{@cUAz>v;R%TmKs%u~Y{%uvDrZa{*X8jLlJHLMGn zTo_{WVwh^#YT2uJN|<Wcni*?3!Wr_!SQtu}E4>&QKroV_P$7~bkI4X}pCgN<nX!g7 zo4F{bgmnR13S$i$sJL0k!pKmlP{Xl+y@q)qV{t{HLJi9Tjv9^yoFIM;TMc^}Gq}m3 zP{UF@1MC*A8kT0p80K0|knJVhB|Ig(S$qrlLCu?mOwEkV;HucKD%>+YFTV&B+0bMG z4rm2cNExYGtdLj?s>M?BQ;QYy@=FwQ6HAgaKv_m1wW1(3xg<430Th=-nMtLfe!l{! z=1@>A*3%Ry0)-W%z5uoJi?~7c1q(?27F$k!dU|TnE!LFOq|)?TobYO_$Q`6e5Xz6w z%u7kFh|kT;yTzQFnODRMic~=m0gw8kSWv;s1u1O7F&_w$4+0V1Ai@J=AQ#wE;QH<s zCxi`Zb+Lk(w-}*)6GTb@Rc-S?Da8uZCSnJ*epr||7+Dxu{_`+1G4e3-Fmf^SF|sf+ zF|qw+VP#_EVq#(hsbFGc`pfj6jRVwn;$y55!Iru-If_6%z@ku)^TI#`sQCr1HNedj zaK%~_0g?c_2uy%$4{$1uWME)u1i1~=I_6+xVdi1s5G?|U;;u?TM&PPS!Br<~FoPz` zEq>R6jMQADn$z7;0o@0X5;?gj71YjD$ShGWR>&{UQveM+<rgIuRYEf`yvPO@EEsJ= zP|FHbjTM6`%o2tYP@j!4g{c?R+hqpz%@(lMFk~@jvDGjxWP;SPn#_J7noPG?Km%L1 z1k!WzlM-`sD&up(Lv|^e>_z;b5EB4Jx1ei)hpTUVxQDB&PrS3Evxn;~&UlauLA@<R z9Sv?JYeE~1pt`gO9Lk`;0(Wk}QF0y>)S#5i0E%Kprhgo)RT6071h1+!*>FcK&Irw5 zU|={6vIP_<pa?AjiC{z~sGR_6ffa-LRfxz;VQOKBVoqTOM<5rt!Q+}&QdEi2kOAoj zms+48s$r~Qh-Ux~E--?cFh!1_Y{UfVcyJYf1}lq8Qu9hs%2ZJM8Lf#44x(Ey$1||9 zF;)p9+yD<3KTQ_&fC06CkPJfvdM*P4!%dKhAO~|W7J>K}fdNW8psY!)kuxr&M1Lc^ zD6ybe0WFTfH77=9$jmFr2aSVf=B4MPDu8_sX@7)(Dl{-3GB^Y&PScALlT*`5b8;#b zQc}~45>paEWu^{NZJP?pfzav}Tp)w<54hQrsF0jmRFasP2ks>(WJ1d0wEWV%6i`12 zT&;qezR21Y(lU#ROCS{~Mv{QHZ9$12)I(bUs<z;5+Y%;F)zb{klc1^%G$I8~E>WQ5 z!iJQUK;_RZo_KJ93K<Rnr{Y^Y@n9c8g`z=O6iX(11&VKQt;{6E$irAAjED|+8p0?; zKxqJ+ph5i#(8vJD^$Qt;8DNRI0Aw4e(k}`CvA{_TOn}Q#ki-X&y`Xf)z*HrJWG7}D z0IUd<;ushhKx~4R7lNz=*@4aSTjC%aAR&V?MDPX4K}u*2!lE3dw+f0)5C(?{$e)m| zK@C$4^Fn6ONL30$DMOJIsBuukl7$GTTl^r$fD>DMDyZlHmjcl7ATYZKUZ>vTMpg&1 z1d@lrAquKBe}Fsys+kzr`4~YpW)&Z*H*h-{6iJ|H%mOFE8s-$nUa+%k7)u$8)Jm9Y zSU^MKy-dNNp&n+es(iqzSW=ils!~9e8e7#iNOuR+O$X;kaOnscfg`5lu8>~@&Vry; zs9%0wsvdak8ypG>;LuXY%uC5khSY}Oz65yaLZLhnl;x4~CZbS<o0ngt0FKnuqC{xJ z7m`syc4;!B1$~GnV-ctXb^{fr;G_)-Z*cKg1WIf;B8;slwWKUD2NF%-2m{AeF#`hw z3nK$VF{o$Gz|F?U1cHCrSUDJZK%+iLyecWw7=+|yNK(<{LNC|R+A>9;YyfsB$VS|) zntTSxoMka6GjlMqu<@{QuyC+&@Dzb$G}Vj1=1PG~lK@rm?4TB8W?njYOzjq1No4_u z1In32psZO0s!NMNxuFPDtVBr_WESYfm!;;V<QM5dx>}ie>3ZNn6LyfHpd?!aYS`bB z#;&xqBr~TN+@!rF0agJX?8{5c(MzpJP6f{h7DJl2%Ba%0`6;P6#d?rYI@rK^5y+dj zB(bUl^^?F&-CGb>!!3fE1TJHXKuzjfGN=ZC-KYm|=pY(IXfB4RD=o??E&{ctZ*iul zmiT~M<dE2m2Zab|#tJ+_18!S_OLItK14Rf@a)PI+TO2l!VI(`ym{~EXiO#~z!3cpe eOd^atOrVA{2n#UsFmW++u=6DgcnR?FaRC54?ay`q diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-39.pyc deleted file mode 100644 index 5aff75cd21c04afcc029cd0a05d2dd4a94f157d0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10722 zcmYe~<>g{vU|^UdaWHkRDFee}5C<8vGcYhXFfcF_i!m}Vq%cG=q%fv1<uFDuf@!8G zCNRw$#SErdqFBH*YZPk=V+wN)TP}MPdoD*5M=oa+XD(M1S1xxHcP>v9PcCm1FC)k- zmK?rZ{wV%jfhYkmpEXA?S13vd%x23G&J~Fg0khe2M03TW#B#->#2Fb<8M7p!BvQFk zI8r5>nWCgpMT!=raON?ka79U{a7W3cil^|T@TTyk@TUl*2==l@$)?I?$)(C>$*0O@ zDWu9~DW=M1DW$PSDMQ6Tatdk8Q7Wm-3sh6p7BWVurwFA8w=hI$q==-5wlG9#rii78 zw=hI$xih3lq)4_fq=0PJPGJgW(3DE#W@KP+&d*EBOfM};EXmBzQ^-xsOH5DAP0cG& zC{8UYE#Tq`&d*I%C`m2K&CJWs$xpAe;?h;fOUzB>Qc!R#RwysZEGbFNQ^?FyNCq3E zkd~Q~TCB&Vt5BAhQwmZQ2BH-bi;MG<GZRZvQxwWGOEMG^A%^HGWT#egDJb|Q=B6qn z=jSG6=D}2CmZ%pi6sIPG-K7C#=z*-(1e;!znV44sa)m;1W?p(uszP~wQHnxJYH@N= zW>RKex<YwIYEh~}Ne0MZWItx7R_cNsr%;fXS)`B*vO29OKbPwzC<XaxvfpBM%&WY` z;*yzMa*M;WB(*3pDJS(7i%({8$t`xj)bfzZg4A0a{skbHCFa~>4Jj?iN!4V!C4>@| zu0=)pMYj}D#N0A-Ql0Zlb5i{BOPo@D@)J{1Q#2WGu_qQ3q+}KqgP7r-elGsu!J16B zxKi_qON&zDQ!<Ngv83je=H6oQ&df`xVlT)n(96urtl|JMK*6rbbc?+#wWv5VKkpVx zMruyMEtb;a)S_E#={fmHi8;4eiZe@6Z!xFll~u8)=9TG|B^GJ2-eL(2b`844=I-O~ z<mhvYCD=2>^%k?MU)U{nSHH0MFvp-|Mo@r2F^J8=z`)=P%2iqn3=B043m6tMECA=I zg-o>|K2r+wLdGJs8io{>6xLQINd}N;FoPyrm78y3b}BT|K`Es;v$zD5$cj?a6N^%E zQj3cf^3xQG^Gl18Qx!B)^U5-d^7FvSFuw?#q%^q{6ciM0F~<L5)U9ID)qTmtz`)?A z$$X17C%-(k=oWiXYC%q7a_TLv;*!Lol44LI(`3BG0!l9{8H$t`7#M!lJ6pws7N-^! z$E4<@WEREv=cT$7WtOEX=qiNzd4{<L1$%}#1}lIfz|S?<(=jI4)z>vR#5G94EG8hp zCnnKEHzz+mv$!NPJ0>-+EXF4@DFzg>x&?{J*@@|?#W4k$1^V%sc_pbud5Jmtps0ao zExm%uTm12P`9-;jIhj?d@gRp8fx?ml6u>M3j9iR7j72I83=Am24)P{E*wq*q7*ZH( z7|Ixnq*9m`Fw`(CWUOT@VXR?nW^7`tVORhv)|eN9GB=CgEk?bnB=6Kpg_Qi%Vuif? z5>U98BxdF*q~wEgcR^wiI6FdfmO^4)3Mez`DFmbzWh539D^%u}DwHSYm87O9l;kUv z7N;txL(-F8b*;KWW?pegYGR80OHjhlWWL3g2J%`-5hnu!!!6e0f}G3}O{OA65RW$% zlojH0Q;Ule(^J850U?w@vI6lbnZ=34#i_YTIjQm4sg*XMP~iiG3KItt(|;yrroSvK z9E?SvM3)Q_hG9^+fC_qWk}Ls-O$t*BLkTERGB0FwVQ6NoWhi0FVqU;f!kWca!oHBH zmJ!MaiE^Z{EMzR<EV4;q&SOepEn#2CT+0NNXIQ`mO3YwA%q84eJT(j@+*!OejOmOe z+*y1zOf}5uOqtA}#O;R>VQdTx48b5@NHH)lq%+ho#0u3imM~;7E?}x*EMZ>AG?A&0 zB^Z(_HCb*k<rm*#DM&2IxW$r{pP6@y-`U^K&C@;J$uZc~&(YUalj#<do<Wfg0|P`0 zQs8mf<YX3?B<JTA*m;611O*8j6Vv}H?ex@=c$5Sf4=I^#a`KZCbBgWs5IS!$7i1Rv zVyvrT(JRO-(Bv=T2FD91X+w<wl|jWt+8_sjU7-t7z+7Bee2cB1C^ap!qDT)U!j)Q4 zkeHVODtn4}Kmz<ACXyMqShF+pQi_YjK_*Fn2r&i*22GY*!jO~&QwnzKEdgW~fP`)d z<)o%3CRZXWyTzZET8=CL2^~;|F9N48aU3Dx4hk;?P+DSQW8(P7#wx(b#>mCU#mMxR zg_Vtw>pu$%8zToJ*WV&rP^JVaM8=?y2JwrJF)%QsGDI<^Fo0SWQOqg2?F?y*Da<J> zEu2v-DXb}MEeuhtDeNg6Eeug?DV!->EeuiYDcmVMEeuf{p!&XrA&L`J=eICKais{R z2(>Uoai<8Uh_o<7@uc#mh^C0OFf=np@ui5TNVG6S@ux_pNVPCT38YA;$h0s-38u)V z$h9y;38l!VD6}v{38yHgD77#|iKHl}sI)LdiKeKgsI@ReiKVEgXtXdyiKl3$Xtgjz zNu+3}=(I3INwzbvFhofOGid7F;zg;h5+5-#FnA>9feL8kra^uhs4PJ=8}zuqrE@@0 zepzNpYOz8hs6kMYT9lTUoC+#C5|fiti$S$CxR3$2F+deGO7aAk^2Jb-LNYRo6_Rrj zi;F=Pm8BMy6e|=UneG_isZf%USfWspn4Mazpad<$^gvZRs9;r6C@!hY0ku99KxG=p zMJWo!CHY0E#oz`3r20p1lVp}CBo-?uAq*+aOGzyPX#jf<Y6;vnC1l4Y=H%p;7b~RY z7bzqvB<G}}1Od1ul9>lGNg*k}Bm>NV83!tNOETbY)djg<A+ab`p`a+WIJKxOH3ihV zO3YJ8O)Rbig(f)sQbAVbf@CloIH0Uj40bZqY=xA>l0=CAQxr0b6%uob^A++klT-D; zs{E3fK`9xEL2OW+1fq+x7#J8z7@8RtFfL?ZWT;_EVJKxRGO1xIVJc%RGAUtBVO+qH z!nA<3gsp_VgsGWnA>%?wUBp<!5YJJ=RKpO@3C;=(C0wBLxP~E~JB2lcr3Jy~0Tqz( zyeSOevb4(7J-<XDGp{T$Co=`oh6MRkAtygEB|bkdr&2*zp*RE7gi=UKRmjgv1+^Qh zYpa-a6flZmP!<Ij!$J%U44I%}n5&kthB2LCG84S`1(y~pnTqs5#T9#5BDhrv7K9Ms zB81B(B{LaP%2t6&4N#@b##p6=l3DcP<1_OzOXB185JfCp8?kQ7#Bf`YJ*b!j7iVAs z<e(x)1_p*&giAE}Zm|}Z7Ni#4;($5g7JrzdkEct#kH4c!yuY7MB)DQOQU@6ZDZO(O z3vRI#r4|(3;>aw{&jGasZgIkc`4*plm}^jwr;BU6e~^o7&@GPmg2W<F<LMSVw6wh? z7@wP;l9`s7ngWy4WWL2xoSKtX1S(vMJQx@lRx;k=jE@Ir<@k6+kQRaJ>>Q8}ASEyt zlK>+VBMT$nf2RMS(wB{yjgjd;2b8Q5!yeKop$ck;fFcHDaxtjlg)~qZ8EP1^7>mU~ zts_txPGJmY&}6D|1vS3Gr3<1MQvme>Km`u65U4u?F1C;wrQloxYL9{%phEHBK!X%! zkV+Qp{aa!X2_${-Wr;<_D;bM?L9qaiO)vq9(pxMbQ<^{_0%|=luy8Q4F;=1WDD*%| zF#HV4t6)D{fg9yn3@MDIjKxA;3@J>YR$&!i4LJ9vFiSFoGXyiRFqAM=nlLheU?c-5 zGz`F`CQFq=P-;nOQ68j-1QjBXu3AQBdPZt-i9$h9W`0p-NhPSzf%q2MYeWP`m8M@R zq`8=ss!&{znhZ`I3W?yt9aMHDr7EPRWR_&+r5AzXOOqL#NN$P7gDPoA0*f!nhoq~@ zTU?%bDXA6Uj#N<)mM{|l=>j<vqz7bf7byI|O-B|UMyCHP%uI}Yj6950a;WJCT^mN2 z!qX9Gl%a+p3mk&M44RBp39v8%)e?|u1k{TxR>;ZBPE`QqcfHJ#)ZAhXO$AWiN-a*! z1NjzQ;)9|uH3c48*uzkh=@xf9$ehglyu_l)TdZK?uz9~If`Nfy8py{W=Q6NX38VTF ztT7oZ2QAt`Y<O}3bv~+iK%T2%geMKgN*z$bU}Pv^N@1*FoXs#7oQNVB@|X-5z@rAt zRXXmeB?^hKvbiWf7wkC{-$3dWP!9RU=a;WgT$-E#s)rSH75p@ri^4%=Er)k%B_w7! zK}|p=aHhD$oSj+;DJ2j&gA){8;Gmuh@+`;$3@l8HJfMgbNA)sXB}$D3>Lakix~`yp z0!qms<i!B#J1u00VX9@WWvO8S<)EUF5@t}pDu$_+wU(`hWdTbK>q5q2w;GlOtRNO6 zLk-IUwi?zNwi>2|%%Hllh9Qd`RMto`)G*qBy2Bhb%rz_vnLq<U;4(+o7gStU!ov>Q zBES)Hewv)O#Nwf202zs8sgU9XR0o1HO;HFaM}Rs-x41JBi{qi~iCf%>DJgIcb8%`( zkvAy31><uQi?ZVriy@gSGc`q%9USIG(I9D7Z~)(8O#?MQZm~hK;w^Tlp+%s697enp zr<TNnwJih1iwG!@v2ZYPG4e2RF!C^in$mns0*qB?aRk?ek~Beu9;m(smt+gTB^hXV zfe})AL*j_Bh9Qdy62fJSMFybO2O^2qFf3pJ#~@QJa}9F}Qz>InUkNKT23cxZYnT_X z)vzpNEJ~|kUcg=hicO~Cyb|UVW>6_v!@Ph4BwO56!@PhK!~)s8fD6>m1H~Z1<{Cy@ zNJe0(QVz{4M#>6Uqq8UyG)_@v;+9yFn4{nc9U4#o_lOmuGgE90WAzjQa#9nEQ$Ynr zei670ny8Reny#nGT@(w7V^BQ`jzmZu4v+VuI8e;-7NzFqm!-z%gU6%5g~Ba9s2D8z z5<yvv4H4Z%pnh~w3drzO5P>avxl2L5gGBHyPy~Z=Bm*-jf(01)n81+?>Mwyh=%BKe z6%^q-OjVMoSrW+<lwuYX*_^OU32F%-XG#}_*oYXWT1HTJd;v44BmzZ33Ah`-fV~FX z$Yf+F;izFuVQOaTm#Ss1VOqdh!@Q7@ks+KRg_(tcg`t_5k)e>!kfAun09@HIGDI?f zL{dPVc9trw;KVZM=wNA45ojzbGfy`+H8;PgQlYpcu>{&S29;q|yx~RQItx^TsTSX2 zEcesof<%oEC<fSa^3&5(i*B)G=B4Eq@qz*r-c`QEo|0Jv&QmP;1*v(rSV1GEshTX1 zxPV8)EygtT?8Q=?SeAMf6!4&~Gy@9<6CWcFvj7thMza8<5G8CuRVyfb!I=p(qy#GE zQy5AaiiAoSQ@{=M5~c;rDWJ^6018=f<D1#9N*z>vr=}<*!Yc1%<eD4Y+N;dWOV_JX z3D3;Q0ky!(^NX@UeL2v0n}TYw0<;CK04k<5Ss(=!D4L71K_SJOlA2VSj<qrarSumd z--1d41|}{>4#p}K)TD&HFhub=sM7*3>Ol!MlL0jH;=&LsQp;4sxByawFiA3iQc595 z4X825SY_h~uDKyKE+`v<dS2-DHfqBVQNw967lDReZn2dXq$HN4f-|ZnGdO;4u@$A3 zlqKdAfu<tR;ul;Cz5{s}T%obEFmW&nVdNg9mH>)BL4gFS*1$151Kdf2H1nDnL0ufs zAeJO(o`MN93R}XG#hT8T%~WJk!nS}NG_1wQkirtoP{X)@V<CeJLu^<KQ!TjIbYY0~ zsAZ{P$l^?4DP=4w0CnK9IJ23H3cxy9YgizaU7<$}1GsQxS;$n&TEmdVUBe{Fuz&|t ztfn!6!`7qF24sgOTa_s(O>KDV2;4p_0*!c9MFnSP78HO|8K?yXqEV_$a1t$6NGS!6 zH6S&&)r%DZJOkpPqiJrQKCTK$sUYq7#d;~JWqGAJIet|NaKk|jNd<M)Vs!-#Xezc+ zP%YNf<h{iLYLDF#%q&SQg7$r&?R*PRUY7(BpbUSD9cn5#u@@DA#6fK|a4xvT1*yM5 zwiJ1RG6P#;K|yL>iYBC7zQqIa6x3u;in+xKQe2EwSc6hDBpreJ3`GG93=DrjNk|S{ z_wq1GF|vS)Vip!A0Y(mH5k?k9Hc%s&iHEsL0WB|qf)d3uC`~4m^aU#9z=NucHH?t> z2X&@um=-dEs@et2;54LG%TmL<fCW@_f>Q)5s8zXut%d<s*@9DrLJg?&W%8?1cgrt= z7Z#vE*HI`36)7b}mEgWUD4IaRnjDD0yd?;7aB)ddX>tj)$9anbTE!KED?V`MD=G$s zt^i`JJq0wXTnr6oNM3{&yhY&p4;)Kqfm^}Az#z`Zz)%b>ewp|fxtMquxfrFGswA)l zB`B&;S~Q>n7}R|LXVC_576px>fT}dmh%~4YE2^pDt6^He3SxsQuDl2qh7z_)A7~St zJ%w=rM+xTwt`zXNN)2NQb1zd9V<bbK0SiM3Ll$>s6(d6}Gb2NlSP6R#a|%l@V-sUI zLnK2ALoIV1a~>CjHefJdr~%Chu=-WWCFkdX<^YP}LoC&`3dtFXMTyBJsYS(ZnoOWF zE3r5~51i^W8E>(In<|<-u=ELS8S)1umP3Le06Z*!7#zOEmRgZnTv7}gTu4m0B@~*M znVg@J>XHf~AuWDTuz-gmZn1$!qf>8*q^FjEMv_yDic(Wj^OEyZGV{`Jv4WLjRF*}c z(1c_IaGZhjLJb20gAypZWI%a=iG!7g5#0G>0u3v0fEp=(xYz`k6d0@IA?}8DUiC22 z6iPu0s!HJnEyy-dRa(NB1uE{CL2XXZe9QvYg$xV9#U8YaWRA1QLn@vi$v-J46*5)_ zZfUSurRJ4c`DwC2QZl%F0gYvV({xcCIAMc2IZ$K30}5EH(?A9W21`(IfO0Ye3lAgT ze~juBTm(Q(0?oC7O+zULKt2bhV{jS<4e@6(fSOt^46zC^Otqj^HDd~+I710T4NEhl zI72O{Kg3+aX2Vd(0m<l9*Zn}#LZBJ1Vg+!A6x4=F&d-D7VueKHiWl65fX|SDXQN;P z!l1wb4+<CMmzHGarGiE=!K13+z9*=CRjiPdnhct&&Q7g_jQ4`ZP;(PgAdS3Y$don6 z90dievyQr`6+E<7$uCks3L!+TU!)3ZQbQ)}U>zxVQF4n5;R|rr=@v7n6#(jJp(k5V zlsbaq36v)o*jX5P7(r8k=pz>Bg&9g31;r2ug9^1`7jQ`fnrZ?U%O;R!bPXe@8NHCP zhzrzYPGJT$3qbuPPyt@TS_Tqlu3<`J3IjEfxu8vC_;^sFLV9XmYEfcIei39yC^07o zIam^NKxw%cA_vOGnHAug_ZADN{(T8@8z@Ob>PTpCLdt8<=wA`2_PQkqnsf%ub_K_K zy8HPDxw^peJvi99L6s?%Zc0%nsDA|yKxQFEE=B=R+Y!r<57cHzG6!XBP)Py8AP0gl zH~=TW0}!+(1T<v`3bInhBDE6cEEdoNAS9UbctHGg1_-Z&wV9!osf0O;tp-d=Ld8LY z0z3@)Ni~f52_+0!91A!>g*^`_8!;DEl`v;<fz@-t)R!=W+EO4ACIT%|>LW8#b5alu zY|zj?q{RR&$e;-}5pAJGW(jnf0+jT@SqL$FUQ(0_8uo>ZT|shZei}-iL?rlI{Ghl* zYD@WP@<0mxK2WK|oSs@z1TL<?%^}c~8Dy3ZJQ56^G;9V%A!xp@2sHBtjon+^5Kn-c zJw>3=^;_Z)2SS=lNE3+YS*MJFfgu7E^C06GIQbYk7zLPknAn(wm^m2v{<AQ%FbOfE zm-ZNKIFvdYG(ZNz;PMWXBSED-s38L$`%?xDe3gNgvw&u!z(aeWvCu?l!2yl{O-69Z ztqB>=f;2Wj)ds}zpqdI?*Fn0~#qpVWpz0?rGrb(-5s=jk%vDOL6%?qvhuDfxj*|aD z+CUiWYS4fX$koMMka4XnP?v{6k^$5$C{_Xu>w(8R7*m)eK{GDQet5<vjBt-ly!`+F z|9|N4Ex0)g9-DxA`xZN-l~4@vHQ4_kuY-rIYCt{(kI^!NmOQX9F@c(_tX0aWzQ#Ht zj8Zv)axAF72lh6|4p8ef4cw0b1wa{NksOF#zz7)^0QYej{WO`1K<(M0N>KTY(G3>_ zHRGUd%lHz|x*l{dfQC}KL0$k?tV|q?T$n8i^pQ4{*a8(iAg6<!4ayE6M`kh32CwYM zVw%mA!Zep9m_d`-?-!%SFGfvG<|2Pk4&#UiuNjGt2lpJYRr;XWAJCw4eEdX^13^iG zfeCZ&1foQf(N9ylXcow1u6WRxU};WjeEcn*`1r!o#2iqK8Xtd)Jw84qKRG@gJY7=+ znoBDR1Lb0HdpQQgN&^v@AfgaNfO_$_I0}mL3sQ?pDj_Zf^-_vJt?43A8?6Y`G6A<_ zz(scvC>Iw^0qF&gYk`8dXg0`IywGW*<kXxT*whgymW%vAiowarj)8#zGzL}-YMO8` zvhebWad2?(aIkZ5a)@w9a|m;=F)?!Sa!7M<bBJ?raPV?)amaJ9a`1Do6@m0>>J-fb z8P*6Q+CY}FgNAZIvlF1Ys>lQ+#8y%X>U$P}g0l#e-iko6R|FbmC<3K{B2Xi#2-Jzc zB>`HH1z-Q8ms*jW3Lcaz24{{UP=OL9jH;%zBr~TNvfx4ri;Ny<X-8rSWHkkv@nEfb zxtYbukTEAvo+<*(Al+gvE-5PF2YCt<Fh%_!7PxE%ue$)HIdBnN1TLz<%}dY-MiHp# zaEmiNwZsQJo&`=Eklq()3<<pc2D}ym9Ck?g0vs!#2)V^!lbfGXnv-e=O60{LD_M9s n7-3L_Nq_}3YA?XV2JTFOre~NKq3|~wy9A>E6Bi2y7bvy>$VbkE diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/exceptions.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/exceptions.cpython-39.pyc deleted file mode 100644 index e6a9ab952836dbe62cd94fcd7a1cf5e0175297b3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15671 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 diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/main.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/main.cpython-39.pyc deleted file mode 100644 index 343a299dd20ad3517a6b1dad93f79a0ecf8cf061..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 604 zcmYe~<>g{vU|^UdaWFNWk%8ech=Yuo85kHG7#J9e<ro+kQW#Pga~N_NqZo6UqL>&N zQdm=%Q&?IUqnJ~ef*CZ~UV?OLGTmbF$t*6p#o=F2l9`{EnB$ks2$FzeCI$uu5OxNc zDgrW<F@*_aYAqupLk(jMLo;JAgC=v;ypW8{Vuj3Ng@U5g;?$zD)D(rZ{33<?oD_xR z{Ji4)oK%J4<f6=il46CDjKmU!+{8+S;*!jq9EGG*g`(87)S}e9<jlNuE(HYzh0GE? zE-=F_zepi5B_$K$GKG}XlEloMVjYFz)KrCxl9GaAD}DX+%#w`KB)#PPT>XN|f<*m- z%mV$);^NZOVtsQHOA9@)K}8@xX)@m8h%YZnEGS4V(qy_NUyxa#7oV9|l3J9Pn4?!( zl9^Mimzq~nR9TRpnO9O=#KOS901BVPqI3vnB|{NA0|UdaGH0up(Bjmh;+WK&l+2<S z|GZR}qRg^X1zm+uKhH4NpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>AO*9SfB>JEL=)Yd z{PfJ?lFaOw)V#77pUk9~;>?m%-GapA?8Nlc;uw%8;7-%eP0Y;GE2zB10%Cw%RSY5+ z*m;<WI6-b?^wVUy#a2>TkeQcW1d6R9P(lF9fgOxQa4;}1+~Tmw%}*)KNwouoN-;=- G05br{kDr(T diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-39.pyc deleted file mode 100644 index d4627db45e6348451a0219f7131b6b479df88347..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3482 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 diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-39.pyc deleted file mode 100644 index 936888cbd4eb0274946e937dde5ccbe6f7016557..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4367 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 diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-39.pyc deleted file mode 100644 index 9a6a77a02ea6035e17a88e86924b1df096153934..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8305 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 L0*5k(HHQEI>K2~u diff --git a/env/Lib/site-packages/pip/_internal/build_env.py b/env/Lib/site-packages/pip/_internal/build_env.py index cc15250f..4f704a35 100644 --- a/env/Lib/site-packages/pip/_internal/build_env.py +++ b/env/Lib/site-packages/pip/_internal/build_env.py @@ -1,24 +1,24 @@ """Build Environment used for isolation during sdist building """ -import contextlib import logging import os import pathlib +import site import sys import textwrap -import zipfile from collections import OrderedDict -from sysconfig import get_paths from types import TracebackType -from typing import TYPE_CHECKING, Iterable, Iterator, List, Optional, Set, Tuple, Type +from typing import TYPE_CHECKING, Iterable, List, Optional, Set, Tuple, Type, Union from pip._vendor.certifi import where -from pip._vendor.pkg_resources import Requirement, VersionConflict, WorkingSet +from pip._vendor.packaging.requirements import Requirement +from pip._vendor.packaging.version import Version from pip import __file__ as pip_location from pip._internal.cli.spinners import open_spinner -from pip._internal.locations import get_platlib, get_prefixed_libs, get_purelib +from pip._internal.locations import get_platlib, get_purelib, get_scheme +from pip._internal.metadata import get_default_environment, get_environment from pip._internal.utils.subprocess import call_subprocess from pip._internal.utils.temp_dir import TempDirectory, tempdir_kinds @@ -28,62 +28,68 @@ if TYPE_CHECKING: logger = logging.getLogger(__name__) -class _Prefix: +def _dedup(a: str, b: str) -> Union[Tuple[str], Tuple[str, str]]: + return (a, b) if a != b else (a,) + - def __init__(self, path): - # type: (str) -> None +class _Prefix: + def __init__(self, path: str) -> None: self.path = path self.setup = False - self.bin_dir = get_paths( - 'nt' if os.name == 'nt' else 'posix_prefix', - vars={'base': path, 'platbase': path} - )['scripts'] - self.lib_dirs = get_prefixed_libs(path) + scheme = get_scheme("", prefix=path) + self.bin_dir = scheme.scripts + self.lib_dirs = _dedup(scheme.purelib, scheme.platlib) -@contextlib.contextmanager -def _create_standalone_pip() -> Iterator[str]: - """Create a "standalone pip" zip file. +def get_runnable_pip() -> str: + """Get a file to pass to a Python executable, to run the currently-running pip. - The zip file's content is identical to the currently-running pip. - It will be used to install requirements into the build environment. + This is used to run a pip subprocess, for installing requirements into the build + environment. """ source = pathlib.Path(pip_location).resolve().parent - # Return the current instance if `source` is not a directory. We can't build - # a zip from this, and it likely means the instance is already standalone. if not source.is_dir(): - yield str(source) - return + # This would happen if someone is using pip from inside a zip file. In that + # case, we can use that directly. + return str(source) - with TempDirectory(kind="standalone-pip") as tmp_dir: - pip_zip = os.path.join(tmp_dir.path, "__env_pip__.zip") - kwargs = {} - if sys.version_info >= (3, 8): - kwargs["strict_timestamps"] = False - with zipfile.ZipFile(pip_zip, "w", **kwargs) as zf: - for child in source.rglob("*"): - zf.write(child, child.relative_to(source.parent).as_posix()) - yield os.path.join(pip_zip, "pip") + return os.fsdecode(source / "__pip-runner__.py") -class BuildEnvironment: - """Creates and manages an isolated environment to install build deps +def _get_system_sitepackages() -> Set[str]: + """Get system site packages + + Usually from site.getsitepackages, + but fallback on `get_purelib()/get_platlib()` if unavailable + (e.g. in a virtualenv created by virtualenv<20) + + Returns normalized set of strings. """ + if hasattr(site, "getsitepackages"): + system_sites = site.getsitepackages() + else: + # virtualenv < 20 overwrites site.py without getsitepackages + # fallback on get_purelib/get_platlib. + # this is known to miss things, but shouldn't in the cases + # where getsitepackages() has been removed (inside a virtualenv) + system_sites = [get_purelib(), get_platlib()] + return {os.path.normcase(path) for path in system_sites} - def __init__(self): - # type: () -> None - temp_dir = TempDirectory( - kind=tempdir_kinds.BUILD_ENV, globally_managed=True - ) + +class BuildEnvironment: + """Creates and manages an isolated environment to install build deps""" + + def __init__(self) -> None: + temp_dir = TempDirectory(kind=tempdir_kinds.BUILD_ENV, globally_managed=True) self._prefixes = OrderedDict( (name, _Prefix(os.path.join(temp_dir.path, name))) - for name in ('normal', 'overlay') + for name in ("normal", "overlay") ) - self._bin_dirs = [] # type: List[str] - self._lib_dirs = [] # type: List[str] + self._bin_dirs: List[str] = [] + self._lib_dirs: List[str] = [] for prefix in reversed(list(self._prefixes.values())): self._bin_dirs.append(prefix.bin_dir) self._lib_dirs.extend(prefix.lib_dirs) @@ -91,15 +97,17 @@ class BuildEnvironment: # Customize site to: # - ensure .pth files are honored # - prevent access to system site packages - system_sites = { - os.path.normcase(site) for site in (get_purelib(), get_platlib()) - } - self._site_dir = os.path.join(temp_dir.path, 'site') + system_sites = _get_system_sitepackages() + + self._site_dir = os.path.join(temp_dir.path, "site") if not os.path.exists(self._site_dir): os.mkdir(self._site_dir) - with open(os.path.join(self._site_dir, 'sitecustomize.py'), 'w') as fp: - fp.write(textwrap.dedent( - ''' + with open( + os.path.join(self._site_dir, "sitecustomize.py"), "w", encoding="utf-8" + ) as fp: + fp.write( + textwrap.dedent( + """ import os, site, sys # First, drop system-sites related paths. @@ -122,90 +130,97 @@ class BuildEnvironment: for path in {lib_dirs!r}: assert not path in sys.path site.addsitedir(path) - ''' - ).format(system_sites=system_sites, lib_dirs=self._lib_dirs)) + """ + ).format(system_sites=system_sites, lib_dirs=self._lib_dirs) + ) - def __enter__(self): - # type: () -> None + def __enter__(self) -> None: self._save_env = { name: os.environ.get(name, None) - for name in ('PATH', 'PYTHONNOUSERSITE', 'PYTHONPATH') + for name in ("PATH", "PYTHONNOUSERSITE", "PYTHONPATH") } path = self._bin_dirs[:] - old_path = self._save_env['PATH'] + old_path = self._save_env["PATH"] if old_path: path.extend(old_path.split(os.pathsep)) pythonpath = [self._site_dir] - os.environ.update({ - 'PATH': os.pathsep.join(path), - 'PYTHONNOUSERSITE': '1', - 'PYTHONPATH': os.pathsep.join(pythonpath), - }) + os.environ.update( + { + "PATH": os.pathsep.join(path), + "PYTHONNOUSERSITE": "1", + "PYTHONPATH": os.pathsep.join(pythonpath), + } + ) def __exit__( self, - exc_type, # type: Optional[Type[BaseException]] - exc_val, # type: Optional[BaseException] - exc_tb # type: Optional[TracebackType] - ): - # type: (...) -> None + exc_type: Optional[Type[BaseException]], + exc_val: Optional[BaseException], + exc_tb: Optional[TracebackType], + ) -> None: for varname, old_value in self._save_env.items(): if old_value is None: os.environ.pop(varname, None) else: os.environ[varname] = old_value - def check_requirements(self, reqs): - # type: (Iterable[str]) -> Tuple[Set[Tuple[str, str]], Set[str]] + def check_requirements( + self, reqs: Iterable[str] + ) -> Tuple[Set[Tuple[str, str]], Set[str]]: """Return 2 sets: - - conflicting requirements: set of (installed, wanted) reqs tuples - - missing requirements: set of reqs + - conflicting requirements: set of (installed, wanted) reqs tuples + - missing requirements: set of reqs """ missing = set() conflicting = set() if reqs: - ws = WorkingSet(self._lib_dirs) - for req in reqs: - try: - if ws.find(Requirement.parse(req)) is None: - missing.add(req) - except VersionConflict as e: - conflicting.add((str(e.args[0].as_requirement()), - str(e.args[1]))) + env = ( + get_environment(self._lib_dirs) + if hasattr(self, "_lib_dirs") + else get_default_environment() + ) + for req_str in reqs: + req = Requirement(req_str) + # We're explicitly evaluating with an empty extra value, since build + # environments are not provided any mechanism to select specific extras. + if req.marker is not None and not req.marker.evaluate({"extra": ""}): + continue + dist = env.get_distribution(req.name) + if not dist: + missing.add(req_str) + continue + if isinstance(dist.version, Version): + installed_req_str = f"{req.name}=={dist.version}" + else: + installed_req_str = f"{req.name}==={dist.version}" + if not req.specifier.contains(dist.version, prereleases=True): + conflicting.add((installed_req_str, req_str)) + # FIXME: Consider direct URL? return conflicting, missing def install_requirements( self, - finder, # type: PackageFinder - requirements, # type: Iterable[str] - prefix_as_string, # type: str - message # type: str - ): - # type: (...) -> None + finder: "PackageFinder", + requirements: Iterable[str], + prefix_as_string: str, + *, + kind: str, + ) -> None: prefix = self._prefixes[prefix_as_string] assert not prefix.setup prefix.setup = True if not requirements: return - with contextlib.ExitStack() as ctx: - # TODO: Remove this block when dropping 3.6 support. Python 3.6 - # lacks importlib.resources and pep517 has issues loading files in - # a zip, so we fallback to the "old" method by adding the current - # pip directory to the child process's sys.path. - if sys.version_info < (3, 7): - pip_runnable = os.path.dirname(pip_location) - else: - pip_runnable = ctx.enter_context(_create_standalone_pip()) - self._install_requirements( - pip_runnable, - finder, - requirements, - prefix, - message, - ) + self._install_requirements( + get_runnable_pip(), + finder, + requirements, + prefix, + kind=kind, + ) @staticmethod def _install_requirements( @@ -213,74 +228,84 @@ class BuildEnvironment: finder: "PackageFinder", requirements: Iterable[str], prefix: _Prefix, - message: str, + *, + kind: str, ) -> None: - args = [ - sys.executable, pip_runnable, 'install', - '--ignore-installed', '--no-user', '--prefix', prefix.path, - '--no-warn-script-location', - ] # type: List[str] + args: List[str] = [ + sys.executable, + pip_runnable, + "install", + "--ignore-installed", + "--no-user", + "--prefix", + prefix.path, + "--no-warn-script-location", + ] if logger.getEffectiveLevel() <= logging.DEBUG: - args.append('-v') - for format_control in ('no_binary', 'only_binary'): + args.append("-v") + for format_control in ("no_binary", "only_binary"): formats = getattr(finder.format_control, format_control) - args.extend(('--' + format_control.replace('_', '-'), - ','.join(sorted(formats or {':none:'})))) + args.extend( + ( + "--" + format_control.replace("_", "-"), + ",".join(sorted(formats or {":none:"})), + ) + ) index_urls = finder.index_urls if index_urls: - args.extend(['-i', index_urls[0]]) + args.extend(["-i", index_urls[0]]) for extra_index in index_urls[1:]: - args.extend(['--extra-index-url', extra_index]) + args.extend(["--extra-index-url", extra_index]) else: - args.append('--no-index') + args.append("--no-index") for link in finder.find_links: - args.extend(['--find-links', link]) + args.extend(["--find-links", link]) for host in finder.trusted_hosts: - args.extend(['--trusted-host', host]) + args.extend(["--trusted-host", host]) if finder.allow_all_prereleases: - args.append('--pre') + args.append("--pre") if finder.prefer_binary: - args.append('--prefer-binary') - args.append('--') + args.append("--prefer-binary") + args.append("--") args.extend(requirements) extra_environ = {"_PIP_STANDALONE_CERT": where()} - with open_spinner(message) as spinner: - call_subprocess(args, spinner=spinner, extra_environ=extra_environ) + with open_spinner(f"Installing {kind}") as spinner: + call_subprocess( + args, + command_desc=f"pip subprocess to install {kind}", + spinner=spinner, + extra_environ=extra_environ, + ) class NoOpBuildEnvironment(BuildEnvironment): - """A no-op drop-in replacement for BuildEnvironment - """ + """A no-op drop-in replacement for BuildEnvironment""" - def __init__(self): - # type: () -> None + def __init__(self) -> None: pass - def __enter__(self): - # type: () -> None + def __enter__(self) -> None: pass def __exit__( self, - exc_type, # type: Optional[Type[BaseException]] - exc_val, # type: Optional[BaseException] - exc_tb # type: Optional[TracebackType] - ): - # type: (...) -> None + exc_type: Optional[Type[BaseException]], + exc_val: Optional[BaseException], + exc_tb: Optional[TracebackType], + ) -> None: pass - def cleanup(self): - # type: () -> None + def cleanup(self) -> None: pass def install_requirements( self, - finder, # type: PackageFinder - requirements, # type: Iterable[str] - prefix_as_string, # type: str - message # type: str - ): - # type: (...) -> None + finder: "PackageFinder", + requirements: Iterable[str], + prefix_as_string: str, + *, + kind: str, + ) -> None: raise NotImplementedError() diff --git a/env/Lib/site-packages/pip/_internal/cache.py b/env/Lib/site-packages/pip/_internal/cache.py index 7ef51b92..8d3a664c 100644 --- a/env/Lib/site-packages/pip/_internal/cache.py +++ b/env/Lib/site-packages/pip/_internal/cache.py @@ -5,13 +5,14 @@ import hashlib import json import logging import os -from typing import Any, Dict, List, Optional, Set +from pathlib import Path +from typing import Any, Dict, List, Optional from pip._vendor.packaging.tags import Tag, interpreter_name, interpreter_version from pip._vendor.packaging.utils import canonicalize_name from pip._internal.exceptions import InvalidWheelFilename -from pip._internal.models.format_control import FormatControl +from pip._internal.models.direct_url import DirectUrl from pip._internal.models.link import Link from pip._internal.models.wheel import Wheel from pip._internal.utils.temp_dir import TempDirectory, tempdir_kinds @@ -19,9 +20,10 @@ from pip._internal.utils.urls import path_to_url logger = logging.getLogger(__name__) +ORIGIN_JSON_NAME = "origin.json" -def _hash_dict(d): - # type: (Dict[str, str]) -> str + +def _hash_dict(d: Dict[str, str]) -> str: """Return a stable sha224 of a dictionary.""" s = json.dumps(d, sort_keys=True, separators=(",", ":"), ensure_ascii=True) return hashlib.sha224(s.encode("ascii")).hexdigest() @@ -30,29 +32,16 @@ def _hash_dict(d): class Cache: """An abstract class - provides cache directories for data from links - - :param cache_dir: The root of the cache. - :param format_control: An object of FormatControl class to limit - binaries being read from the cache. - :param allowed_formats: which formats of files the cache should store. - ('binary' and 'source' are the only allowed values) + :param cache_dir: The root of the cache. """ - def __init__(self, cache_dir, format_control, allowed_formats): - # type: (str, FormatControl, Set[str]) -> None + def __init__(self, cache_dir: str) -> None: super().__init__() assert not cache_dir or os.path.isabs(cache_dir) self.cache_dir = cache_dir or None - self.format_control = format_control - self.allowed_formats = allowed_formats - - _valid_formats = {"source", "binary"} - assert self.allowed_formats.union(_valid_formats) == _valid_formats - def _get_cache_path_parts(self, link): - # type: (Link) -> List[str] - """Get parts of part that must be os.path.joined with cache_dir - """ + def _get_cache_path_parts(self, link: Link) -> List[str]: + """Get parts of part that must be os.path.joined with cache_dir""" # We want to generate an url to use as our cache key, we don't want to # just re-use the URL because it might have other items in the fragment @@ -84,22 +73,11 @@ class Cache: return parts - def _get_candidates(self, link, canonical_package_name): - # type: (Link, str) -> List[Any] - can_not_cache = ( - not self.cache_dir or - not canonical_package_name or - not link - ) + def _get_candidates(self, link: Link, canonical_package_name: str) -> List[Any]: + can_not_cache = not self.cache_dir or not canonical_package_name or not link if can_not_cache: return [] - formats = self.format_control.get_allowed_formats( - canonical_package_name - ) - if not self.allowed_formats.intersection(formats): - return [] - candidates = [] path = self.get_path_for_link(link) if os.path.isdir(path): @@ -107,19 +85,16 @@ class Cache: candidates.append((candidate, path)) return candidates - def get_path_for_link(self, link): - # type: (Link) -> str - """Return a directory to store cached items in for link. - """ + def get_path_for_link(self, link: Link) -> str: + """Return a directory to store cached items in for link.""" raise NotImplementedError() def get( self, - link, # type: Link - package_name, # type: Optional[str] - supported_tags, # type: List[Tag] - ): - # type: (...) -> Link + link: Link, + package_name: Optional[str], + supported_tags: List[Tag], + ) -> Link: """Returns a link to a cached item if it exists, otherwise returns the passed link. """ @@ -127,15 +102,12 @@ class Cache: class SimpleWheelCache(Cache): - """A cache of wheels for future installs. - """ + """A cache of wheels for future installs.""" - def __init__(self, cache_dir, format_control): - # type: (str, FormatControl) -> None - super().__init__(cache_dir, format_control, {"binary"}) + def __init__(self, cache_dir: str) -> None: + super().__init__(cache_dir) - def get_path_for_link(self, link): - # type: (Link) -> str + def get_path_for_link(self, link: Link) -> str: """Return a directory to store cached wheels for link Because there are M wheels for any one sdist, we provide a directory @@ -157,20 +129,17 @@ class SimpleWheelCache(Cache): def get( self, - link, # type: Link - package_name, # type: Optional[str] - supported_tags, # type: List[Tag] - ): - # type: (...) -> Link + link: Link, + package_name: Optional[str], + supported_tags: List[Tag], + ) -> Link: candidates = [] if not package_name: return link canonical_package_name = canonicalize_name(package_name) - for wheel_name, wheel_dir in self._get_candidates( - link, canonical_package_name - ): + for wheel_name, wheel_dir in self._get_candidates(link, canonical_package_name): try: wheel = Wheel(wheel_name) except InvalidWheelFilename: @@ -179,7 +148,9 @@ class SimpleWheelCache(Cache): logger.debug( "Ignoring cached wheel %s for %s as it " "does not match the expected distribution name %s.", - wheel_name, link, package_name, + wheel_name, + link, + package_name, ) continue if not wheel.supported(supported_tags): @@ -201,27 +172,39 @@ class SimpleWheelCache(Cache): class EphemWheelCache(SimpleWheelCache): - """A SimpleWheelCache that creates it's own temporary cache directory - """ + """A SimpleWheelCache that creates it's own temporary cache directory""" - def __init__(self, format_control): - # type: (FormatControl) -> None + def __init__(self) -> None: self._temp_dir = TempDirectory( kind=tempdir_kinds.EPHEM_WHEEL_CACHE, globally_managed=True, ) - super().__init__(self._temp_dir.path, format_control) + super().__init__(self._temp_dir.path) class CacheEntry: def __init__( self, - link, # type: Link - persistent, # type: bool + link: Link, + persistent: bool, ): self.link = link self.persistent = persistent + self.origin: Optional[DirectUrl] = None + origin_direct_url_path = Path(self.link.file_path).parent / ORIGIN_JSON_NAME + if origin_direct_url_path.exists(): + try: + self.origin = DirectUrl.from_json( + origin_direct_url_path.read_text(encoding="utf-8") + ) + except Exception as e: + logger.warning( + "Ignoring invalid cache entry origin file %s for %s (%s)", + origin_direct_url_path, + link.filename, + e, + ) class WheelCache(Cache): @@ -231,27 +214,23 @@ class WheelCache(Cache): when a certain link is not found in the simple wheel cache first. """ - def __init__(self, cache_dir, format_control): - # type: (str, FormatControl) -> None - super().__init__(cache_dir, format_control, {'binary'}) - self._wheel_cache = SimpleWheelCache(cache_dir, format_control) - self._ephem_cache = EphemWheelCache(format_control) + def __init__(self, cache_dir: str) -> None: + super().__init__(cache_dir) + self._wheel_cache = SimpleWheelCache(cache_dir) + self._ephem_cache = EphemWheelCache() - def get_path_for_link(self, link): - # type: (Link) -> str + def get_path_for_link(self, link: Link) -> str: return self._wheel_cache.get_path_for_link(link) - def get_ephem_path_for_link(self, link): - # type: (Link) -> str + def get_ephem_path_for_link(self, link: Link) -> str: return self._ephem_cache.get_path_for_link(link) def get( self, - link, # type: Link - package_name, # type: Optional[str] - supported_tags, # type: List[Tag] - ): - # type: (...) -> Link + link: Link, + package_name: Optional[str], + supported_tags: List[Tag], + ) -> Link: cache_entry = self.get_cache_entry(link, package_name, supported_tags) if cache_entry is None: return link @@ -259,11 +238,10 @@ class WheelCache(Cache): def get_cache_entry( self, - link, # type: Link - package_name, # type: Optional[str] - supported_tags, # type: List[Tag] - ): - # type: (...) -> Optional[CacheEntry] + link: Link, + package_name: Optional[str], + supported_tags: List[Tag], + ) -> Optional[CacheEntry]: """Returns a CacheEntry with a link to a cached item if it exists or None. The cache entry indicates if the item was found in the persistent or ephemeral cache. @@ -285,3 +263,30 @@ class WheelCache(Cache): return CacheEntry(retval, persistent=False) return None + + @staticmethod + def record_download_origin(cache_dir: str, download_info: DirectUrl) -> None: + origin_path = Path(cache_dir) / ORIGIN_JSON_NAME + if origin_path.exists(): + try: + origin = DirectUrl.from_json(origin_path.read_text(encoding="utf-8")) + except Exception as e: + logger.warning( + "Could not read origin file %s in cache entry (%s). " + "Will attempt to overwrite it.", + origin_path, + e, + ) + else: + # TODO: use DirectUrl.equivalent when + # https://github.com/pypa/pip/pull/10564 is merged. + if origin.url != download_info.url: + logger.warning( + "Origin URL %s in cache entry %s does not match download URL " + "%s. This is likely a pip bug or a cache corruption issue. " + "Will overwrite it with the new value.", + origin.url, + cache_dir, + download_info.url, + ) + origin_path.write_text(download_info.to_json(), encoding="utf-8") diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index ff82adfae63eee653bc79382e24e4c238b6a410f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 300 zcmYe~<>g{vU|^UdaWJ)ofq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}X0gG-YN z5|gtN(^D0a^Ycm)GxIX@(iIYOauo8@6bdp6)Qc68^K)|(^HLOYGV@XuGV@AOi_#L4 zQx%F*a}rBZQxuZ(Q&PG7G#PKP$H%ASC&$OHWGG@{V1N+6>YS}&LW@(2iepl9QZkET z{PR*>iZaVm6?7Fs{XD~5gMvLn9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u5>0e- z^3yYmOER-#QuE4Ud@_?_iZe@6b)l{<jw#42(2oZ@D=#reKRG8;KR!M)FS8^*Uaz3? U7Kcr4eoARhsvRf<K7)b;0O!eA`2YX_ diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-39.pyc deleted file mode 100644 index 5bd91fd9253b4308b87b47d6255bec2e41e9d916..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4998 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 diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-39.pyc deleted file mode 100644 index b3f214f29cbc78efc695aa019cc97ce97a990923..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5821 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 UYziC@7ASWKF!C_5F>x^i05Y{rN&o-= diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-39.pyc deleted file mode 100644 index 12076cc0043e7bf61c200f413071848f1f2d3d10..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21055 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\Cah2EQU@9Dxj7r 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 diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-39.pyc deleted file mode 100644 index c6722b70ee195e4921c901fcde9d50fd6b8d0848..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1249 zcmYe~<>g{vU|^UdaWGY%nStRkh=Yt-7#J8F7#J9eofsGxQW#Pga~N_NqZo6UqL>&# ze5M@cT$U)7T-GSoT(&4SMut?j6y_9`6xLp*D0X*-6t)!h7KRk|W~L~P6pmm9P0p7f z(>0lHak^GymIRk1CTHK`OU}<LNv$Z!P0UM7Pc719zQyMZ5%GnH+~V*oNi9k&$uGLa z9#UD58kSgeizz-NM3eCrXL5d7Vo_#dUP&^@U}Ve;<rEt*FfgPtL@}l?L@~89q%o#2 zrZBZ|L@}qbfSlUG(99Ucn!=jG*1{0Q*3Q7f5XBzMpvitq*f~EpH!&{-=9bI~&%9(t zsG%SV#Aae(U;tTEEW^OSP{Pp6uz+zP10zEUV+}(*Qwei3Lk&YbOA13UgC>)on<ncm z*5cBF)S_D)@$s2?nI-Y@w*=xd^Wt+8GxOr1p-==e@)j?O*h<D*EXAogX)76TamL3d z=Oh*v$H%W^_|@uc6%$&VT2vg9nv;@Q6yu+l>Qa<hma3qu5bEa{<{A|28R8hM;OXb$ z@8=rq=@=92>gyUD;u@r2784NQ6O(A7o0FfOSzMBt9g~_@7UPqd6jPj8lB!#fn4F!M zo?0AJkXfJ~pP5&ZT9lWVqo16Ush<o96_|7N3Mz}Z85kHiK#7D66f8_!jBJcmGFU=S z59Vu(U<By~MPP9V0|P@1Ll#33mls15BRCits?2H_vKaftKnX64fsrAcA%%g3frX)& znUNt+z>uNX#DIYj3?m`3Of?Mg40#+WVA_BI9Q@3FA#R#XMLY})3`M*kf)7Lp!3kjo z28LTa$PocjPz+Mfz|6(O#>m9T!KlVmrGU*}$l8)Y@dpYA5C*Y9$-@~GI$}`26@&c- z^3wvQ8pef;!3>&=ewxe(x834R1%)^)h&7pt_(84{fToc6f};Gg%#_rkB2?!Wi83%S zNP%nu<yr<NE~Y9)Y_3H$oCA~?^AdAY<Ku5}#mDF7r<CS^*gWy^g{6r(5E*b37lC|I zBmxRDkWIIEp-C}0H76%N9?3BRASIvxE#hQgU|<Ki2o%8_j67^ij9lDcQ9n)2TU<~N z<zyy-Q$5&%TWlqj1(|v2MIcWUv4V^OC95KkF<_lY7J>Z_vgj6v4aDJgpiEf|(jdSn I!o<T20NRlz)Bpeg diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-39.pyc deleted file mode 100644 index 2a1ea13d959aefde891da5e34e74833dcebedcdb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1349 zcmYe~<>g{vU|^UdaWHi=Cj-M{5C<7EGcYhXFfcF_cQ7z8q%cG=q%fv1<uFDuf@!8G zCNRw$#SErdqF7QGQ<!sDbJ?QUa@nKU8A0k<ayW81qd38A)*P-}?kH|Bn=OYYmp6(R z%x2Hw%jJ*a2eUbH1abwV1Q{7pnHC783NK`g5=r4s;Y{IbVT=+@VG3r@<f&2!D9X%D zEUHvUEGWpyOinDx%+FIu%_}LYEXdEyE79Y63G#)XCetkzpUmQtTO9rcASH=8nvA!2 z5=%?+lk;;6a#BlDH5qU579<uGr^YAe=jJBnrD!tV;!7?{O)Nnc;Rwhqa4jmzFVbYZ z#hsE`P?QR>GMN!%4HUC6Fff2Z(-{<APZ$^&Y8X-&N*Rj8N*J<0;l<F(B*{?AP{Oo; zc_9NMLkUYW10zF~KnZINLo;IxQ!QgHQ#eDO9}7bXTV)d?LoG8SLzP(xLl*l2jufUE z=GhE$nHDlKGC)L1IJ3AQyan7Tj38DxLnK2ALoIV1a~>CjHefJds1hpSS-@Mulf{?9 zypV~JA)F!4h=rkqCyT%G1S3N&3nN37M2Wxx!4#Gn7Kl996qY&`uqiBcEFe=#glZU5 zSZkQd7*g1JnQB>USQiM_FfC*ZX3%8!dkG4JDt6bPApamMg<A|&s-Ee2`9+y|=?bZ! zFjG)1Rw&O%%~L2&Ehzzs=Hw?Q=A>3}>FQ<{=jSArq=EvS1I`w?#avuje2XQqD7~zR zgMoqJmRM$9aY<rMPJDS{QC?<VdVEfPdU|S65eowYLlG;8U<WB<D=tY%Eh@UjT3(b{ zl6s3NzxWn=PG(+eacaRWmeh*Ol3Q#Lt8Z}@r<OpOY(CEMjy^uOSi$iNQUNmh7Hdjs zQfYb-C{Ay&<R)h3X|jP`RD6pgIX5LfFEKY2!b&VkFTTZ`T9JH<G4&QZG!d<2C{ko# zVE9$#Y!wq)oLW>IlbVx~Srp@+m+DfKS(d7xs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2 z?CR?p9O4?JU=|Y);1iQ*qMMVSo>^RynH`gwR~F-wnG{o;S(2(-keHmEn4Vf3Q;=Dp zAD@|5l3J9Pn4_PZlc^7KtX@H7krV?1gDxm3DuB`_69*$7GY1nJ6BDBVBOjv>BOjvz z3lpOdqX3f<qW}|FwI-vVrr0g^`1q9k<oNg^5m1=2gMvCUFTF?*6wEvzA-0mr0+0w3 zNCZ?s+)^mWEYO3yLN7TdQx7SRW#;FBW9pVHrZSLY<H7l_2po~O#L(10GG#F&A|y~H zQ!A2F!P&aF2o(QO!l=@vC7C(JkOah;o?7AqPBXVS;=z#@A73N^az7}Pz;T5{D1m&* gVUwGmQks)$2TI+=Ahj$^9E=bsz{JA{g-l#>0Binn#sB~S diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-39.pyc deleted file mode 100644 index 87424e9188b059ff2b0dd1d8a7285af6a210861d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2130 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 KfQf^dLjeFfwo<YH diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-39.pyc deleted file mode 100644 index b3ce798f74719f2627fecd76d78d5c0fff11d182..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9394 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 diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-39.pyc deleted file mode 100644 index 876b8062f01fc20a4763f35b0baedb985488f221..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7466 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 J6#i!81OU2v%cTGS diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-39.pyc deleted file mode 100644 index 98a9806baf04bcc2b17af91728798359eb791a1b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11309 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 diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-39.pyc deleted file mode 100644 index c1157315338cbb7d296cd9a545cf70586998bfa0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4637 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 diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-39.pyc deleted file mode 100644 index 603750ba7833106e3d2b6e9315c72062ecacba23..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 379 zcmYe~<>g{vU|^UdaWJ)nfq~&Mh=Yt785kHG7#J9eWf&M3QW&BbQW&EcQ<$QdQkbKd zQ&^%{Qdpx{Q`mwTG}&K*^t}XWc*(@T!0?h8M6iGeaRvqkKTWn<?7^YV&aT11w^&_+ zg8YMS@rL?&`}v3a#Y4CvVV*%Dp^iSTeqr%`{vq*h{-J&@w<H3BT*Ey5Lxba;LOp$4 z;$1w0py~zu{NsHcL!3QagCS~HG8FMLFhGc3P0m&^p~b01#WATlDVaqv{&}e`MVV!( z3c3oRex6~jLBXCOj=>6^elGrguECy;F~P3BuE8O$K?-Iu0RcWSi6*)^`RSR(C7IbV zsd;5FKAA}|#hE3kx&?{J*@@|?#W4k$1^V%sc_pbud5Jmt$vK(&#U+U)rN!~d`6;Qz bdIgoYIBatBQ%ZAE?LeVY3<_x$Mi>MD!%Ss~ diff --git a/env/Lib/site-packages/pip/_internal/cli/autocompletion.py b/env/Lib/site-packages/pip/_internal/cli/autocompletion.py index 3b1d2ac9..226fe84d 100644 --- a/env/Lib/site-packages/pip/_internal/cli/autocompletion.py +++ b/env/Lib/site-packages/pip/_internal/cli/autocompletion.py @@ -9,11 +9,10 @@ from typing import Any, Iterable, List, Optional from pip._internal.cli.main_parser import create_main_parser from pip._internal.commands import commands_dict, create_command -from pip._internal.utils.misc import get_installed_distributions +from pip._internal.metadata import get_default_environment -def autocomplete(): - # type: () -> None +def autocomplete() -> None: """Entry Point for completion of main and subcommand options.""" # Don't complete if user hasn't sourced bash_completion file. if "PIP_AUTO_COMPLETE" not in os.environ: @@ -30,7 +29,7 @@ def autocomplete(): options = [] # subcommand - subcommand_name = None # type: Optional[str] + subcommand_name: Optional[str] = None for word in cwords: if word in subcommands: subcommand_name = word @@ -46,11 +45,13 @@ def autocomplete(): "uninstall", ] if should_list_installed: + env = get_default_environment() lc = current.lower() installed = [ - dist.key - for dist in get_installed_distributions(local_only=True) - if dist.key.startswith(lc) and dist.key not in cwords[1:] + dist.canonical_name + for dist in env.iter_installed_distributions(local_only=True) + if dist.canonical_name.startswith(lc) + and dist.canonical_name not in cwords[1:] ] # if there are no dists installed, fall back to option completion if installed: @@ -58,6 +59,14 @@ def autocomplete(): print(dist) sys.exit(1) + should_list_installables = ( + not current.startswith("-") and subcommand_name == "install" + ) + if should_list_installables: + for path in auto_complete_paths(current, "path"): + print(path) + sys.exit(1) + subcommand = create_command(subcommand_name) for opt in subcommand.parser.option_list_all: @@ -107,8 +116,9 @@ def autocomplete(): sys.exit(1) -def get_path_completion_type(cwords, cword, opts): - # type: (List[str], int, Iterable[Any]) -> Optional[str] +def get_path_completion_type( + cwords: List[str], cword: int, opts: Iterable[Any] +) -> Optional[str]: """Get the type of path completion (``file``, ``dir``, ``path`` or None) :param cwords: same as the environmental variable ``COMP_WORDS`` @@ -130,14 +140,13 @@ def get_path_completion_type(cwords, cword, opts): return None -def auto_complete_paths(current, completion_type): - # type: (str, str) -> Iterable[str] +def auto_complete_paths(current: str, completion_type: str) -> Iterable[str]: """If ``completion_type`` is ``file`` or ``path``, list all regular files and directories starting with ``current``; otherwise only list directories starting with ``current``. :param current: The word to be completed - :param completion_type: path completion type(`file`, `path` or `dir`)i + :param completion_type: path completion type(``file``, ``path`` or ``dir``) :return: A generator of regular files and/or directories """ directory, filename = os.path.split(current) diff --git a/env/Lib/site-packages/pip/_internal/cli/base_command.py b/env/Lib/site-packages/pip/_internal/cli/base_command.py index b59420dd..6a3b8e6c 100644 --- a/env/Lib/site-packages/pip/_internal/cli/base_command.py +++ b/env/Lib/site-packages/pip/_internal/cli/base_command.py @@ -1,5 +1,6 @@ """Base Command class, and related routines""" +import functools import logging import logging.config import optparse @@ -7,7 +8,9 @@ import os import sys import traceback from optparse import Values -from typing import Any, List, Optional, Tuple +from typing import Any, Callable, List, Optional, Tuple + +from pip._vendor.rich import traceback as rich_traceback from pip._internal.cli import cmdoptions from pip._internal.cli.command_context import CommandContextMixIn @@ -21,12 +24,12 @@ from pip._internal.cli.status_codes import ( from pip._internal.exceptions import ( BadCommand, CommandError, + DiagnosticPipError, InstallationError, NetworkConnectionError, PreviousBuildDirError, UninstallationError, ) -from pip._internal.utils.deprecation import deprecated from pip._internal.utils.filesystem import check_path_owner from pip._internal.utils.logging import BrokenStdoutLoggingError, setup_logging from pip._internal.utils.misc import get_prog, normalize_path @@ -40,11 +43,10 @@ logger = logging.getLogger(__name__) class Command(CommandContextMixIn): - usage = None # type: str - ignore_require_venv = False # type: bool + usage: str = "" + ignore_require_venv: bool = False - def __init__(self, name, summary, isolated=False): - # type: (str, str, bool) -> None + def __init__(self, name: str, summary: str, isolated: bool = False) -> None: super().__init__() self.name = name @@ -59,7 +61,7 @@ class Command(CommandContextMixIn): isolated=isolated, ) - self.tempdir_registry = None # type: Optional[TempDirRegistry] + self.tempdir_registry: Optional[TempDirRegistry] = None # Commands should add options to this option group optgroup_name = f"{self.name.capitalize()} Options" @@ -74,12 +76,10 @@ class Command(CommandContextMixIn): self.add_options() - def add_options(self): - # type: () -> None + def add_options(self) -> None: pass - def handle_pip_version_check(self, options): - # type: (Values) -> None + def handle_pip_version_check(self, options: Values) -> None: """ This is a no-op so that commands by default do not do the pip version check. @@ -88,25 +88,21 @@ class Command(CommandContextMixIn): # are present. assert not hasattr(options, "no_index") - def run(self, options, args): - # type: (Values, List[Any]) -> int + def run(self, options: Values, args: List[str]) -> int: raise NotImplementedError - def parse_args(self, args): - # type: (List[str]) -> Tuple[Any, Any] + def parse_args(self, args: List[str]) -> Tuple[Values, List[str]]: # factored out for testability return self.parser.parse_args(args) - def main(self, args): - # type: (List[str]) -> int + def main(self, args: List[str]) -> int: try: with self.main_context(): return self._main(args) finally: logging.shutdown() - def _main(self, args): - # type: (List[str]) -> int + def _main(self, args: List[str]) -> int: # We must initialize this before the tempdir manager, otherwise the # configuration would not be accessible by the time we clean up the # tempdir manager. @@ -126,6 +122,26 @@ class Command(CommandContextMixIn): user_log_file=options.log, ) + always_enabled_features = set(options.features_enabled) & set( + cmdoptions.ALWAYS_ENABLED_FEATURES + ) + if always_enabled_features: + logger.warning( + "The following features are always enabled: %s. ", + ", ".join(sorted(always_enabled_features)), + ) + + # Make sure that the --python argument isn't specified after the + # subcommand. We can tell, because if --python was specified, + # we should only reach this point if we're running in the created + # subprocess, which has the _PIP_RUNNING_IN_SUBPROCESS environment + # variable set. + if options.python and "_PIP_RUNNING_IN_SUBPROCESS" not in os.environ: + logger.critical( + "The --python option must be placed before the pip subcommand name" + ) + sys.exit(ERROR) + # TODO: Try to get these passing down from the command? # without resorting to os.environ to hold these. # This also affects isolated builds and it should. @@ -155,67 +171,66 @@ class Command(CommandContextMixIn): ) options.cache_dir = None - if getattr(options, "build_dir", None): - deprecated( - reason=( - "The -b/--build/--build-dir/--build-directory " - "option is deprecated and has no effect anymore." - ), - replacement=( - "use the TMPDIR/TEMP/TMP environment variable, " - "possibly combined with --no-clean" - ), - gone_in="21.3", - issue=8333, - ) - - if "2020-resolver" in options.features_enabled: - logger.warning( - "--use-feature=2020-resolver no longer has any effect, " - "since it is now the default dependency resolver in pip. " - "This will become an error in pip 21.0." - ) + def intercepts_unhandled_exc( + run_func: Callable[..., int] + ) -> Callable[..., int]: + @functools.wraps(run_func) + def exc_logging_wrapper(*args: Any) -> int: + try: + status = run_func(*args) + assert isinstance(status, int) + return status + except DiagnosticPipError as exc: + logger.error("[present-rich] %s", exc) + logger.debug("Exception information:", exc_info=True) + + return ERROR + except PreviousBuildDirError as exc: + logger.critical(str(exc)) + logger.debug("Exception information:", exc_info=True) + + return PREVIOUS_BUILD_DIR_ERROR + except ( + InstallationError, + UninstallationError, + BadCommand, + NetworkConnectionError, + ) as exc: + logger.critical(str(exc)) + logger.debug("Exception information:", exc_info=True) + + return ERROR + except CommandError as exc: + logger.critical("%s", exc) + logger.debug("Exception information:", exc_info=True) + + return ERROR + except BrokenStdoutLoggingError: + # Bypass our logger and write any remaining messages to + # stderr because stdout no longer works. + print("ERROR: Pipe to stdout was broken", file=sys.stderr) + if level_number <= logging.DEBUG: + traceback.print_exc(file=sys.stderr) + + return ERROR + except KeyboardInterrupt: + logger.critical("Operation cancelled by user") + logger.debug("Exception information:", exc_info=True) + + return ERROR + except BaseException: + logger.critical("Exception:", exc_info=True) + + return UNKNOWN_ERROR + + return exc_logging_wrapper try: - status = self.run(options, args) - assert isinstance(status, int) - return status - except PreviousBuildDirError as exc: - logger.critical(str(exc)) - logger.debug("Exception information:", exc_info=True) - - return PREVIOUS_BUILD_DIR_ERROR - except ( - InstallationError, - UninstallationError, - BadCommand, - NetworkConnectionError, - ) as exc: - logger.critical(str(exc)) - logger.debug("Exception information:", exc_info=True) - - return ERROR - except CommandError as exc: - logger.critical("%s", exc) - logger.debug("Exception information:", exc_info=True) - - return ERROR - except BrokenStdoutLoggingError: - # Bypass our logger and write any remaining messages to stderr - # because stdout no longer works. - print("ERROR: Pipe to stdout was broken", file=sys.stderr) - if level_number <= logging.DEBUG: - traceback.print_exc(file=sys.stderr) - - return ERROR - except KeyboardInterrupt: - logger.critical("Operation cancelled by user") - logger.debug("Exception information:", exc_info=True) - - return ERROR - except BaseException: - logger.critical("Exception:", exc_info=True) - - return UNKNOWN_ERROR + if not options.debug_mode: + run = intercepts_unhandled_exc(self.run) + else: + run = self.run + rich_traceback.install(show_locals=True) + return run(options, args) finally: self.handle_pip_version_check(options) diff --git a/env/Lib/site-packages/pip/_internal/cli/cmdoptions.py b/env/Lib/site-packages/pip/_internal/cli/cmdoptions.py index f71c0b02..02ba6082 100644 --- a/env/Lib/site-packages/pip/_internal/cli/cmdoptions.py +++ b/env/Lib/site-packages/pip/_internal/cli/cmdoptions.py @@ -10,9 +10,10 @@ pass on state. To be consistent, all options will follow this design. # The following comment should be removed at some point in the future. # mypy: strict-optional=False +import importlib.util +import logging import os import textwrap -import warnings from functools import partial from optparse import SUPPRESS_HELP, Option, OptionGroup, OptionParser, Values from textwrap import dedent @@ -21,7 +22,6 @@ from typing import Any, Callable, Dict, Optional, Tuple from pip._vendor.packaging.utils import canonicalize_name from pip._internal.cli.parser import ConfigOptionParser -from pip._internal.cli.progress_bars import BAR_TYPES from pip._internal.exceptions import CommandError from pip._internal.locations import USER_CACHE_DIR, get_src_prefix from pip._internal.models.format_control import FormatControl @@ -30,9 +30,10 @@ from pip._internal.models.target_python import TargetPython from pip._internal.utils.hashes import STRONG_HASHES from pip._internal.utils.misc import strtobool +logger = logging.getLogger(__name__) -def raise_option_error(parser, option, msg): - # type: (OptionParser, Option, str) -> None + +def raise_option_error(parser: OptionParser, option: Option, msg: str) -> None: """ Raise an option parsing error using parser.error(). @@ -46,8 +47,7 @@ def raise_option_error(parser, option, msg): parser.error(msg) -def make_option_group(group, parser): - # type: (Dict[str, Any], ConfigOptionParser) -> OptionGroup +def make_option_group(group: Dict[str, Any], parser: ConfigOptionParser) -> OptionGroup: """ Return an OptionGroup object group -- assumed to be dict with 'name' and 'options' keys @@ -59,34 +59,7 @@ def make_option_group(group, parser): return option_group -def check_install_build_global(options, check_options=None): - # type: (Values, Optional[Values]) -> None - """Disable wheels if per-setup.py call options are set. - - :param options: The OptionParser options to update. - :param check_options: The options to check, if not supplied defaults to - options. - """ - if check_options is None: - check_options = options - - def getname(n): - # type: (str) -> Optional[Any] - return getattr(check_options, n, None) - - names = ["build_options", "global_options", "install_options"] - if any(map(getname, names)): - control = options.format_control - control.disallow_binaries() - warnings.warn( - "Disabling all use of wheels due to the use of --build-option " - "/ --global-option / --install-option.", - stacklevel=2, - ) - - -def check_dist_restriction(options, check_target=False): - # type: (Values, bool) -> None +def check_dist_restriction(options: Values, check_target: bool = False) -> None: """Function for determining if custom platform options are allowed. :param options: The OptionParser options. @@ -126,13 +99,11 @@ def check_dist_restriction(options, check_target=False): ) -def _path_option_check(option, opt, value): - # type: (Option, str, str) -> str +def _path_option_check(option: Option, opt: str, value: str) -> str: return os.path.expanduser(value) -def _package_name_option_check(option, opt, value): - # type: (Option, str, str) -> str +def _package_name_option_check(option: Option, opt: str, value: str) -> str: return canonicalize_name(value) @@ -147,16 +118,28 @@ class PipOption(Option): # options # ########### -help_ = partial( +help_: Callable[..., Option] = partial( Option, "-h", "--help", dest="help", action="help", help="Show help.", -) # type: Callable[..., Option] +) + +debug_mode: Callable[..., Option] = partial( + Option, + "--debug", + dest="debug_mode", + action="store_true", + default=False, + help=( + "Let unhandled exceptions propagate outside the main subroutine, " + "instead of logging them to stderr." + ), +) -isolated_mode = partial( +isolated_mode: Callable[..., Option] = partial( Option, "--isolated", dest="isolated_mode", @@ -166,20 +149,37 @@ isolated_mode = partial( "Run pip in an isolated mode, ignoring environment variables and user " "configuration." ), -) # type: Callable[..., Option] +) -require_virtualenv = partial( +require_virtualenv: Callable[..., Option] = partial( Option, - # Run only if inside a virtualenv, bail if not. "--require-virtualenv", "--require-venv", dest="require_venv", action="store_true", default=False, - help=SUPPRESS_HELP, -) # type: Callable[..., Option] + help=( + "Allow pip to only run in a virtual environment; " + "exit with an error otherwise." + ), +) + +override_externally_managed: Callable[..., Option] = partial( + Option, + "--break-system-packages", + dest="override_externally_managed", + action="store_true", + help="Allow pip to modify an EXTERNALLY-MANAGED Python installation", +) -verbose = partial( +python: Callable[..., Option] = partial( + Option, + "--python", + dest="python", + help="Run pip with the specified Python interpreter.", +) + +verbose: Callable[..., Option] = partial( Option, "-v", "--verbose", @@ -187,27 +187,27 @@ verbose = partial( action="count", default=0, help="Give more output. Option is additive, and can be used up to 3 times.", -) # type: Callable[..., Option] +) -no_color = partial( +no_color: Callable[..., Option] = partial( Option, "--no-color", dest="no_color", action="store_true", default=False, help="Suppress colored output.", -) # type: Callable[..., Option] +) -version = partial( +version: Callable[..., Option] = partial( Option, "-V", "--version", dest="version", action="store_true", help="Show version and exit.", -) # type: Callable[..., Option] +) -quiet = partial( +quiet: Callable[..., Option] = partial( Option, "-q", "--quiet", @@ -219,23 +219,19 @@ quiet = partial( " times (corresponding to WARNING, ERROR, and CRITICAL logging" " levels)." ), -) # type: Callable[..., Option] +) -progress_bar = partial( +progress_bar: Callable[..., Option] = partial( Option, "--progress-bar", dest="progress_bar", type="choice", - choices=list(BAR_TYPES.keys()), + choices=["on", "off"], default="on", - help=( - "Specify type of progress to be displayed [" - + "|".join(BAR_TYPES.keys()) - + "] (default: %default)" - ), -) # type: Callable[..., Option] + help="Specify whether the progress bar should be used [on, off] (default: on)", +) -log = partial( +log: Callable[..., Option] = partial( PipOption, "--log", "--log-file", @@ -244,9 +240,9 @@ log = partial( metavar="path", type="path", help="Path to a verbose appending log.", -) # type: Callable[..., Option] +) -no_input = partial( +no_input: Callable[..., Option] = partial( Option, # Don't ask for input "--no-input", @@ -254,18 +250,31 @@ no_input = partial( action="store_true", default=False, help="Disable prompting for input.", -) # type: Callable[..., Option] +) + +keyring_provider: Callable[..., Option] = partial( + Option, + "--keyring-provider", + dest="keyring_provider", + choices=["auto", "disabled", "import", "subprocess"], + default="auto", + help=( + "Enable the credential lookup via the keyring library if user input is allowed." + " Specify which mechanism to use [disabled, import, subprocess]." + " (default: disabled)" + ), +) -proxy = partial( +proxy: Callable[..., Option] = partial( Option, "--proxy", dest="proxy", type="str", default="", - help="Specify a proxy in the form [user:passwd@]proxy.server:port.", -) # type: Callable[..., Option] + help="Specify a proxy in the form scheme://[user:passwd@]proxy.server:port.", +) -retries = partial( +retries: Callable[..., Option] = partial( Option, "--retries", dest="retries", @@ -273,9 +282,9 @@ retries = partial( default=5, help="Maximum number of retries each connection should attempt " "(default %default times).", -) # type: Callable[..., Option] +) -timeout = partial( +timeout: Callable[..., Option] = partial( Option, "--timeout", "--default-timeout", @@ -284,11 +293,10 @@ timeout = partial( type="float", default=15, help="Set the socket timeout (default %default seconds).", -) # type: Callable[..., Option] +) -def exists_action(): - # type: () -> Option +def exists_action() -> Option: return Option( # Option when path already exist "--exists-action", @@ -303,7 +311,7 @@ def exists_action(): ) -cert = partial( +cert: Callable[..., Option] = partial( PipOption, "--cert", dest="cert", @@ -315,9 +323,9 @@ cert = partial( "See 'SSL Certificate Verification' in pip documentation " "for more information." ), -) # type: Callable[..., Option] +) -client_cert = partial( +client_cert: Callable[..., Option] = partial( PipOption, "--client-cert", dest="client_cert", @@ -326,9 +334,9 @@ client_cert = partial( metavar="path", help="Path to SSL client certificate, a single file containing the " "private key and the certificate in PEM format.", -) # type: Callable[..., Option] +) -index_url = partial( +index_url: Callable[..., Option] = partial( Option, "-i", "--index-url", @@ -340,11 +348,10 @@ index_url = partial( "This should point to a repository compliant with PEP 503 " "(the simple repository API) or a local directory laid out " "in the same format.", -) # type: Callable[..., Option] +) -def extra_index_url(): - # type: () -> Option +def extra_index_url() -> Option: return Option( "--extra-index-url", dest="extra_index_urls", @@ -357,18 +364,17 @@ def extra_index_url(): ) -no_index = partial( +no_index: Callable[..., Option] = partial( Option, "--no-index", dest="no_index", action="store_true", default=False, help="Ignore package index (only looking at --find-links URLs instead).", -) # type: Callable[..., Option] +) -def find_links(): - # type: () -> Option +def find_links() -> Option: return Option( "-f", "--find-links", @@ -378,14 +384,13 @@ def find_links(): metavar="url", help="If a URL or path to an html file, then parse for links to " "archives such as sdist (.tar.gz) or wheel (.whl) files. " - "If a local path or file:// URL that's a directory, " + "If a local path or file:// URL that's a directory, " "then look for archives in the directory listing. " "Links to VCS project URLs are not supported.", ) -def trusted_host(): - # type: () -> Option +def trusted_host() -> Option: return Option( "--trusted-host", dest="trusted_hosts", @@ -397,8 +402,7 @@ def trusted_host(): ) -def constraints(): - # type: () -> Option +def constraints() -> Option: return Option( "-c", "--constraint", @@ -411,8 +415,7 @@ def constraints(): ) -def requirements(): - # type: () -> Option +def requirements() -> Option: return Option( "-r", "--requirement", @@ -425,8 +428,7 @@ def requirements(): ) -def editable(): - # type: () -> Option +def editable() -> Option: return Option( "-e", "--editable", @@ -441,13 +443,12 @@ def editable(): ) -def _handle_src(option, opt_str, value, parser): - # type: (Option, str, str, OptionParser) -> None +def _handle_src(option: Option, opt_str: str, value: str, parser: OptionParser) -> None: value = os.path.abspath(value) setattr(parser.values, option.dest, value) -src = partial( +src: Callable[..., Option] = partial( PipOption, "--src", "--source", @@ -462,17 +463,17 @@ src = partial( help="Directory to check out editable projects into. " 'The default in a virtualenv is "<venv path>/src". ' 'The default for global installs is "<current dir>/src".', -) # type: Callable[..., Option] +) -def _get_format_control(values, option): - # type: (Values, Option) -> Any +def _get_format_control(values: Values, option: Option) -> Any: """Get a format_control object.""" return getattr(values, option.dest) -def _handle_no_binary(option, opt_str, value, parser): - # type: (Option, str, str, OptionParser) -> None +def _handle_no_binary( + option: Option, opt_str: str, value: str, parser: OptionParser +) -> None: existing = _get_format_control(parser.values, option) FormatControl.handle_mutual_excludes( value, @@ -481,8 +482,9 @@ def _handle_no_binary(option, opt_str, value, parser): ) -def _handle_only_binary(option, opt_str, value, parser): - # type: (Option, str, str, OptionParser) -> None +def _handle_only_binary( + option: Option, opt_str: str, value: str, parser: OptionParser +) -> None: existing = _get_format_control(parser.values, option) FormatControl.handle_mutual_excludes( value, @@ -491,8 +493,7 @@ def _handle_only_binary(option, opt_str, value, parser): ) -def no_binary(): - # type: () -> Option +def no_binary() -> Option: format_control = FormatControl(set(), set()) return Option( "--no-binary", @@ -510,8 +511,7 @@ def no_binary(): ) -def only_binary(): - # type: () -> Option +def only_binary() -> Option: format_control = FormatControl(set(), set()) return Option( "--only-binary", @@ -529,7 +529,7 @@ def only_binary(): ) -platforms = partial( +platforms: Callable[..., Option] = partial( Option, "--platform", dest="platforms", @@ -541,12 +541,11 @@ platforms = partial( "platform of the running system. Use this option multiple times to " "specify multiple platforms supported by the target interpreter." ), -) # type: Callable[..., Option] +) # This was made a separate function for unit-testing purposes. -def _convert_python_version(value): - # type: (str) -> Tuple[Tuple[int, ...], Optional[str]] +def _convert_python_version(value: str) -> Tuple[Tuple[int, ...], Optional[str]]: """ Convert a version string like "3", "37", or "3.7.3" into a tuple of ints. @@ -575,8 +574,9 @@ def _convert_python_version(value): return (version_info, None) -def _handle_python_version(option, opt_str, value, parser): - # type: (Option, str, str, OptionParser) -> None +def _handle_python_version( + option: Option, opt_str: str, value: str, parser: OptionParser +) -> None: """ Handle a provided --python-version value. """ @@ -591,7 +591,7 @@ def _handle_python_version(option, opt_str, value, parser): parser.values.python_version = version_info -python_version = partial( +python_version: Callable[..., Option] = partial( Option, "--python-version", dest="python_version", @@ -609,10 +609,10 @@ python_version = partial( version can also be given as a string without dots (e.g. "37" for 3.7.0). """ ), -) # type: Callable[..., Option] +) -implementation = partial( +implementation: Callable[..., Option] = partial( Option, "--implementation", dest="implementation", @@ -625,10 +625,10 @@ implementation = partial( "interpreter implementation is used. Use 'py' to force " "implementation-agnostic wheels." ), -) # type: Callable[..., Option] +) -abis = partial( +abis: Callable[..., Option] = partial( Option, "--abi", dest="abis", @@ -643,19 +643,17 @@ abis = partial( "--implementation, --platform, and --python-version when using this " "option." ), -) # type: Callable[..., Option] +) -def add_target_python_options(cmd_opts): - # type: (OptionGroup) -> None +def add_target_python_options(cmd_opts: OptionGroup) -> None: cmd_opts.add_option(platforms()) cmd_opts.add_option(python_version()) cmd_opts.add_option(implementation()) cmd_opts.add_option(abis()) -def make_target_python(options): - # type: (Values) -> TargetPython +def make_target_python(options: Values) -> TargetPython: target_python = TargetPython( platforms=options.platforms, py_version_info=options.python_version, @@ -666,8 +664,7 @@ def make_target_python(options): return target_python -def prefer_binary(): - # type: () -> Option +def prefer_binary() -> Option: return Option( "--prefer-binary", dest="prefer_binary", @@ -677,7 +674,7 @@ def prefer_binary(): ) -cache_dir = partial( +cache_dir: Callable[..., Option] = partial( PipOption, "--cache-dir", dest="cache_dir", @@ -685,11 +682,12 @@ cache_dir = partial( metavar="dir", type="path", help="Store the cache data in <dir>.", -) # type: Callable[..., Option] +) -def _handle_no_cache_dir(option, opt, value, parser): - # type: (Option, str, str, OptionParser) -> None +def _handle_no_cache_dir( + option: Option, opt: str, value: str, parser: OptionParser +) -> None: """ Process a value provided for the --no-cache-dir option. @@ -716,16 +714,16 @@ def _handle_no_cache_dir(option, opt, value, parser): parser.values.cache_dir = False -no_cache = partial( +no_cache: Callable[..., Option] = partial( Option, "--no-cache-dir", dest="cache_dir", action="callback", callback=_handle_no_cache_dir, help="Disable the cache.", -) # type: Callable[..., Option] +) -no_deps = partial( +no_deps: Callable[..., Option] = partial( Option, "--no-deps", "--no-dependencies", @@ -733,29 +731,17 @@ no_deps = partial( action="store_true", default=False, help="Don't install package dependencies.", -) # type: Callable[..., Option] - -build_dir = partial( - PipOption, - "-b", - "--build", - "--build-dir", - "--build-directory", - dest="build_dir", - type="path", - metavar="dir", - help=SUPPRESS_HELP, -) # type: Callable[..., Option] +) -ignore_requires_python = partial( +ignore_requires_python: Callable[..., Option] = partial( Option, "--ignore-requires-python", dest="ignore_requires_python", action="store_true", help="Ignore the Requires-Python information.", -) # type: Callable[..., Option] +) -no_build_isolation = partial( +no_build_isolation: Callable[..., Option] = partial( Option, "--no-build-isolation", dest="build_isolation", @@ -764,11 +750,21 @@ no_build_isolation = partial( help="Disable isolation when building a modern source distribution. " "Build dependencies specified by PEP 518 must be already installed " "if this option is used.", -) # type: Callable[..., Option] +) + +check_build_deps: Callable[..., Option] = partial( + Option, + "--check-build-dependencies", + dest="check_build_deps", + action="store_true", + default=False, + help="Check the build dependencies when PEP517 is used.", +) -def _handle_no_use_pep517(option, opt, value, parser): - # type: (Option, str, str, OptionParser) -> None +def _handle_no_use_pep517( + option: Option, opt: str, value: str, parser: OptionParser +) -> None: """ Process a value provided for the --no-use-pep517 option. @@ -787,11 +783,21 @@ def _handle_no_use_pep517(option, opt, value, parser): """ raise_option_error(parser, option=option, msg=msg) + # If user doesn't wish to use pep517, we check if setuptools and wheel are installed + # and raise error if it is not. + packages = ("setuptools", "wheel") + if not all(importlib.util.find_spec(package) for package in packages): + msg = ( + f"It is not possible to use --no-use-pep517 " + f"without {' and '.join(packages)} installed." + ) + raise_option_error(parser, option=option, msg=msg) + # Otherwise, --no-use-pep517 was passed via the command-line. parser.values.use_pep517 = False -use_pep517 = partial( +use_pep517: Any = partial( Option, "--use-pep517", dest="use_pep517", @@ -799,9 +805,9 @@ use_pep517 = partial( default=None, help="Use PEP 517 for building source distributions " "(use --no-use-pep517 to force legacy behaviour).", -) # type: Any +) -no_use_pep517 = partial( +no_use_pep517: Any = partial( Option, "--no-use-pep517", dest="use_pep517", @@ -809,31 +815,52 @@ no_use_pep517 = partial( callback=_handle_no_use_pep517, default=None, help=SUPPRESS_HELP, -) # type: Any - -install_options = partial( +) + + +def _handle_config_settings( + option: Option, opt_str: str, value: str, parser: OptionParser +) -> None: + key, sep, val = value.partition("=") + if sep != "=": + parser.error(f"Arguments to {opt_str} must be of the form KEY=VAL") # noqa + dest = getattr(parser.values, option.dest) + if dest is None: + dest = {} + setattr(parser.values, option.dest, dest) + if key in dest: + if isinstance(dest[key], list): + dest[key].append(val) + else: + dest[key] = [dest[key], val] + else: + dest[key] = val + + +config_settings: Callable[..., Option] = partial( Option, - "--install-option", - dest="install_options", - action="append", - metavar="options", - help="Extra arguments to be supplied to the setup.py install " - 'command (use like --install-option="--install-scripts=/usr/local/' - 'bin"). Use multiple --install-option options to pass multiple ' - "options to setup.py install. If you are using an option with a " - "directory path, be sure to use absolute path.", -) # type: Callable[..., Option] - -build_options = partial( + "-C", + "--config-settings", + dest="config_settings", + type=str, + action="callback", + callback=_handle_config_settings, + metavar="settings", + help="Configuration settings to be passed to the PEP 517 build backend. " + "Settings take the form KEY=VALUE. Use multiple --config-settings options " + "to pass multiple keys to the backend.", +) + +build_options: Callable[..., Option] = partial( Option, "--build-option", dest="build_options", metavar="options", action="append", help="Extra arguments to be supplied to 'setup.py bdist_wheel'.", -) # type: Callable[..., Option] +) -global_options = partial( +global_options: Callable[..., Option] = partial( Option, "--global-option", dest="global_options", @@ -841,26 +868,26 @@ global_options = partial( metavar="options", help="Extra global options to be supplied to the setup.py " "call before the install or bdist_wheel command.", -) # type: Callable[..., Option] +) -no_clean = partial( +no_clean: Callable[..., Option] = partial( Option, "--no-clean", action="store_true", default=False, help="Don't clean up build directories.", -) # type: Callable[..., Option] +) -pre = partial( +pre: Callable[..., Option] = partial( Option, "--pre", action="store_true", default=False, help="Include pre-release and development versions. By default, " "pip only finds stable versions.", -) # type: Callable[..., Option] +) -disable_pip_version_check = partial( +disable_pip_version_check: Callable[..., Option] = partial( Option, "--disable-pip-version-check", dest="disable_pip_version_check", @@ -868,11 +895,21 @@ disable_pip_version_check = partial( default=False, help="Don't periodically check PyPI to determine whether a new version " "of pip is available for download. Implied with --no-index.", -) # type: Callable[..., Option] +) + +root_user_action: Callable[..., Option] = partial( + Option, + "--root-user-action", + dest="root_user_action", + default="warn", + choices=["warn", "ignore"], + help="Action if pip is run as a root user. By default, a warning message is shown.", +) -def _handle_merge_hash(option, opt_str, value, parser): - # type: (Option, str, str, OptionParser) -> None +def _handle_merge_hash( + option: Option, opt_str: str, value: str, parser: OptionParser +) -> None: """Given a value spelled "algo:digest", append the digest to a list pointed to in a dict by the algo name.""" if not parser.values.hashes: @@ -894,7 +931,7 @@ def _handle_merge_hash(option, opt_str, value, parser): parser.values.hashes.setdefault(algo, []).append(digest) -hash = partial( +hash: Callable[..., Option] = partial( Option, "--hash", # Hash values eventually end up in InstallRequirement.hashes due to @@ -905,10 +942,10 @@ hash = partial( type="string", help="Verify that the package's archive matches this " "hash before installing. Example: --hash=sha256:abcdef...", -) # type: Callable[..., Option] +) -require_hashes = partial( +require_hashes: Callable[..., Option] = partial( Option, "--require-hashes", dest="require_hashes", @@ -917,10 +954,10 @@ require_hashes = partial( help="Require a hash to check each requirement against, for " "repeatable installs. This option is implied when any package in a " "requirements file has a --hash option.", -) # type: Callable[..., Option] +) -list_path = partial( +list_path: Callable[..., Option] = partial( PipOption, "--path", dest="path", @@ -928,16 +965,15 @@ list_path = partial( action="append", help="Restrict to the specified installation path for listing " "packages (can be used multiple times).", -) # type: Callable[..., Option] +) -def check_list_path_option(options): - # type: (Values) -> None +def check_list_path_option(options: Values) -> None: if options.path and (options.user or options.local): raise CommandError("Cannot combine '--path' with '--user' or '--local'") -list_exclude = partial( +list_exclude: Callable[..., Option] = partial( PipOption, "--exclude", dest="excludes", @@ -945,57 +981,71 @@ list_exclude = partial( metavar="package", type="package_name", help="Exclude specified package from the output", -) # type: Callable[..., Option] +) -no_python_version_warning = partial( +no_python_version_warning: Callable[..., Option] = partial( Option, "--no-python-version-warning", dest="no_python_version_warning", action="store_true", default=False, help="Silence deprecation warnings for upcoming unsupported Pythons.", -) # type: Callable[..., Option] +) -use_new_feature = partial( +# Features that are now always on. A warning is printed if they are used. +ALWAYS_ENABLED_FEATURES = [ + "no-binary-enable-wheel-cache", # always on since 23.1 +] + +use_new_feature: Callable[..., Option] = partial( Option, "--use-feature", dest="features_enabled", metavar="feature", action="append", default=[], - choices=["2020-resolver", "fast-deps", "in-tree-build"], + choices=[ + "fast-deps", + "truststore", + ] + + ALWAYS_ENABLED_FEATURES, help="Enable new functionality, that may be backward incompatible.", -) # type: Callable[..., Option] +) -use_deprecated_feature = partial( +use_deprecated_feature: Callable[..., Option] = partial( Option, "--use-deprecated", dest="deprecated_features_enabled", metavar="feature", action="append", default=[], - choices=["legacy-resolver"], + choices=[ + "legacy-resolver", + ], help=("Enable deprecated functionality, that will be removed in the future."), -) # type: Callable[..., Option] +) ########## # groups # ########## -general_group = { +general_group: Dict[str, Any] = { "name": "General Options", "options": [ help_, + debug_mode, isolated_mode, require_virtualenv, + python, verbose, version, quiet, log, no_input, + keyring_provider, proxy, retries, timeout, @@ -1011,9 +1061,9 @@ general_group = { use_new_feature, use_deprecated_feature, ], -} # type: Dict[str, Any] +} -index_group = { +index_group: Dict[str, Any] = { "name": "Package Index Options", "options": [ index_url, @@ -1021,4 +1071,4 @@ index_group = { no_index, find_links, ], -} # type: Dict[str, Any] +} diff --git a/env/Lib/site-packages/pip/_internal/cli/command_context.py b/env/Lib/site-packages/pip/_internal/cli/command_context.py index 375a2e36..139995ac 100644 --- a/env/Lib/site-packages/pip/_internal/cli/command_context.py +++ b/env/Lib/site-packages/pip/_internal/cli/command_context.py @@ -1,19 +1,17 @@ from contextlib import ExitStack, contextmanager -from typing import ContextManager, Iterator, TypeVar +from typing import ContextManager, Generator, TypeVar _T = TypeVar("_T", covariant=True) class CommandContextMixIn: - def __init__(self): - # type: () -> None + def __init__(self) -> None: super().__init__() self._in_main_context = False self._main_context = ExitStack() @contextmanager - def main_context(self): - # type: () -> Iterator[None] + def main_context(self) -> Generator[None, None, None]: assert not self._in_main_context self._in_main_context = True @@ -23,8 +21,7 @@ class CommandContextMixIn: finally: self._in_main_context = False - def enter_context(self, context_provider): - # type: (ContextManager[_T]) -> _T + def enter_context(self, context_provider: ContextManager[_T]) -> _T: assert self._in_main_context return self._main_context.enter_context(context_provider) diff --git a/env/Lib/site-packages/pip/_internal/cli/main.py b/env/Lib/site-packages/pip/_internal/cli/main.py index 7ae074b5..7e061f5b 100644 --- a/env/Lib/site-packages/pip/_internal/cli/main.py +++ b/env/Lib/site-packages/pip/_internal/cli/main.py @@ -4,6 +4,7 @@ import locale import logging import os import sys +import warnings from typing import List, Optional from pip._internal.cli.autocompletion import autocomplete @@ -42,11 +43,18 @@ logger = logging.getLogger(__name__) # main, this should not be an issue in practice. -def main(args=None): - # type: (Optional[List[str]]) -> int +def main(args: Optional[List[str]] = None) -> int: if args is None: args = sys.argv[1:] + # Suppress the pkg_resources deprecation warning + # Note - we use a module of .*pkg_resources to cover + # the normal case (pip._vendor.pkg_resources) and the + # devendored case (a bare pkg_resources) + warnings.filterwarnings( + action="ignore", category=DeprecationWarning, module=".*pkg_resources" + ) + # Configure our deprecation warnings to be sent through loggers deprecation.install_warning_logger() diff --git a/env/Lib/site-packages/pip/_internal/cli/main_parser.py b/env/Lib/site-packages/pip/_internal/cli/main_parser.py index d0f58fe4..5ade356b 100644 --- a/env/Lib/site-packages/pip/_internal/cli/main_parser.py +++ b/env/Lib/site-packages/pip/_internal/cli/main_parser.py @@ -2,9 +2,11 @@ """ import os +import subprocess import sys -from typing import List, Tuple +from typing import List, Optional, Tuple +from pip._internal.build_env import get_runnable_pip from pip._internal.cli import cmdoptions from pip._internal.cli.parser import ConfigOptionParser, UpdatingDefaultsHelpFormatter from pip._internal.commands import commands_dict, get_similar_commands @@ -14,8 +16,7 @@ from pip._internal.utils.misc import get_pip_version, get_prog __all__ = ["create_main_parser", "parse_command"] -def create_main_parser(): - # type: () -> ConfigOptionParser +def create_main_parser() -> ConfigOptionParser: """Creates and returns the main parser for pip's CLI""" parser = ConfigOptionParser( @@ -46,8 +47,26 @@ def create_main_parser(): return parser -def parse_command(args): - # type: (List[str]) -> Tuple[str, List[str]] +def identify_python_interpreter(python: str) -> Optional[str]: + # If the named file exists, use it. + # If it's a directory, assume it's a virtual environment and + # look for the environment's Python executable. + if os.path.exists(python): + if os.path.isdir(python): + # bin/python for Unix, Scripts/python.exe for Windows + # Try both in case of odd cases like cygwin. + for exe in ("bin/python", "Scripts/python.exe"): + py = os.path.join(python, exe) + if os.path.exists(py): + return py + else: + return python + + # Could not find the interpreter specified + return None + + +def parse_command(args: List[str]) -> Tuple[str, List[str]]: parser = create_main_parser() # Note: parser calls disable_interspersed_args(), so the result of this @@ -59,6 +78,32 @@ def parse_command(args): # args_else: ['install', '--user', 'INITools'] general_options, args_else = parser.parse_args(args) + # --python + if general_options.python and "_PIP_RUNNING_IN_SUBPROCESS" not in os.environ: + # Re-invoke pip using the specified Python interpreter + interpreter = identify_python_interpreter(general_options.python) + if interpreter is None: + raise CommandError( + f"Could not locate Python interpreter {general_options.python}" + ) + + pip_cmd = [ + interpreter, + get_runnable_pip(), + ] + pip_cmd.extend(args) + + # Set a flag so the child doesn't re-invoke itself, causing + # an infinite loop. + os.environ["_PIP_RUNNING_IN_SUBPROCESS"] = "1" + returncode = 0 + try: + proc = subprocess.run(pip_cmd) + returncode = proc.returncode + except (subprocess.SubprocessError, OSError) as exc: + raise CommandError(f"Failed to run pip under {interpreter}: {exc}") + sys.exit(returncode) + # --version if general_options.version: sys.stdout.write(parser.version) diff --git a/env/Lib/site-packages/pip/_internal/cli/parser.py b/env/Lib/site-packages/pip/_internal/cli/parser.py index 16523c5a..c762cf27 100644 --- a/env/Lib/site-packages/pip/_internal/cli/parser.py +++ b/env/Lib/site-packages/pip/_internal/cli/parser.py @@ -6,7 +6,7 @@ import shutil import sys import textwrap from contextlib import suppress -from typing import Any, Dict, Iterator, List, Tuple +from typing import Any, Dict, Generator, List, Tuple from pip._internal.cli.status_codes import UNKNOWN_ERROR from pip._internal.configuration import Configuration, ConfigurationError @@ -18,20 +18,19 @@ logger = logging.getLogger(__name__) class PrettyHelpFormatter(optparse.IndentedHelpFormatter): """A prettier/less verbose help formatter for optparse.""" - def __init__(self, *args, **kwargs): - # type: (*Any, **Any) -> None + def __init__(self, *args: Any, **kwargs: Any) -> None: # help position must be aligned with __init__.parseopts.description kwargs["max_help_position"] = 30 kwargs["indent_increment"] = 1 kwargs["width"] = shutil.get_terminal_size()[0] - 2 super().__init__(*args, **kwargs) - def format_option_strings(self, option): - # type: (optparse.Option) -> str + def format_option_strings(self, option: optparse.Option) -> str: return self._format_option_strings(option) - def _format_option_strings(self, option, mvarfmt=" <{}>", optsep=", "): - # type: (optparse.Option, str, str) -> str + def _format_option_strings( + self, option: optparse.Option, mvarfmt: str = " <{}>", optsep: str = ", " + ) -> str: """ Return a comma-separated list of option strings and metavars. @@ -55,14 +54,12 @@ class PrettyHelpFormatter(optparse.IndentedHelpFormatter): return "".join(opts) - def format_heading(self, heading): - # type: (str) -> str + def format_heading(self, heading: str) -> str: if heading == "Options": return "" return heading + ":\n" - def format_usage(self, usage): - # type: (str) -> str + def format_usage(self, usage: str) -> str: """ Ensure there is only one newline between usage and the first heading if there is no description. @@ -70,8 +67,7 @@ class PrettyHelpFormatter(optparse.IndentedHelpFormatter): msg = "\nUsage: {}\n".format(self.indent_lines(textwrap.dedent(usage), " ")) return msg - def format_description(self, description): - # type: (str) -> str + def format_description(self, description: str) -> str: # leave full control over description to us if description: if hasattr(self.parser, "main"): @@ -89,16 +85,14 @@ class PrettyHelpFormatter(optparse.IndentedHelpFormatter): else: return "" - def format_epilog(self, epilog): - # type: (str) -> str + def format_epilog(self, epilog: str) -> str: # leave full control over epilog to us if epilog: return epilog else: return "" - def indent_lines(self, text, indent): - # type: (str, str) -> str + def indent_lines(self, text: str, indent: str) -> str: new_lines = [indent + line for line in text.split("\n")] return "\n".join(new_lines) @@ -112,8 +106,7 @@ class UpdatingDefaultsHelpFormatter(PrettyHelpFormatter): Also redact auth from url type options """ - def expand_default(self, option): - # type: (optparse.Option) -> str + def expand_default(self, option: optparse.Option) -> str: default_values = None if self.parser is not None: assert isinstance(self.parser, ConfigOptionParser) @@ -137,8 +130,9 @@ class UpdatingDefaultsHelpFormatter(PrettyHelpFormatter): class CustomOptionParser(optparse.OptionParser): - def insert_option_group(self, idx, *args, **kwargs): - # type: (int, Any, Any) -> optparse.OptionGroup + def insert_option_group( + self, idx: int, *args: Any, **kwargs: Any + ) -> optparse.OptionGroup: """Insert an OptionGroup at a given position.""" group = self.add_option_group(*args, **kwargs) @@ -148,8 +142,7 @@ class CustomOptionParser(optparse.OptionParser): return group @property - def option_list_all(self): - # type: () -> List[optparse.Option] + def option_list_all(self) -> List[optparse.Option]: """Get a list of all options, including those in option groups.""" res = self.option_list[:] for i in self.option_groups: @@ -164,35 +157,34 @@ class ConfigOptionParser(CustomOptionParser): def __init__( self, - *args, # type: Any - name, # type: str - isolated=False, # type: bool - **kwargs, # type: Any - ): - # type: (...) -> None + *args: Any, + name: str, + isolated: bool = False, + **kwargs: Any, + ) -> None: self.name = name self.config = Configuration(isolated) assert self.name super().__init__(*args, **kwargs) - def check_default(self, option, key, val): - # type: (optparse.Option, str, Any) -> Any + def check_default(self, option: optparse.Option, key: str, val: Any) -> Any: try: return option.check_value(key, val) except optparse.OptionValueError as exc: print(f"An error occurred during configuration: {exc}") sys.exit(3) - def _get_ordered_configuration_items(self): - # type: () -> Iterator[Tuple[str, Any]] + def _get_ordered_configuration_items( + self, + ) -> Generator[Tuple[str, Any], None, None]: # Configuration gives keys in an unordered manner. Order them. override_order = ["global", self.name, ":env:"] # Pool the options into different groups - section_items = { + section_items: Dict[str, List[Tuple[str, Any]]] = { name: [] for name in override_order - } # type: Dict[str, List[Tuple[str, Any]]] + } for section_key, val in self.config.items(): # ignore empty values if not val: @@ -211,8 +203,7 @@ class ConfigOptionParser(CustomOptionParser): for key, val in section_items[section]: yield key, val - def _update_defaults(self, defaults): - # type: (Dict[str, Any]) -> Dict[str, Any] + def _update_defaults(self, defaults: Dict[str, Any]) -> Dict[str, Any]: """Updates the given defaults with values from the config files and the environ. Does a little special handling for certain types of options (lists).""" @@ -276,8 +267,7 @@ class ConfigOptionParser(CustomOptionParser): self.values = None return defaults - def get_default_values(self): - # type: () -> optparse.Values + def get_default_values(self) -> optparse.Values: """Overriding to make updating the defaults after instantiation of the option parser possible, _update_defaults() does the dirty work.""" if not self.process_default_values: @@ -299,7 +289,6 @@ class ConfigOptionParser(CustomOptionParser): defaults[option.dest] = option.check_value(opt_str, default) return optparse.Values(defaults) - def error(self, msg): - # type: (str) -> None + def error(self, msg: str) -> None: self.print_usage(sys.stderr) self.exit(UNKNOWN_ERROR, f"{msg}\n") diff --git a/env/Lib/site-packages/pip/_internal/cli/progress_bars.py b/env/Lib/site-packages/pip/_internal/cli/progress_bars.py index 3064c856..0ad14031 100644 --- a/env/Lib/site-packages/pip/_internal/cli/progress_bars.py +++ b/env/Lib/site-packages/pip/_internal/cli/progress_bars.py @@ -1,261 +1,68 @@ -import itertools -import sys -from signal import SIGINT, default_int_handler, signal -from typing import Any, Dict, List +import functools +from typing import Callable, Generator, Iterable, Iterator, Optional, Tuple + +from pip._vendor.rich.progress import ( + BarColumn, + DownloadColumn, + FileSizeColumn, + Progress, + ProgressColumn, + SpinnerColumn, + TextColumn, + TimeElapsedColumn, + TimeRemainingColumn, + TransferSpeedColumn, +) -from pip._vendor.progress.bar import Bar, FillingCirclesBar, IncrementalBar -from pip._vendor.progress.spinner import Spinner - -from pip._internal.utils.compat import WINDOWS from pip._internal.utils.logging import get_indentation -from pip._internal.utils.misc import format_size - -try: - from pip._vendor import colorama -# Lots of different errors can come from this, including SystemError and -# ImportError. -except Exception: - colorama = None - - -def _select_progress_class(preferred, fallback): - # type: (Bar, Bar) -> Bar - encoding = getattr(preferred.file, "encoding", None) - # If we don't know what encoding this file is in, then we'll just assume - # that it doesn't support unicode and use the ASCII bar. - if not encoding: - return fallback - - # Collect all of the possible characters we want to use with the preferred - # bar. - characters = [ - getattr(preferred, "empty_fill", ""), - getattr(preferred, "fill", ""), - ] - characters += list(getattr(preferred, "phases", [])) - - # Try to decode the characters we're using for the bar using the encoding - # of the given file, if this works then we'll assume that we can use the - # fancier bar and if not we'll fall back to the plaintext bar. - try: - "".join(characters).encode(encoding) - except UnicodeEncodeError: - return fallback +DownloadProgressRenderer = Callable[[Iterable[bytes]], Iterator[bytes]] + + +def _rich_progress_bar( + iterable: Iterable[bytes], + *, + bar_type: str, + size: int, +) -> Generator[bytes, None, None]: + assert bar_type == "on", "This should only be used in the default mode." + + if not size: + total = float("inf") + columns: Tuple[ProgressColumn, ...] = ( + TextColumn("[progress.description]{task.description}"), + SpinnerColumn("line", speed=1.5), + FileSizeColumn(), + TransferSpeedColumn(), + TimeElapsedColumn(), + ) else: - return preferred - - -_BaseBar = _select_progress_class(IncrementalBar, Bar) # type: Any - - -class InterruptibleMixin: - """ - Helper to ensure that self.finish() gets called on keyboard interrupt. - - This allows downloads to be interrupted without leaving temporary state - (like hidden cursors) behind. - - This class is similar to the progress library's existing SigIntMixin - helper, but as of version 1.2, that helper has the following problems: - - 1. It calls sys.exit(). - 2. It discards the existing SIGINT handler completely. - 3. It leaves its own handler in place even after an uninterrupted finish, - which will have unexpected delayed effects if the user triggers an - unrelated keyboard interrupt some time after a progress-displaying - download has already completed, for example. - """ - - def __init__(self, *args, **kwargs): - # type: (List[Any], Dict[Any, Any]) -> None - """ - Save the original SIGINT handler for later. - """ - # https://github.com/python/mypy/issues/5887 - super().__init__(*args, **kwargs) # type: ignore - - self.original_handler = signal(SIGINT, self.handle_sigint) - - # If signal() returns None, the previous handler was not installed from - # Python, and we cannot restore it. This probably should not happen, - # but if it does, we must restore something sensible instead, at least. - # The least bad option should be Python's default SIGINT handler, which - # just raises KeyboardInterrupt. - if self.original_handler is None: - self.original_handler = default_int_handler - - def finish(self): - # type: () -> None - """ - Restore the original SIGINT handler after finishing. - - This should happen regardless of whether the progress display finishes - normally, or gets interrupted. - """ - super().finish() # type: ignore - signal(SIGINT, self.original_handler) - - def handle_sigint(self, signum, frame): # type: ignore - """ - Call self.finish() before delegating to the original SIGINT handler. - - This handler should only be in place while the progress display is - active. - """ - self.finish() - self.original_handler(signum, frame) - - -class SilentBar(Bar): - def update(self): - # type: () -> None - pass - - -class BlueEmojiBar(IncrementalBar): - - suffix = "%(percent)d%%" - bar_prefix = " " - bar_suffix = " " - phases = ("\U0001F539", "\U0001F537", "\U0001F535") - - -class DownloadProgressMixin: - def __init__(self, *args, **kwargs): - # type: (List[Any], Dict[Any, Any]) -> None - # https://github.com/python/mypy/issues/5887 - super().__init__(*args, **kwargs) # type: ignore - self.message = (" " * (get_indentation() + 2)) + self.message # type: str - - @property - def downloaded(self): - # type: () -> str - return format_size(self.index) # type: ignore - - @property - def download_speed(self): - # type: () -> str - # Avoid zero division errors... - if self.avg == 0.0: # type: ignore - return "..." - return format_size(1 / self.avg) + "/s" # type: ignore - - @property - def pretty_eta(self): - # type: () -> str - if self.eta: # type: ignore - return f"eta {self.eta_td}" # type: ignore - return "" - - def iter(self, it): # type: ignore - for x in it: - yield x - # B305 is incorrectly raised here - # https://github.com/PyCQA/flake8-bugbear/issues/59 - self.next(len(x)) # noqa: B305 - self.finish() - - -class WindowsMixin: - def __init__(self, *args, **kwargs): - # type: (List[Any], Dict[Any, Any]) -> None - # The Windows terminal does not support the hide/show cursor ANSI codes - # even with colorama. So we'll ensure that hide_cursor is False on - # Windows. - # This call needs to go before the super() call, so that hide_cursor - # is set in time. The base progress bar class writes the "hide cursor" - # code to the terminal in its init, so if we don't set this soon - # enough, we get a "hide" with no corresponding "show"... - if WINDOWS and self.hide_cursor: # type: ignore - self.hide_cursor = False - - # https://github.com/python/mypy/issues/5887 - super().__init__(*args, **kwargs) # type: ignore - - # Check if we are running on Windows and we have the colorama module, - # if we do then wrap our file with it. - if WINDOWS and colorama: - self.file = colorama.AnsiToWin32(self.file) # type: ignore - # The progress code expects to be able to call self.file.isatty() - # but the colorama.AnsiToWin32() object doesn't have that, so we'll - # add it. - self.file.isatty = lambda: self.file.wrapped.isatty() - # The progress code expects to be able to call self.file.flush() - # but the colorama.AnsiToWin32() object doesn't have that, so we'll - # add it. - self.file.flush = lambda: self.file.wrapped.flush() - - -class BaseDownloadProgressBar(WindowsMixin, InterruptibleMixin, DownloadProgressMixin): - - file = sys.stdout - message = "%(percent)d%%" - suffix = "%(downloaded)s %(download_speed)s %(pretty_eta)s" - - -class DefaultDownloadProgressBar(BaseDownloadProgressBar, _BaseBar): - pass - - -class DownloadSilentBar(BaseDownloadProgressBar, SilentBar): - pass - - -class DownloadBar(BaseDownloadProgressBar, Bar): - pass - - -class DownloadFillingCirclesBar(BaseDownloadProgressBar, FillingCirclesBar): - pass - - -class DownloadBlueEmojiProgressBar(BaseDownloadProgressBar, BlueEmojiBar): - pass - - -class DownloadProgressSpinner( - WindowsMixin, InterruptibleMixin, DownloadProgressMixin, Spinner -): - - file = sys.stdout - suffix = "%(downloaded)s %(download_speed)s" - - def next_phase(self): - # type: () -> str - if not hasattr(self, "_phaser"): - self._phaser = itertools.cycle(self.phases) - return next(self._phaser) - - def update(self): - # type: () -> None - message = self.message % self - phase = self.next_phase() - suffix = self.suffix % self - line = "".join( - [ - message, - " " if message else "", - phase, - " " if suffix else "", - suffix, - ] + total = size + columns = ( + TextColumn("[progress.description]{task.description}"), + BarColumn(), + DownloadColumn(), + TransferSpeedColumn(), + TextColumn("eta"), + TimeRemainingColumn(), ) - self.writeln(line) - + progress = Progress(*columns, refresh_per_second=30) + task_id = progress.add_task(" " * (get_indentation() + 2), total=total) + with progress: + for chunk in iterable: + yield chunk + progress.update(task_id, advance=len(chunk)) -BAR_TYPES = { - "off": (DownloadSilentBar, DownloadSilentBar), - "on": (DefaultDownloadProgressBar, DownloadProgressSpinner), - "ascii": (DownloadBar, DownloadProgressSpinner), - "pretty": (DownloadFillingCirclesBar, DownloadProgressSpinner), - "emoji": (DownloadBlueEmojiProgressBar, DownloadProgressSpinner), -} +def get_download_progress_renderer( + *, bar_type: str, size: Optional[int] = None +) -> DownloadProgressRenderer: + """Get an object that can be used to render the download progress. -def DownloadProgressProvider(progress_bar, max=None): # type: ignore - if max is None or max == 0: - return BAR_TYPES[progress_bar][1]().iter + Returns a callable, that takes an iterable to "wrap". + """ + if bar_type == "on": + return functools.partial(_rich_progress_bar, bar_type=bar_type, size=size) else: - return BAR_TYPES[progress_bar][0](max=max).iter + return iter # no-op, when passed an iterator diff --git a/env/Lib/site-packages/pip/_internal/cli/req_command.py b/env/Lib/site-packages/pip/_internal/cli/req_command.py index 7ed62388..86070f10 100644 --- a/env/Lib/site-packages/pip/_internal/cli/req_command.py +++ b/env/Lib/site-packages/pip/_internal/cli/req_command.py @@ -10,7 +10,7 @@ import os import sys from functools import partial from optparse import Values -from typing import Any, List, Optional, Tuple +from typing import TYPE_CHECKING, Any, List, Optional, Tuple from pip._internal.cache import WheelCache from pip._internal.cli import cmdoptions @@ -22,6 +22,7 @@ from pip._internal.index.package_finder import PackageFinder from pip._internal.models.selection_prefs import SelectionPreferences from pip._internal.models.target_python import TargetPython from pip._internal.network.session import PipSession +from pip._internal.operations.build.build_tracker import BuildTracker from pip._internal.operations.prepare import RequirementPreparer from pip._internal.req.constructors import ( install_req_from_editable, @@ -31,7 +32,6 @@ from pip._internal.req.constructors import ( ) from pip._internal.req.req_file import parse_requirements from pip._internal.req.req_install import InstallRequirement -from pip._internal.req.req_tracker import RequirementTracker from pip._internal.resolution.base import BaseResolver from pip._internal.self_outdated_check import pip_self_version_check from pip._internal.utils.temp_dir import ( @@ -41,23 +41,45 @@ from pip._internal.utils.temp_dir import ( ) from pip._internal.utils.virtualenv import running_under_virtualenv +if TYPE_CHECKING: + from ssl import SSLContext + logger = logging.getLogger(__name__) +def _create_truststore_ssl_context() -> Optional["SSLContext"]: + if sys.version_info < (3, 10): + raise CommandError("The truststore feature is only available for Python 3.10+") + + try: + import ssl + except ImportError: + logger.warning("Disabling truststore since ssl support is missing") + return None + + try: + import truststore + except ImportError: + raise CommandError( + "To use the truststore feature, 'truststore' must be installed into " + "pip's current environment." + ) + + return truststore.SSLContext(ssl.PROTOCOL_TLS_CLIENT) + + class SessionCommandMixin(CommandContextMixIn): """ A class mixin for command classes needing _build_session(). """ - def __init__(self): - # type: () -> None + def __init__(self) -> None: super().__init__() - self._session = None # Optional[PipSession] + self._session: Optional[PipSession] = None @classmethod - def _get_index_urls(cls, options): - # type: (Values) -> Optional[List[str]] + def _get_index_urls(cls, options: Values) -> Optional[List[str]]: """Return a list of index urls from user-provided options.""" index_urls = [] if not getattr(options, "no_index", False): @@ -70,8 +92,7 @@ class SessionCommandMixin(CommandContextMixIn): # Return None rather than an empty list return index_urls or None - def get_default_session(self, options): - # type: (Values) -> PipSession + def get_default_session(self, options: Values) -> PipSession: """Get a default-managed session.""" if self._session is None: self._session = self.enter_context(self._build_session(options)) @@ -81,16 +102,32 @@ class SessionCommandMixin(CommandContextMixIn): assert self._session is not None return self._session - def _build_session(self, options, retries=None, timeout=None): - # type: (Values, Optional[int], Optional[int]) -> PipSession - assert not options.cache_dir or os.path.isabs(options.cache_dir) + def _build_session( + self, + options: Values, + retries: Optional[int] = None, + timeout: Optional[int] = None, + fallback_to_certifi: bool = False, + ) -> PipSession: + cache_dir = options.cache_dir + assert not cache_dir or os.path.isabs(cache_dir) + + if "truststore" in options.features_enabled: + try: + ssl_context = _create_truststore_ssl_context() + except Exception: + if not fallback_to_certifi: + raise + ssl_context = None + else: + ssl_context = None + session = PipSession( - cache=( - os.path.join(options.cache_dir, "http") if options.cache_dir else None - ), + cache=os.path.join(cache_dir, "http") if cache_dir else None, retries=retries if retries is not None else options.retries, trusted_hosts=options.trusted_hosts, index_urls=self._get_index_urls(options), + ssl_context=ssl_context, ) # Handle custom ca-bundles from the user @@ -114,6 +151,7 @@ class SessionCommandMixin(CommandContextMixIn): # Determine if we can prompt the user for authentication or not session.auth.prompting = not options.no_input + session.auth.keyring_provider = options.keyring_provider return session @@ -126,8 +164,7 @@ class IndexGroupCommand(Command, SessionCommandMixin): This also corresponds to the commands that permit the pip version check. """ - def handle_pip_version_check(self, options): - # type: (Values) -> None + def handle_pip_version_check(self, options: Values) -> None: """ Do the pip version check if not disabled. @@ -141,7 +178,14 @@ class IndexGroupCommand(Command, SessionCommandMixin): # Otherwise, check if we're using the latest version of pip available. session = self._build_session( - options, retries=0, timeout=min(5, options.timeout) + options, + retries=0, + timeout=min(5, options.timeout), + # This is set to ensure the function does not fail when truststore is + # specified in use-feature but cannot be loaded. This usually raises a + # CommandError and shows a nice user-facing error, but this function is not + # called in that try-except block. + fallback_to_certifi=True, ) with session: pip_self_version_check(session, options) @@ -154,8 +198,7 @@ KEEPABLE_TEMPDIR_TYPES = [ ] -def warn_if_run_as_root(): - # type: () -> None +def warn_if_run_as_root() -> None: """Output a warning for sudo users on Unix. In a virtual environment, sudo pip still writes to virtualenv. @@ -173,9 +216,10 @@ def warn_if_run_as_root(): # checks: https://mypy.readthedocs.io/en/stable/common_issues.html if sys.platform == "win32" or sys.platform == "cygwin": return - if sys.platform == "darwin" or sys.platform == "linux": - if os.getuid() != 0: - return + + if os.getuid() != 0: + return + logger.warning( "Running pip as the 'root' user can result in broken permissions and " "conflicting behaviour with the system package manager. " @@ -184,19 +228,18 @@ def warn_if_run_as_root(): ) -def with_cleanup(func): - # type: (Any) -> Any +def with_cleanup(func: Any) -> Any: """Decorator for common logic related to managing temporary directories. """ - def configure_tempdir_registry(registry): - # type: (TempDirectoryTypeRegistry) -> None + def configure_tempdir_registry(registry: TempDirectoryTypeRegistry) -> None: for t in KEEPABLE_TEMPDIR_TYPES: registry.set_delete(t, False) - def wrapper(self, options, args): - # type: (RequirementCommand, Values, List[Any]) -> Optional[int] + def wrapper( + self: RequirementCommand, options: Values, args: List[Any] + ) -> Optional[int]: assert self.tempdir_registry is not None if options.no_clean: configure_tempdir_registry(self.tempdir_registry) @@ -214,15 +257,13 @@ def with_cleanup(func): class RequirementCommand(IndexGroupCommand): - def __init__(self, *args, **kw): - # type: (Any, Any) -> None + def __init__(self, *args: Any, **kw: Any) -> None: super().__init__(*args, **kw) self.cmd_opts.add_option(cmdoptions.no_clean()) @staticmethod - def determine_resolver_variant(options): - # type: (Values) -> str + def determine_resolver_variant(options: Values) -> str: """Determines which resolver should be used, based on the given options.""" if "legacy-resolver" in options.deprecated_features_enabled: return "legacy" @@ -232,20 +273,21 @@ class RequirementCommand(IndexGroupCommand): @classmethod def make_requirement_preparer( cls, - temp_build_dir, # type: TempDirectory - options, # type: Values - req_tracker, # type: RequirementTracker - session, # type: PipSession - finder, # type: PackageFinder - use_user_site, # type: bool - download_dir=None, # type: str - ): - # type: (...) -> RequirementPreparer + temp_build_dir: TempDirectory, + options: Values, + build_tracker: BuildTracker, + session: PipSession, + finder: PackageFinder, + use_user_site: bool, + download_dir: Optional[str] = None, + verbosity: int = 0, + ) -> RequirementPreparer: """ Create a RequirementPreparer instance for the given parameters. """ temp_build_dir_path = temp_build_dir.path assert temp_build_dir_path is not None + legacy_resolver = False resolver_variant = cls.determine_resolver_variant(options) if resolver_variant == "2020-resolver": @@ -259,6 +301,7 @@ class RequirementCommand(IndexGroupCommand): "production." ) else: + legacy_resolver = True lazy_wheel = False if "fast-deps" in options.features_enabled: logger.warning( @@ -270,32 +313,33 @@ class RequirementCommand(IndexGroupCommand): src_dir=options.src_dir, download_dir=download_dir, build_isolation=options.build_isolation, - req_tracker=req_tracker, + check_build_deps=options.check_build_deps, + build_tracker=build_tracker, session=session, progress_bar=options.progress_bar, finder=finder, require_hashes=options.require_hashes, use_user_site=use_user_site, lazy_wheel=lazy_wheel, - in_tree_build="in-tree-build" in options.features_enabled, + verbosity=verbosity, + legacy_resolver=legacy_resolver, ) @classmethod def make_resolver( cls, - preparer, # type: RequirementPreparer - finder, # type: PackageFinder - options, # type: Values - wheel_cache=None, # type: Optional[WheelCache] - use_user_site=False, # type: bool - ignore_installed=True, # type: bool - ignore_requires_python=False, # type: bool - force_reinstall=False, # type: bool - upgrade_strategy="to-satisfy-only", # type: str - use_pep517=None, # type: Optional[bool] - py_version_info=None, # type: Optional[Tuple[int, ...]] - ): - # type: (...) -> BaseResolver + preparer: RequirementPreparer, + finder: PackageFinder, + options: Values, + wheel_cache: Optional[WheelCache] = None, + use_user_site: bool = False, + ignore_installed: bool = True, + ignore_requires_python: bool = False, + force_reinstall: bool = False, + upgrade_strategy: str = "to-satisfy-only", + use_pep517: Optional[bool] = None, + py_version_info: Optional[Tuple[int, ...]] = None, + ) -> BaseResolver: """ Create a Resolver instance for the given parameters. """ @@ -342,16 +386,15 @@ class RequirementCommand(IndexGroupCommand): def get_requirements( self, - args, # type: List[str] - options, # type: Values - finder, # type: PackageFinder - session, # type: PipSession - ): - # type: (...) -> List[InstallRequirement] + args: List[str], + options: Values, + finder: PackageFinder, + session: PipSession, + ) -> List[InstallRequirement]: """ Parse command-line arguments into the corresponding requirements. """ - requirements = [] # type: List[InstallRequirement] + requirements: List[InstallRequirement] = [] for filename in options.constraints: for parsed_req in parse_requirements( filename, @@ -370,10 +413,11 @@ class RequirementCommand(IndexGroupCommand): for req in args: req_to_add = install_req_from_line( req, - None, + comes_from=None, isolated=options.isolated_mode, use_pep517=options.use_pep517, user_supplied=True, + config_settings=getattr(options, "config_settings", None), ) requirements.append(req_to_add) @@ -383,6 +427,7 @@ class RequirementCommand(IndexGroupCommand): user_supplied=True, isolated=options.isolated_mode, use_pep517=options.use_pep517, + config_settings=getattr(options, "config_settings", None), ) requirements.append(req_to_add) @@ -396,6 +441,9 @@ class RequirementCommand(IndexGroupCommand): isolated=options.isolated_mode, use_pep517=options.use_pep517, user_supplied=True, + config_settings=parsed_req.options.get("config_settings") + if parsed_req.options + else None, ) requirements.append(req_to_add) @@ -421,8 +469,7 @@ class RequirementCommand(IndexGroupCommand): return requirements @staticmethod - def trace_basic_info(finder): - # type: (PackageFinder) -> None + def trace_basic_info(finder: PackageFinder) -> None: """ Trace basic information about the provided objects. """ @@ -434,12 +481,11 @@ class RequirementCommand(IndexGroupCommand): def _build_package_finder( self, - options, # type: Values - session, # type: PipSession - target_python=None, # type: Optional[TargetPython] - ignore_requires_python=None, # type: Optional[bool] - ): - # type: (...) -> PackageFinder + options: Values, + session: PipSession, + target_python: Optional[TargetPython] = None, + ignore_requires_python: Optional[bool] = None, + ) -> PackageFinder: """ Create a package finder appropriate to this requirement command. diff --git a/env/Lib/site-packages/pip/_internal/cli/spinners.py b/env/Lib/site-packages/pip/_internal/cli/spinners.py index 08e15661..cf2b976f 100644 --- a/env/Lib/site-packages/pip/_internal/cli/spinners.py +++ b/env/Lib/site-packages/pip/_internal/cli/spinners.py @@ -3,9 +3,7 @@ import itertools import logging import sys import time -from typing import IO, Iterator - -from pip._vendor.progress import HIDE_CURSOR, SHOW_CURSOR +from typing import IO, Generator, Optional from pip._internal.utils.compat import WINDOWS from pip._internal.utils.logging import get_indentation @@ -14,25 +12,22 @@ logger = logging.getLogger(__name__) class SpinnerInterface: - def spin(self): - # type: () -> None + def spin(self) -> None: raise NotImplementedError() - def finish(self, final_status): - # type: (str) -> None + def finish(self, final_status: str) -> None: raise NotImplementedError() class InteractiveSpinner(SpinnerInterface): def __init__( self, - message, - file=None, - spin_chars="-\\|/", + message: str, + file: Optional[IO[str]] = None, + spin_chars: str = "-\\|/", # Empirically, 8 updates/second looks nice - min_update_interval_seconds=0.125, + min_update_interval_seconds: float = 0.125, ): - # type: (str, IO[str], str, float) -> None self._message = message if file is None: file = sys.stdout @@ -45,8 +40,7 @@ class InteractiveSpinner(SpinnerInterface): self._file.write(" " * get_indentation() + self._message + " ... ") self._width = 0 - def _write(self, status): - # type: (str) -> None + def _write(self, status: str) -> None: assert not self._finished # Erase what we wrote before by backspacing to the beginning, writing # spaces to overwrite the old text, and then backspacing again @@ -58,16 +52,14 @@ class InteractiveSpinner(SpinnerInterface): self._file.flush() self._rate_limiter.reset() - def spin(self): - # type: () -> None + def spin(self) -> None: if self._finished: return if not self._rate_limiter.ready(): return self._write(next(self._spin_cycle)) - def finish(self, final_status): - # type: (str) -> None + def finish(self, final_status: str) -> None: if self._finished: return self._write(final_status) @@ -81,29 +73,25 @@ class InteractiveSpinner(SpinnerInterface): # act as a keep-alive for systems like Travis-CI that take lack-of-output as # an indication that a task has frozen. class NonInteractiveSpinner(SpinnerInterface): - def __init__(self, message, min_update_interval_seconds=60): - # type: (str, float) -> None + def __init__(self, message: str, min_update_interval_seconds: float = 60.0) -> None: self._message = message self._finished = False self._rate_limiter = RateLimiter(min_update_interval_seconds) self._update("started") - def _update(self, status): - # type: (str) -> None + def _update(self, status: str) -> None: assert not self._finished self._rate_limiter.reset() logger.info("%s: %s", self._message, status) - def spin(self): - # type: () -> None + def spin(self) -> None: if self._finished: return if not self._rate_limiter.ready(): return self._update("still running...") - def finish(self, final_status): - # type: (str) -> None + def finish(self, final_status: str) -> None: if self._finished: return self._update(f"finished with status '{final_status}'") @@ -111,32 +99,28 @@ class NonInteractiveSpinner(SpinnerInterface): class RateLimiter: - def __init__(self, min_update_interval_seconds): - # type: (float) -> None + def __init__(self, min_update_interval_seconds: float) -> None: self._min_update_interval_seconds = min_update_interval_seconds - self._last_update = 0 # type: float + self._last_update: float = 0 - def ready(self): - # type: () -> bool + def ready(self) -> bool: now = time.time() delta = now - self._last_update return delta >= self._min_update_interval_seconds - def reset(self): - # type: () -> None + def reset(self) -> None: self._last_update = time.time() @contextlib.contextmanager -def open_spinner(message): - # type: (str) -> Iterator[SpinnerInterface] +def open_spinner(message: str) -> Generator[SpinnerInterface, None, None]: # Interactive spinner goes directly to sys.stdout rather than being routed # through the logging system, but it acts like it has level INFO, # i.e. it's only displayed if we're at level INFO or better. # Non-interactive spinner goes through the logging system, so it is always # in sync with logging configuration. if sys.stdout.isatty() and logger.getEffectiveLevel() <= logging.INFO: - spinner = InteractiveSpinner(message) # type: SpinnerInterface + spinner: SpinnerInterface = InteractiveSpinner(message) else: spinner = NonInteractiveSpinner(message) try: @@ -152,9 +136,12 @@ def open_spinner(message): spinner.finish("done") +HIDE_CURSOR = "\x1b[?25l" +SHOW_CURSOR = "\x1b[?25h" + + @contextlib.contextmanager -def hidden_cursor(file): - # type: (IO[str]) -> Iterator[None] +def hidden_cursor(file: IO[str]) -> Generator[None, None, None]: # The Windows terminal does not support the hide/show cursor ANSI codes, # even via colorama. So don't even try. if WINDOWS: diff --git a/env/Lib/site-packages/pip/_internal/commands/__init__.py b/env/Lib/site-packages/pip/_internal/commands/__init__.py index 31c985fd..858a4101 100644 --- a/env/Lib/site-packages/pip/_internal/commands/__init__.py +++ b/env/Lib/site-packages/pip/_internal/commands/__init__.py @@ -3,87 +3,110 @@ Package containing all pip commands """ import importlib -from collections import OrderedDict, namedtuple -from typing import Any, Optional +from collections import namedtuple +from typing import Any, Dict, Optional from pip._internal.cli.base_command import Command -CommandInfo = namedtuple('CommandInfo', 'module_path, class_name, summary') +CommandInfo = namedtuple("CommandInfo", "module_path, class_name, summary") -# The ordering matters for help display. -# Also, even though the module path starts with the same -# "pip._internal.commands" prefix in each case, we include the full path -# because it makes testing easier (specifically when modifying commands_dict -# in test setup / teardown by adding info for a FakeCommand class defined -# in a test-related module). -# Finally, we need to pass an iterable of pairs here rather than a dict -# so that the ordering won't be lost when using Python 2.7. -commands_dict = OrderedDict([ - ('install', CommandInfo( - 'pip._internal.commands.install', 'InstallCommand', - 'Install packages.', - )), - ('download', CommandInfo( - 'pip._internal.commands.download', 'DownloadCommand', - 'Download packages.', - )), - ('uninstall', CommandInfo( - 'pip._internal.commands.uninstall', 'UninstallCommand', - 'Uninstall packages.', - )), - ('freeze', CommandInfo( - 'pip._internal.commands.freeze', 'FreezeCommand', - 'Output installed packages in requirements format.', - )), - ('list', CommandInfo( - 'pip._internal.commands.list', 'ListCommand', - 'List installed packages.', - )), - ('show', CommandInfo( - 'pip._internal.commands.show', 'ShowCommand', - 'Show information about installed packages.', - )), - ('check', CommandInfo( - 'pip._internal.commands.check', 'CheckCommand', - 'Verify installed packages have compatible dependencies.', - )), - ('config', CommandInfo( - 'pip._internal.commands.configuration', 'ConfigurationCommand', - 'Manage local and global configuration.', - )), - ('search', CommandInfo( - 'pip._internal.commands.search', 'SearchCommand', - 'Search PyPI for packages.', - )), - ('cache', CommandInfo( - 'pip._internal.commands.cache', 'CacheCommand', +# This dictionary does a bunch of heavy lifting for help output: +# - Enables avoiding additional (costly) imports for presenting `--help`. +# - The ordering matters for help display. +# +# Even though the module path starts with the same "pip._internal.commands" +# prefix, the full path makes testing easier (specifically when modifying +# `commands_dict` in test setup / teardown). +commands_dict: Dict[str, CommandInfo] = { + "install": CommandInfo( + "pip._internal.commands.install", + "InstallCommand", + "Install packages.", + ), + "download": CommandInfo( + "pip._internal.commands.download", + "DownloadCommand", + "Download packages.", + ), + "uninstall": CommandInfo( + "pip._internal.commands.uninstall", + "UninstallCommand", + "Uninstall packages.", + ), + "freeze": CommandInfo( + "pip._internal.commands.freeze", + "FreezeCommand", + "Output installed packages in requirements format.", + ), + "inspect": CommandInfo( + "pip._internal.commands.inspect", + "InspectCommand", + "Inspect the python environment.", + ), + "list": CommandInfo( + "pip._internal.commands.list", + "ListCommand", + "List installed packages.", + ), + "show": CommandInfo( + "pip._internal.commands.show", + "ShowCommand", + "Show information about installed packages.", + ), + "check": CommandInfo( + "pip._internal.commands.check", + "CheckCommand", + "Verify installed packages have compatible dependencies.", + ), + "config": CommandInfo( + "pip._internal.commands.configuration", + "ConfigurationCommand", + "Manage local and global configuration.", + ), + "search": CommandInfo( + "pip._internal.commands.search", + "SearchCommand", + "Search PyPI for packages.", + ), + "cache": CommandInfo( + "pip._internal.commands.cache", + "CacheCommand", "Inspect and manage pip's wheel cache.", - )), - ('wheel', CommandInfo( - 'pip._internal.commands.wheel', 'WheelCommand', - 'Build wheels from your requirements.', - )), - ('hash', CommandInfo( - 'pip._internal.commands.hash', 'HashCommand', - 'Compute hashes of package archives.', - )), - ('completion', CommandInfo( - 'pip._internal.commands.completion', 'CompletionCommand', - 'A helper command used for command completion.', - )), - ('debug', CommandInfo( - 'pip._internal.commands.debug', 'DebugCommand', - 'Show information useful for debugging.', - )), - ('help', CommandInfo( - 'pip._internal.commands.help', 'HelpCommand', - 'Show help for commands.', - )), -]) # type: OrderedDict[str, CommandInfo] + ), + "index": CommandInfo( + "pip._internal.commands.index", + "IndexCommand", + "Inspect information available from package indexes.", + ), + "wheel": CommandInfo( + "pip._internal.commands.wheel", + "WheelCommand", + "Build wheels from your requirements.", + ), + "hash": CommandInfo( + "pip._internal.commands.hash", + "HashCommand", + "Compute hashes of package archives.", + ), + "completion": CommandInfo( + "pip._internal.commands.completion", + "CompletionCommand", + "A helper command used for command completion.", + ), + "debug": CommandInfo( + "pip._internal.commands.debug", + "DebugCommand", + "Show information useful for debugging.", + ), + "help": CommandInfo( + "pip._internal.commands.help", + "HelpCommand", + "Show help for commands.", + ), +} -def create_command(name, **kwargs): - # type: (str, **Any) -> Command +def create_command(name: str, **kwargs: Any) -> Command: """ Create an instance of the Command class with the given name. """ @@ -95,8 +118,7 @@ def create_command(name, **kwargs): return command -def get_similar_commands(name): - # type: (str) -> Optional[str] +def get_similar_commands(name: str) -> Optional[str]: """Command name auto-correct.""" from difflib import get_close_matches diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 04f7572180d336fd0d41a6dfd90ae1a40fc5da45..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2893 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 diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-39.pyc deleted file mode 100644 index ce122136e9571e86ba5f72497a1a42bcb928e585..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5775 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 BwX*;K diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-39.pyc deleted file mode 100644 index d1b8d60541ad768db4004959a8f6ad0911cd8ab3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1541 zcmYe~<>g{vU|^UdaWK`Gje+4Yh=Yt-7#J8F7#J9es~8v<QW#Pga~PsPG*b>^E>jc} zBZ$qM!<@?!#gfY!#R}%L<gn$kN3nz1tT`OHoKc*)Tv1$LK3fiVE>9FsE^ibsn9rWW zm&+f;&&ZI<us|SHa3N!qkUK*PM+#>PLkedqdoy#Ca0+8EgC^HYkgNPO8E>(LCFYc- z7HcxyVs^}{yv5>^SzMyYc#GXRKQ}iqFGZ8-7OQJekblrE_TW%wXV>6hO{QCd$r-81 z+3^L5$=QkNsqw|BCASoli&7IyQjx{t(~9zQ<1_P$OA>Q(Qd2Y;Z}F5DWtODI=a-fg zl$IoeT!4(3U|}P}z`&5o5XG3n5XF?j7{#2z6vdLloWjz=5XG9p8qA={c8kXu<N~N0 ztIWevi!#$H72tL$K%G{skdauHs*s$YTaZ|inUs^Nkdj)EnwOHAmz<eetXCz*r2q!1 z1x5Mk3eoumC7Jno#j(lENbcfgU|`^6U|?_tMcWbv28I%bW`-E1TIO1o62=<lX2uw% zTGm>&8devESiM^I8s-{yNro(@T8<i45X*%jR;-q@ggJ$=hP{TPhBJjplA)P}k)hC_ zP^yN_g(21iMGqTPk4y}6EmtjfEl&w^3Nu(IPYqWMcQYF!Lt#pxUkz*Vgc`Qu2{kN5 zQ%YEZ8A_N_Seh9b8A@1#8B!R688lh_s<c##6;z8Aic$+pGmBC|Y#oL2jLhT=h0J1w zy!;YGaOo8>GB7Yy=|VJQB*Hc2rskC>s21xeB$bvZROXjLf)lJvuS(W0Um>X|KRY!K zW(P=lu|isYX<mw+CR-6G)QUJ57#MD`m!%dJXXfV>fpSL?8v_GF5jz6|gC_4Smg3Z$ zv|H@ZkiW%}Sd?CTiyIn!pp+HGTaZ{(oSBy%Ur>~vRD6p)H?tVTy~UlJpO==CnOu^Y zmwt<<peR2pHMt}{FEKZ@hzDdR7d)yfZ*iog7J#L0af4V;*W6+*N-bQ;P$a>?!0@ZV z*(xTqIJKxaCN(D|vna+tFV&?evn*9XS0U8TGt4z8*fYd2Si#fJ#oy00*wZm4*wxoH zIK(wb!7L^qz$YfrL^mftJ+rtZGdm_VuPnwVGbyGxvm{j)>X+h}g3JQ__{_YL)S|q^ z9Q|ZS{wmf7=Ow*@%3I7urFmkYM5X~seau{pJWL#nT#P)7OpHv7T>m&&K|CQikB5<k ziG#69068b<6_w`sX|mnohzI*NKK>S0e0*+xN@-4NeEcn*`1r!o#2io%#mC=bkB?8u zPmYhj#addNn4VfB1&S3=P=Lb&LP&zdxEUB21VHWr#Ty4B3lj@-5lBo^<Q98QetJ46 z{5kRqN<i_HS_I0)x7bQ53o`T4i$M9P2vp|Xk}Jq8(1ZJ4FF7YuFDbD&H69uaMXaDG z!=k9TB(bElI6gT)CAAolaL|p*FGwv)1m|5naBzZC9XS2nl0db%v?Md9ST8rTI2oK4 zZ*iulmiXkSr>7PbNrRlg2J%sA5!i!}FhB$eC^T+y*g(S54wPkzLE*x|$ipbW#KS1S LD8RzQ#KjB%UBjsv diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-39.pyc deleted file mode 100644 index ef90587f3b654e54f6b96290027aa7e696bf94f3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3097 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 diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-39.pyc deleted file mode 100644 index 7e2472bd8f2106dea5261c6baae3a06dbd02249a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8078 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 diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/debug.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/debug.cpython-39.pyc deleted file mode 100644 index 2e13ff15c5b4c7755b5d713a303bfd2cfbd7c682..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6462 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 HB@R&lSwEjg diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/download.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/download.cpython-39.pyc deleted file mode 100644 index 9a6089bad2293ba88c4b265ae8b2786b279e3be6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3948 zcmYe~<>g{vU|^UdaWJ(}n1SIjh=Yt-7#J8F7#J9emoYFfq%fo~<}gG-XvQeU6owS0 z9Hw06C}u{G7;_FwE^8Dkn9Y*ImdhT+4ra6FaO84Eae~=wIb6BiQQWyaQ9NKidk$|d zUlbph&5^^OD-b0BW^?8U<_bj#<qAg$=ZZv$fW^3SM03TW#26V;85W4AN-SiIl5}TC z;ZEUcVMyUg<!)w<l1gC=X3*q)3G#uTCgUx(u*96w)M8D>TP!}A#U+}Ix44pXQ}PQ+ zGV}95qC&Ze*{Sg*iACwDCGiE7B^mj7noPHZf>H}hGmBDlQ}ark^K)|(^HOf{lxLP? z#3$#ZCgznEXfobn4-R#9b`1{JWV|H~(p-el5?@l3n4Fzjq{)1XD>bjUv?w(`C9~)j zUtWGuZemVmRcd@eVoAm=p7Ns1lGOP8(vpHwkjr>OQgaJjGK*4^OY(~<lR;iU#>}vY z&|qL-NM!&8eiTy*V-#}=Qxr=Ia|%lfLlkQ&TMBCmTMI)oV-$M|doY70$1Q%B{PMh< z{KOQfPZE6?85p<}6ciL-5()*0$=QkNsl^IuMftf_TwqCEg@DQcPX&#{ycC7}l8n?M zh0MH^)QZ$%O@-3p%)E33Bo8YT7o;X<re&rU73)DYhdBo;6cpuWr6!jslosW{#eMRV z6La7)DNx^LrlKjxFH$H<&CM@KRVdCcElN&RNGwXu$SeaX16xp#S)h=ZQ=G3*Tv||& zUsO`8kOK83$Y~&NC@3L0uvj52GbgoJNk^ePBQrSzWPe#^N-Ef>#5{%6#NtYY^2ADo zl6<IFDisnH$}{qFQWaA3$})@c^FT=fB%PEBw<$FR;@L!LSb!=hs1_9Erz=F~LlRi5 zf(?=*phjn=7TGC8LxWrw9H_c*^?G^`GcirlEkZF2;v;elvMEb01_b~tYU~tnTWXVo z5?!EVi&r@`mOwGC4_BPbh?I<(7#J8p1&%YQNQq%&V5nipVpzaf!nA;SA;UsOMg*S) zjn9h4XG7z&qwzV=_?&2bE;K$j8lMM^&x^+AL*w(K@deQMf@pjp1V4*0g)xN*l!rmN zw?sHgB!xYNqnCq`p@eCHC@6$LAydM%K&*r*OT305OJX5YEhC6tAeq8h!?=(M9BvX| z9zzxbh@Zj`%%I8TSH+~8QpKjLo03{wQY8qXGxHKb<)3a!W>J+mh7hFqxy1v^P~ftQ z8KhPgv%tvAE6G=|Ny#j-)6-<R#R9VB7JF`LNn%-I(Jl6r)U?FXoRV8C8L2r1MWAG$ zDRqk@IX5Lfzo4Y}7FS{ln3b8IR|KkNZgD5)=M|R}C1&Q86yM@O$~wijIFm{<b5g)= zVb9BtPf0B(zQvcGlb@8B12PO$oZsTi%a2dW%u6h)yv3cLms1Jj@D>!Mrll6axXi^x z$+wsbic)X!L9K|-NG#4sExyGA%DqLY#l`VSiAA@BK*oV>%`DE(0SDPFuF~Sv_=3~| zQ$zDxym|TYNL;bZ^t}9{)Oe_w#n9^H7E^xlEw<#+B2X0|3Gy*YZ3B0_Ah;%i6a?|< zMfs%#x46ND1C+y7kXTflT69Y|Gp{(cs06AHBB{xAi={X<C+!v&L<cBzS27eCFfcIu zYIe4Y2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2 zbqx-24N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)rFQ|#W4k$1^V%sc_pbu zd5Jmt$&mW8SRa;t^a?6(afAE~@msMfDCgUNiUcMBM!b-Tjgf<qiIItsg^}qu8wU>) z3nL37%Rd%YKE^6(SXzYEYI;aEB!j9-kOd&j$H2hA$-uw>E^yQs85mL+YZ&7h(iv(P z<H5yF4I?;nvD7eTu{ML`SWDO-Y(|C}h6U^(`C8@@jvB^h##)vdhAhq+#v0}tkb15Z zre2m>)*6Nd+$B8C3=0`+*-Ch87_<0z7*d#17*kk!nQPf=7#8r?Fx4>Du+}gyWU1w- zVaO7wVXtAVVXI-TVFlR)%JjYLwVX8!S%Nj3Ah8<8EUp^HETI(kUe;Q!8iobJHLM_4 z)^KHs)NrIQrf~E!)pDmZ)biADXNfKlTgc$T5NlM+Tf>_rp2ASdP;{e)H%lUgp_H-s zix)!^V-4p5$r@g;2|Np=Kyn~<;f)%e35-QbCDJLJDO?L=YIqhhHZw6Yl*k4%Xmb07 zXtLa5hep~h_Ttpy;>`TKTf8XAw@8hFf#DVhEUq<~Z?UDM=A@RS-eSql%uBf?0Lh{` zmGQZWd5P(%DQ=qVxA;m@a|`0(8M??AWCnLpY9XxQRAd4YVM_z0=At5g5Qi6((@Kj| zi{e3vPm}c)M?q0)L1IyAQ4uIDfz5z8hQFXPzAUu}<k<MkytI5x##>^^8L7$H@zAzH zYD#>0MrvwKag|hXX>xLEadBE{PEI9Ky{@2I{EJaRQ|^`kG*4&d6_+ID<fNwD;!I7+ zEJ;ktNiBvHSx}=>GK)*%i&BeAiZYWyWor>P0|Nut<wc;{?v^m9i3lwY<Do%W#0v75 zC^R6T*(o0CX>hpmrh;-+d~$wXNoqw&5hut@UXUh^ynIMg^p*g~U}%v8YNHh2k^~nd zNJ8<jkh;YSl`789DN8N7#RqBd!b0no0I1!X8lRL{oS6&`x?Ai;sSvdiAY0kWz>Vo! zJjID6nZ;?DsVVVEmA6>(5_3~;i5Dl9rN-xE=4Gd*z=}YSdv38M78IoBr4;diOkl~% z&&(_0U|?X-<SWtxc?TT#EQv+w#o$OUG6e~OW7Ha?ffLq3th~iilv-F^WCs%EfH~_H zKe9iIQ%i1f!IENX$}Q%i)Ix9}2q6qXTA7PV^SnSMP!gzcU}0lsW8z}sVdP@sV&VXm zGm!G;4;woV6B8pFi1(L`O@N67#DZcLMy8)^Trd$9MwZ`f99*EX=|39_3nL#R7ZkHG z3NTd(qnA@frFnju9Je^)<3ZsTAAgH0K0Y@;r8FlsKK>R@e0*VPVh&V>Jw84qKRG`B z7Hes7VtQ(k5h!ffK|~CQ02S{LpMhB*?-hYcJ3)~5K&g&{k%fnaokNw05iG7LeTzLO zKRrD&FTF?|6c!x$1tpML1=K3L#a2>T0Fncho>77YnFV_AQe7`OClj3Bqhv6|^$;B@ zNQ#!lR07J|(2Ajm4dix^FK)?UDl9HZEGaFHPtH$CEe5BPTWF>gr55UeOamp=?9?J~ zp137}YEWrOW=^qQZf0>ZIP*dBA~^k_xgMerTpFch78QZB7H4{DiBEoddTLQoEGUrJ zKtYyT1P(!@(1r*3Ee;z<^x1*hH^rcg!okSF$iv9P#KXwLC;(zHiZJppaWMk`AX=Q{ diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-39.pyc deleted file mode 100644 index fcfde785a5b7a033456abe0d7a65cdb9dca147f0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2946 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 diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/hash.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/hash.cpython-39.pyc deleted file mode 100644 index 86395283513416bb9f85def0919200009424cc90..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2058 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 diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/help.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/help.cpython-39.pyc deleted file mode 100644 index 8767c57e9cc95e4746bf30f1e65951f1184267ea..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1277 zcmYe~<>g{vU|^UdaWJ)(g@NHQh=Yt-7#J8F7#J9e0~i<>QW#Pga~N_NqZk=MY^EHh zT;?cdFq=7tC6_gd70hPIVasKYVh6KXb2xH2qc|BE+!<2XQrKG<QrJ^jo0+4yQaFMc zG&x^_?9ybs#TJ&BQ<_?=$#{#!C$qRjlkpb2bAE1aVqOY}864{D>>3=b$#{zgD(YHP zlwXt#(u|CmV2)K_U|>jPh+<4(h+;}%jABk<iegD&j$%z=Nnveah+<1&3ue${zs2p5 zno|HZu}UmBBfnfBBQ>W$AuYd1AsJ$Qag`XC0vM<k6y>KY*g(bYLXw%0tOf-l2Ll6x zGbpGgfP#uKg$Wc?wamFpwJf>JwXBQ`RXjCJDU6Z~wQS)Gd15RKB`lR@j0_-H!pg=F z$q>w7z)-_h!(7H#R8_-T!`94L%bvnq!#0~Cg=H>tI%6$I4SP{e4aWku6xJGci0DE_ zMurmh6t)E%H5>~Wn;DxJYgoWKIcqqxI2Uj&WME_{VFmftuZWR>fkBh`7BAEb#qlYb z$tAb=l8aIkOH$*ZqPIlSQ%mBDGjlU@5{qDh#Z`i(dD(gS<$17hQBeBDs8l7Gn^>8Y zs!*9<s*szSm{+2pRK={ItDwn!ORONXKrcQsuOzi7FEK|CYIt!GD3FRc85kIfKtXnk z%QG(}wE`TQMXU@A47b=43kp*6Qi|9>9G0y7%)DD{1&Kw)sYSQA3W_rGO5#B=q{(%Q zr8qSw?G}4}K}lwQUhyrK#G-Tz(>aoJQ{wXyb5n1zrkAD`7vEyeEl$714t2~*h9XG@ z28Lht&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW z!LGip!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g z`tY#Ohgx5(5Aum#LFFyxqS8D8P{NS`r6?v5HYO$>Mjl2kCJsgpCO$?MMj<9XCJsg} zrYe4<1glq6n&+p<ev2a>?8W%_TU_z+x%nxjIjQmSw|L^?3riDoK%S3}zr`LOpOT*( zAAgIrv^X(6^_FmEdR~4}YJ5>@VQFSjYJ6F0URjYeC{{or0uB}kAq5g+XJB9eMOiT@ z@;De-m_V=yB<iQheTyT%pac>_pzL>xt)#LbGcUaelsj(8p{0VHOueMUVt86B0+lY< z6cv{wmXsF9C+DZ67DLj71gc4?70IcPm<Oj6uwx)DMtA_^_FEh_kRY)GCH`Vin&V;Q J0S7M+GXVF#RZ0K= diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-39.pyc deleted file mode 100644 index d2303ddb9525c8b56dc3349e16f9af37930246d2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16724 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 GLkj=~Q8gF< diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-39.pyc deleted file mode 100644 index e8376fc691603f5cd9336d1b06101f7de917a3cc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8835 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 T&?s1f4V1;Xm<8$?@;KB0tR^RH diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-39.pyc deleted file mode 100644 index 8f67ca4d02b7926ac728fc80dbeb4b9cbc175acd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4934 zcmYe~<>g{vU|^UdaWM6sC<DV|5C<8vGB7YWFfcF_>oGDgq%fo~<}gG-XvQc;FrO)k z2~0CbF@tHADAp8)6s8=uT=pn-Mvz+O9FAPhC{8e&C5J1QJBmA(CyFPRH;OlxFNzN= z&YHuYD-b0JX0zo8<qAg$gW2pkBDtbbqF^>hj##dElz6U0lmwX1nIoAi6(t2`bLB|q z%0$V4+1xp@xpGl*U^Y*Ve6B*20+`L4qnN7{r37a4<tXQ>M5!<`q;eO1NnuFg&*92d zjZ$S~aA!ynND*vdND)j`ZDx*AOJ!J~o~p5sF-p^&Aw?)fxP>7_I8``Rw3#JJD@7zl zw1pu`J4Gr*EJeJ9F-j*zB1N)=AxbxeF_=M9`XwkN{WKYGar+mgq!y*7xMU`mXfobn z3rox?O)b`Bxy2h28Q>c4?BVL{?dj)!iv^_M7K=}2amg(X|ALat{Jg{*O~zZS1&Kw) zshW(p*q!rpa})DYG#PIR2d5SnXXfWYMSL?WGV?T<ZVCAL$NM^lID5DT$GiE5`nlX< z4-R#9b`1{JWW2=#RqR?+lwYLDcuPDzwIn_zH7&6;rzAc#uPn1DKQA{m59CIcfXV<* zO~zY70ht96xj97z$st9FdBp|!MIc$O%)FG;yps5w{B)49<wcn#sqy)xB?YA*S<aBk z0*GgmK_P&QnPKTki-Cb5l>wB7qL@M%Qkhd(QW$L@G?NWODr+jUBtt4o3bPGE3QI79 zChILeu>EQIMY*Xd9+@S#Sn?8cQ*W^sm*(as7FFKjC`&B@1xK-;CfhBJ_;`?PeEco0 z`1suXl+v8k`1o5q@$rSFi8)Xi=Hil~Tm13yiFtYXC5fP*E{=~cVq;)nSjkW%%fJ93 zel<E<#e^2878S>&=A>j6#rWr?x)f!Wr7Gwug!*}gxdsJ$hByW*c>1~c`?&^tI>rRM z`nm>(xCSYh#RLTS#3Y*N=H#bm7MEmZ$E4<!#rR|<#S~|jr0NzVCTAz6rxwQ)WESYh zXXcfp7Ud=8=qE!WxLCh9HL)l;L$9E+NQ8lbK@yY)L5|~M<Y44r1dCw=E)y(p4Uhsi zg)xdbg(-?9g*l2fg(Zcxg&~S9g)N1>g&~SPg(HQtg&~R~g)5jrllvBLFxXCLBB^qK za23+>ixfbqK>_Auh4PI2;#37tKq}-HDL|t@Avr&<Br!9uSiz>SG_|PGPOnOiO92d2 z3ySj76{7RODY`forXVDl5h-ne*c=QD49+00>M<}d)G%Z*WHF{NrZA;2r?8YTWih9) zrm*$0F@j`R7O<wUgH$YJ0%ho622BpXDkj~`Dt296P~xn(#R{RALxX&(jGYpTQx!sk zd=&E26ap$sGV=2j0w58f;F*__TA`o;%?1jpP==-^%Pp3a)Z&s`?768WiDijJx7eXl zw^%Y#a|((;4hAK*<lL0_{DP9=TU?1LU{+>+UJ*Y71H&zjg35x-_|l@BTWsJQTy#q~ zGp{(cs05@wGe0jry(qu5K$GznOL1yW8Y0yd$$@lpBaAE700oKwD72W^7+DyZ7@0ui zZ#MQSNk}X~BTWxUPckU8fwX`yI|Bm)3oLZQK%vW2%u~XU!r08%#8|^r%Ur{-fU$<T zhH)WNElUYg4NEg)Eo%xxEn5k57Rv(Gg$zY@C2R}W7c!(UNrFT<YFKO7QkZ+07#V6< zih@cwgBeOdsffj|O4B#9xHvN}U7;wour#wMHANw@D7_R^t|(|gQndm&foSSMf{^hR zUrB0FZf0I$PJDT0N=b$$cM&fr0N5a^Z}F9YiXKqbkI%>~DZa&ATv>dJt+*s5zqI5Q zTV`=$NlE1`w&IM^lFXc2f}k=DZeDR_Rq8F?f}+g4lK7(3;?kUw;vybU=H_N#V9;bQ z(gxYX4o#T1SQ3lUi*K=lT^Gd(jy$l1EFiK-7o-nfGC<;pxu`VH7!)@Wpg?9~VdP+B zVdP=tU}9n9V&q}sVPs)sVXP8FjiaK{Je0TrRly((PWe;7ag)UWjS;4WjNtfSu3>3r zs%3@5Mh$Zf>q4elwkok2wgqf8j5UlYjB}V$m=-eCvWGL|Ik7N+)Mc?(HZU^OaxgMf zsiiPyanx{Ran^8Taiy^IGSzaHaMy5x;y#=qk|BkmmZOd%j|)N@Fc>hD@YJxE@HR6Q zPw--BVys~Y6~TU*OhuxgFc1R;8dH8zm2QNuPf&m}IHFUFOBB))Gjmc?6rz*!Q&O!I zszFq3ELU}LNl|8AdaWkYEf$avDC$50ntVkHAd`eaF$T?A@x_o@tq7FXZ?RQ?Yo1$d z$vK&+c_p{FgHwyjQi}qL@+&HfKt;qYRyR=Hb&Cy@I1)>4ae}Kd=lqn^Tijq~FxYBH za^lJ?&de(=Nz6-5y~UD~SzMyY1&;qB3y`PGKu+NVml@z3%MNwPElzOi166#tSU^dl z$P%QI6>L1HY$z^HOixA2yI{w;fYOBwI9;$YaWQc*@-Z?oiZKd-(*(;uHWoQXKE^5$ z)U*Lf@_w3}MW7T_1S<E7q(Bz3$H%ASC&$O%Vl4$(cuP1lJukl~H6EJD;>%L=%8GPA zKCuE3pwK~b6gb&}N|hpc1_lO2kjp^XfP;~R2?RN~IRwEnC?ztez5z7=!RfM%fq|if zp_!qUv4+8gAvUj;sfH<qQ4*9+nZRWNOAS*Bvm`?;E2tD%z_^g1jIqeAhPj5NhBcir zg=G$N4Py<n4MQOph?ZnXVU=W9z*NJ!kdcw0hP4DN3lVK*%w{U$s$qeuV*=?ZVX0vR zl|s#+h80`Y9&p7Hl98$aibsXCqWoM1P~0eF7Aq8`Cg$W+DkMUr^3xPxEdxD;@KlBJ z#Jm!O9M~8{wU$|up-=)d6iKH-aY;U?9Lvnh$;?aDQwYh(ECy9~WvN9a#ULGEbI_fV zSCX%gpO>moo~n?Xn5R%$oT>*_hm?ufp>ES;MhF&(gW?ZFXtEW7s`Ohd*{PrcFR`E? zH815Be@13{Mrv_MJXCLyJ1BXul|kB+Y>?#10rS)?=8Vh|B*OzihJ#ZBm;fgUeFg@G z2vCv$CsuYga1(=rk%Nhc30%?q<zW+I7GdOLDgvoQDY`)AG$*WDNn-?6+Ql3x48aUF zj42GI3`J_7Dkg=gg#nakni-oJQ<%jWY8guyn?VVO!G&Q0W2{~+OASj33pnYpfRaUl zM+#dl8>kXmz?{OK!jaCnkg1ummc524g`t$OXjTnV4Wk4@3a11^Ek_MU3RgBu(X0}d z1*|n}H5?0>YB^K5Q+R3^Q+UN0L>R;w7O>TDE@Z4_t6`nZkiu8PKARzhe=bWcR}EJU z<7|f6EGYstY_l2WGS_lf^_8&Ka5sYzB=Z6eP|~dBso??HIf1drqlB}Wp+Ag~p@t`m ztA;(BspwY;dx{{4*UZGokf&F|o+1R}m2lUvH#27OOkgaMD`8I&u3-nO;VNNI5rMG7 z8B!Qn7+4sZnHd@KgbW!bFc#YxFff8)Bm*NuI76WU3quL-1jfoZm}sGa0YjkyD0DSN z{ZMi$D4BqwAs7^kpsb(HP{R<bR?AodjtEJHX2ueR62=<F1x%p!6eK{K8O0eUG8KZF z*U;n#N_4*%bv2o9G3TV_6@`Ej7IS)Pi6+x6COw0qaLlxGi^~R-?343z3+$>umV??D zY)nl5s}xZxT|Jwe{N%)(Vmm#A`j;TJh@^Ro0h01TDe)z!*m()66K^qc{bE#j32Mqz zF)3*LV$`f+R?t<b67%#64srDHadoj$P%T!_$Vn_oEiTcl;zbd!vh{HcaSaZ!0yRTH z$_k27b&FDSQWJ|)trftvK~9cBIVj&N6=W8`MRauwic*y{t9VhgYx3P<&P}W+;sb>P zC~%6RKq16Yl3GzxUX)mHiv>bv<!9y<34x>pz*So&r~*tX1@$qC1VMU1neY}bxJd}h z#kZIXic)V0h2~{~sz}#7FbVFa@q%-7lpv_N9iN<^Q<|F>4{j!b8zi@wLFGO;X5e*m z6dNQoqIgOYi$E>_E05xZHq_%mg;;SEH`qXkN>F{6mwJmO1>{t4!2l+}rGqI014Ah& zYQ4Z!8K^-6DjS&ou`x6KWnpDw1a(Px7=;))zzrWBMgc~q|18V`j6#e|j2w(yV0kV^ zJ|-SUP;-dsKO3_iBOhZC$Xt{}3~En<k_5QA0o6_=3^fcTj46!0Ou-DAOrVZ5b9QQ_ zCR0%=C=jziEjUI<ngP2OOn{vXikk%>Cxh|@0~0tQYcl!yY3ki#&&f|u&&*3N0=3$T zKpmx`G*C?OLYf+Skd{V~JxGi@IX@>SH5n9d#gLMiBfp>o9BoCQ1bK_Cq_O~H7Rc2_ zpd<_KKNf-7+EKCvnFV^FS~(@ZNDopPXXd5r!3u3qPp1gvg<Eo9g|H4F$N_puiN&e$ z(4JrsC|}=#n1-ULD76r-2Aor{7*t%6SW;RX4@ykMMW7}xxbb^S0@cdYisV#C*9_87 z5<`^+b$?P4OA^89{+1M)WPVC&PO%=i-30FRM9H8k$V)9L&o9c>gM=@nT_=sI1k`RX z)`LY1D2JfC5TYVCvp5-?uZo002>{eDzQviITH=$Ro}O9+ZZO?q0~wQA1a8cLt1ECi z1E&CN&7oTyHjwcFJ5cH?Hez640QIjS7?fZom_V&~P@)F$pqPn;k%vium5W)(oI{pN F8vuh?0>l6S diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/show.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/show.cpython-39.pyc deleted file mode 100644 index 575e0e6764f229fdd77450afb66c5e5dbf14a090..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6333 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 LCN5?H6^<wXjdw$x diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-39.pyc deleted file mode 100644 index ac30940333179e957cd821fb0e2ce525a52ec5f7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2882 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 aR4l^4z`(=E!^FeH!zjSW1BL=DJj?*3sZcZk diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-39.pyc deleted file mode 100644 index de43dd9d54fcdc00b2f5635f96d32e63919dba27..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4821 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 diff --git a/env/Lib/site-packages/pip/_internal/commands/cache.py b/env/Lib/site-packages/pip/_internal/commands/cache.py index 5155a505..e96d2b49 100644 --- a/env/Lib/site-packages/pip/_internal/commands/cache.py +++ b/env/Lib/site-packages/pip/_internal/commands/cache.py @@ -1,4 +1,3 @@ -import logging import os import textwrap from optparse import Values @@ -8,8 +7,9 @@ import pip._internal.utils.filesystem as filesystem from pip._internal.cli.base_command import Command from pip._internal.cli.status_codes import ERROR, SUCCESS from pip._internal.exceptions import CommandError, PipError +from pip._internal.utils.logging import getLogger -logger = logging.getLogger(__name__) +logger = getLogger(__name__) class CacheCommand(Command): @@ -36,22 +36,19 @@ class CacheCommand(Command): %prog purge """ - def add_options(self): - # type: () -> None - + def add_options(self) -> None: self.cmd_opts.add_option( - '--format', - action='store', - dest='list_format', + "--format", + action="store", + dest="list_format", default="human", - choices=('human', 'abspath'), - help="Select the output format among: human (default) or abspath" + choices=("human", "abspath"), + help="Select the output format among: human (default) or abspath", ) self.parser.insert_option_group(0, self.cmd_opts) - def run(self, options, args): - # type: (Values, List[Any]) -> int + def run(self, options: Values, args: List[str]) -> int: handlers = { "dir": self.get_cache_dir, "info": self.get_cache_info, @@ -61,8 +58,7 @@ class CacheCommand(Command): } if not options.cache_dir: - logger.error("pip cache commands can not " - "function since cache is disabled.") + logger.error("pip cache commands can not function since cache is disabled.") return ERROR # Determine action @@ -84,78 +80,77 @@ class CacheCommand(Command): return SUCCESS - def get_cache_dir(self, options, args): - # type: (Values, List[Any]) -> None + def get_cache_dir(self, options: Values, args: List[Any]) -> None: if args: - raise CommandError('Too many arguments') + raise CommandError("Too many arguments") logger.info(options.cache_dir) - def get_cache_info(self, options, args): - # type: (Values, List[Any]) -> None + def get_cache_info(self, options: Values, args: List[Any]) -> None: if args: - raise CommandError('Too many arguments') + raise CommandError("Too many arguments") num_http_files = len(self._find_http_files(options)) - num_packages = len(self._find_wheels(options, '*')) + num_packages = len(self._find_wheels(options, "*")) - http_cache_location = self._cache_dir(options, 'http') - wheels_cache_location = self._cache_dir(options, 'wheels') + http_cache_location = self._cache_dir(options, "http") + wheels_cache_location = self._cache_dir(options, "wheels") http_cache_size = filesystem.format_directory_size(http_cache_location) - wheels_cache_size = filesystem.format_directory_size( - wheels_cache_location + wheels_cache_size = filesystem.format_directory_size(wheels_cache_location) + + message = ( + textwrap.dedent( + """ + Package index page cache location: {http_cache_location} + Package index page cache size: {http_cache_size} + Number of HTTP files: {num_http_files} + Locally built wheels location: {wheels_cache_location} + Locally built wheels size: {wheels_cache_size} + Number of locally built wheels: {package_count} + """ + ) + .format( + http_cache_location=http_cache_location, + http_cache_size=http_cache_size, + num_http_files=num_http_files, + wheels_cache_location=wheels_cache_location, + package_count=num_packages, + wheels_cache_size=wheels_cache_size, + ) + .strip() ) - message = textwrap.dedent(""" - Package index page cache location: {http_cache_location} - Package index page cache size: {http_cache_size} - Number of HTTP files: {num_http_files} - Wheels location: {wheels_cache_location} - Wheels size: {wheels_cache_size} - Number of wheels: {package_count} - """).format( - http_cache_location=http_cache_location, - http_cache_size=http_cache_size, - num_http_files=num_http_files, - wheels_cache_location=wheels_cache_location, - package_count=num_packages, - wheels_cache_size=wheels_cache_size, - ).strip() - logger.info(message) - def list_cache_items(self, options, args): - # type: (Values, List[Any]) -> None + def list_cache_items(self, options: Values, args: List[Any]) -> None: if len(args) > 1: - raise CommandError('Too many arguments') + raise CommandError("Too many arguments") if args: pattern = args[0] else: - pattern = '*' + pattern = "*" files = self._find_wheels(options, pattern) - if options.list_format == 'human': + if options.list_format == "human": self.format_for_human(files) else: self.format_for_abspath(files) - def format_for_human(self, files): - # type: (List[str]) -> None + def format_for_human(self, files: List[str]) -> None: if not files: - logger.info('Nothing cached.') + logger.info("No locally built wheels cached.") return results = [] for filename in files: wheel = os.path.basename(filename) size = filesystem.format_file_size(filename) - results.append(f' - {wheel} ({size})') - logger.info('Cache contents:\n') - logger.info('\n'.join(sorted(results))) + results.append(f" - {wheel} ({size})") + logger.info("Cache contents:\n") + logger.info("\n".join(sorted(results))) - def format_for_abspath(self, files): - # type: (List[str]) -> None + def format_for_abspath(self, files: List[str]) -> None: if not files: return @@ -163,49 +158,48 @@ class CacheCommand(Command): for filename in files: results.append(filename) - logger.info('\n'.join(sorted(results))) + logger.info("\n".join(sorted(results))) - def remove_cache_items(self, options, args): - # type: (Values, List[Any]) -> None + def remove_cache_items(self, options: Values, args: List[Any]) -> None: if len(args) > 1: - raise CommandError('Too many arguments') + raise CommandError("Too many arguments") if not args: - raise CommandError('Please provide a pattern') + raise CommandError("Please provide a pattern") files = self._find_wheels(options, args[0]) - # Only fetch http files if no specific pattern given - if args[0] == '*': + no_matching_msg = "No matching packages" + if args[0] == "*": + # Only fetch http files if no specific pattern given files += self._find_http_files(options) + else: + # Add the pattern to the log message + no_matching_msg += ' for pattern "{}"'.format(args[0]) if not files: - raise CommandError('No matching packages') + logger.warning(no_matching_msg) for filename in files: os.unlink(filename) - logger.debug('Removed %s', filename) - logger.info('Files removed: %s', len(files)) + logger.verbose("Removed %s", filename) + logger.info("Files removed: %s", len(files)) - def purge_cache(self, options, args): - # type: (Values, List[Any]) -> None + def purge_cache(self, options: Values, args: List[Any]) -> None: if args: - raise CommandError('Too many arguments') + raise CommandError("Too many arguments") - return self.remove_cache_items(options, ['*']) + return self.remove_cache_items(options, ["*"]) - def _cache_dir(self, options, subdir): - # type: (Values, str) -> str + def _cache_dir(self, options: Values, subdir: str) -> str: return os.path.join(options.cache_dir, subdir) - def _find_http_files(self, options): - # type: (Values) -> List[str] - http_dir = self._cache_dir(options, 'http') - return filesystem.find_files(http_dir, '*') + def _find_http_files(self, options: Values) -> List[str]: + http_dir = self._cache_dir(options, "http") + return filesystem.find_files(http_dir, "*") - def _find_wheels(self, options, pattern): - # type: (Values, str) -> List[str] - wheel_dir = self._cache_dir(options, 'wheels') + def _find_wheels(self, options: Values, pattern: str) -> List[str]: + wheel_dir = self._cache_dir(options, "wheels") # The wheel filename format, as specified in PEP 427, is: # {distribution}-{version}(-{build})?-{python}-{abi}-{platform}.whl diff --git a/env/Lib/site-packages/pip/_internal/commands/check.py b/env/Lib/site-packages/pip/_internal/commands/check.py index 70aa5af2..5efd0a34 100644 --- a/env/Lib/site-packages/pip/_internal/commands/check.py +++ b/env/Lib/site-packages/pip/_internal/commands/check.py @@ -1,12 +1,13 @@ import logging from optparse import Values -from typing import Any, List +from typing import List from pip._internal.cli.base_command import Command from pip._internal.cli.status_codes import ERROR, SUCCESS from pip._internal.operations.check import ( check_package_set, create_package_set_from_installed, + warn_legacy_versions_and_specifiers, ) from pip._internal.utils.misc import write_output @@ -19,10 +20,9 @@ class CheckCommand(Command): usage = """ %prog [options]""" - def run(self, options, args): - # type: (Values, List[Any]) -> int - + def run(self, options: Values, args: List[str]) -> int: package_set, parsing_probs = create_package_set_from_installed() + warn_legacy_versions_and_specifiers(package_set) missing, conflicting = check_package_set(package_set) for project_name in missing: @@ -30,7 +30,9 @@ class CheckCommand(Command): for dependency in missing[project_name]: write_output( "%s %s requires %s, which is not installed.", - project_name, version, dependency[0], + project_name, + version, + dependency[0], ) for project_name in conflicting: @@ -38,7 +40,11 @@ class CheckCommand(Command): for dep_name, dep_version, req in conflicting[project_name]: write_output( "%s %s has requirement %s, but you have %s %s.", - project_name, version, req, dep_name, dep_version, + project_name, + version, + req, + dep_name, + dep_version, ) if missing or conflicting or parsing_probs: diff --git a/env/Lib/site-packages/pip/_internal/commands/completion.py b/env/Lib/site-packages/pip/_internal/commands/completion.py index 92cb7882..30233fc7 100644 --- a/env/Lib/site-packages/pip/_internal/commands/completion.py +++ b/env/Lib/site-packages/pip/_internal/commands/completion.py @@ -12,7 +12,7 @@ BASE_COMPLETION = """ """ COMPLETION_SCRIPTS = { - 'bash': """ + "bash": """ _pip_completion() {{ COMPREPLY=( $( COMP_WORDS="${{COMP_WORDS[*]}}" \\ @@ -21,18 +21,13 @@ COMPLETION_SCRIPTS = { }} complete -o default -F _pip_completion {prog} """, - 'zsh': """ - function _pip_completion {{ - local words cword - read -Ac words - read -cn cword - reply=( $( COMP_WORDS="$words[*]" \\ - COMP_CWORD=$(( cword-1 )) \\ - PIP_AUTO_COMPLETE=1 $words[1] 2>/dev/null )) - }} - compctl -K _pip_completion {prog} + "zsh": """ + #compdef -P pip[0-9.]# + compadd $( COMP_WORDS="$words[*]" \\ + COMP_CWORD=$((CURRENT-1)) \\ + PIP_AUTO_COMPLETE=1 $words[1] 2>/dev/null ) """, - 'fish': """ + "fish": """ function __fish_complete_pip set -lx COMP_WORDS (commandline -o) "" set -lx COMP_CWORD ( \\ @@ -43,6 +38,28 @@ COMPLETION_SCRIPTS = { end complete -fa "(__fish_complete_pip)" -c {prog} """, + "powershell": """ + if ((Test-Path Function:\\TabExpansion) -and -not ` + (Test-Path Function:\\_pip_completeBackup)) {{ + Rename-Item Function:\\TabExpansion _pip_completeBackup + }} + function TabExpansion($line, $lastWord) {{ + $lastBlock = [regex]::Split($line, '[|;]')[-1].TrimStart() + if ($lastBlock.StartsWith("{prog} ")) {{ + $Env:COMP_WORDS=$lastBlock + $Env:COMP_CWORD=$lastBlock.Split().Length - 1 + $Env:PIP_AUTO_COMPLETE=1 + (& {prog}).Split() + Remove-Item Env:COMP_WORDS + Remove-Item Env:COMP_CWORD + Remove-Item Env:PIP_AUTO_COMPLETE + }} + elseif (Test-Path Function:\\_pip_completeBackup) {{ + # Fall back on existing tab expansion + _pip_completeBackup $line $lastWord + }} + }} + """, } @@ -51,43 +68,54 @@ class CompletionCommand(Command): ignore_require_venv = True - def add_options(self): - # type: () -> None + def add_options(self) -> None: + self.cmd_opts.add_option( + "--bash", + "-b", + action="store_const", + const="bash", + dest="shell", + help="Emit completion code for bash", + ) self.cmd_opts.add_option( - '--bash', '-b', - action='store_const', - const='bash', - dest='shell', - help='Emit completion code for bash') + "--zsh", + "-z", + action="store_const", + const="zsh", + dest="shell", + help="Emit completion code for zsh", + ) self.cmd_opts.add_option( - '--zsh', '-z', - action='store_const', - const='zsh', - dest='shell', - help='Emit completion code for zsh') + "--fish", + "-f", + action="store_const", + const="fish", + dest="shell", + help="Emit completion code for fish", + ) self.cmd_opts.add_option( - '--fish', '-f', - action='store_const', - const='fish', - dest='shell', - help='Emit completion code for fish') + "--powershell", + "-p", + action="store_const", + const="powershell", + dest="shell", + help="Emit completion code for powershell", + ) self.parser.insert_option_group(0, self.cmd_opts) - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: """Prints the completion code of the given shell""" shells = COMPLETION_SCRIPTS.keys() - shell_options = ['--' + shell for shell in sorted(shells)] + shell_options = ["--" + shell for shell in sorted(shells)] if options.shell in shells: script = textwrap.dedent( - COMPLETION_SCRIPTS.get(options.shell, '').format( - prog=get_prog()) + COMPLETION_SCRIPTS.get(options.shell, "").format(prog=get_prog()) ) print(BASE_COMPLETION.format(script=script, shell=options.shell)) return SUCCESS else: sys.stderr.write( - 'ERROR: You must pass {}\n' .format(' or '.join(shell_options)) + "ERROR: You must pass {}\n".format(" or ".join(shell_options)) ) return SUCCESS diff --git a/env/Lib/site-packages/pip/_internal/commands/configuration.py b/env/Lib/site-packages/pip/_internal/commands/configuration.py index e13f7142..84b134e4 100644 --- a/env/Lib/site-packages/pip/_internal/commands/configuration.py +++ b/env/Lib/site-packages/pip/_internal/commands/configuration.py @@ -27,14 +27,20 @@ class ConfigurationCommand(Command): - list: List the active configuration (or from the file specified) - edit: Edit the configuration file in an editor - - get: Get the value associated with name - - set: Set the name=value - - unset: Unset the value associated with name + - get: Get the value associated with command.option + - set: Set the command.option=value + - unset: Unset the value associated with command.option - debug: List the configuration files and values defined under them + Configuration keys should be dot separated command and option name, + with the special prefix "global" affecting any command. For example, + "pip config set global.index-url https://example.org/" would configure + the index url for all commands, but "pip config set download.timeout 10" + would configure a 10 second timeout only for "pip download" commands. + If none of --user, --global and --site are passed, a virtual environment configuration file is used if one is active and the file - exists. Otherwise, all modifications happen on the to the user file by + exists. Otherwise, all modifications happen to the user file by default. """ @@ -43,53 +49,51 @@ class ConfigurationCommand(Command): %prog [<file-option>] list %prog [<file-option>] [--editor <editor-path>] edit - %prog [<file-option>] get name - %prog [<file-option>] set name value - %prog [<file-option>] unset name + %prog [<file-option>] get command.option + %prog [<file-option>] set command.option value + %prog [<file-option>] unset command.option %prog [<file-option>] debug """ - def add_options(self): - # type: () -> None + def add_options(self) -> None: self.cmd_opts.add_option( - '--editor', - dest='editor', - action='store', + "--editor", + dest="editor", + action="store", default=None, help=( - 'Editor to use to edit the file. Uses VISUAL or EDITOR ' - 'environment variables if not provided.' - ) + "Editor to use to edit the file. Uses VISUAL or EDITOR " + "environment variables if not provided." + ), ) self.cmd_opts.add_option( - '--global', - dest='global_file', - action='store_true', + "--global", + dest="global_file", + action="store_true", default=False, - help='Use the system-wide configuration file only' + help="Use the system-wide configuration file only", ) self.cmd_opts.add_option( - '--user', - dest='user_file', - action='store_true', + "--user", + dest="user_file", + action="store_true", default=False, - help='Use the user configuration file only' + help="Use the user configuration file only", ) self.cmd_opts.add_option( - '--site', - dest='site_file', - action='store_true', + "--site", + dest="site_file", + action="store_true", default=False, - help='Use the current environment configuration file only' + help="Use the current environment configuration file only", ) self.parser.insert_option_group(0, self.cmd_opts) - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: handlers = { "list": self.list_values, "edit": self.open_in_editor, @@ -134,13 +138,16 @@ class ConfigurationCommand(Command): return SUCCESS - def _determine_file(self, options, need_value): - # type: (Values, bool) -> Optional[Kind] - file_options = [key for key, value in ( - (kinds.USER, options.user_file), - (kinds.GLOBAL, options.global_file), - (kinds.SITE, options.site_file), - ) if value] + def _determine_file(self, options: Values, need_value: bool) -> Optional[Kind]: + file_options = [ + key + for key, value in ( + (kinds.USER, options.user_file), + (kinds.GLOBAL, options.global_file), + (kinds.SITE, options.site_file), + ) + if value + ] if not file_options: if not need_value: @@ -161,36 +168,31 @@ class ConfigurationCommand(Command): "(--user, --site, --global) to perform." ) - def list_values(self, options, args): - # type: (Values, List[str]) -> None + def list_values(self, options: Values, args: List[str]) -> None: self._get_n_args(args, "list", n=0) for key, value in sorted(self.configuration.items()): write_output("%s=%r", key, value) - def get_name(self, options, args): - # type: (Values, List[str]) -> None + def get_name(self, options: Values, args: List[str]) -> None: key = self._get_n_args(args, "get [name]", n=1) value = self.configuration.get_value(key) write_output("%s", value) - def set_name_value(self, options, args): - # type: (Values, List[str]) -> None + def set_name_value(self, options: Values, args: List[str]) -> None: key, value = self._get_n_args(args, "set [name] [value]", n=2) self.configuration.set_value(key, value) self._save_configuration() - def unset_name(self, options, args): - # type: (Values, List[str]) -> None + def unset_name(self, options: Values, args: List[str]) -> None: key = self._get_n_args(args, "unset [name]", n=1) self.configuration.unset_value(key) self._save_configuration() - def list_config_values(self, options, args): - # type: (Values, List[str]) -> None + def list_config_values(self, options: Values, args: List[str]) -> None: """List config key-value pairs across different config files""" self._get_n_args(args, "debug", n=0) @@ -202,51 +204,53 @@ class ConfigurationCommand(Command): for fname in files: with indent_log(): file_exists = os.path.exists(fname) - write_output("%s, exists: %r", - fname, file_exists) + write_output("%s, exists: %r", fname, file_exists) if file_exists: self.print_config_file_values(variant) - def print_config_file_values(self, variant): - # type: (Kind) -> None + def print_config_file_values(self, variant: Kind) -> None: """Get key-value pairs from the file of a variant""" - for name, value in self.configuration.\ - get_values_in_config(variant).items(): + for name, value in self.configuration.get_values_in_config(variant).items(): with indent_log(): write_output("%s: %s", name, value) - def print_env_var_values(self): - # type: () -> None + def print_env_var_values(self) -> None: """Get key-values pairs present as environment variables""" - write_output("%s:", 'env_var') + write_output("%s:", "env_var") with indent_log(): for key, value in sorted(self.configuration.get_environ_vars()): - env_var = f'PIP_{key.upper()}' + env_var = f"PIP_{key.upper()}" write_output("%s=%r", env_var, value) - def open_in_editor(self, options, args): - # type: (Values, List[str]) -> None + def open_in_editor(self, options: Values, args: List[str]) -> None: editor = self._determine_editor(options) fname = self.configuration.get_file_to_edit() if fname is None: raise PipError("Could not determine appropriate file.") + elif '"' in fname: + # This shouldn't happen, unless we see a username like that. + # If that happens, we'd appreciate a pull request fixing this. + raise PipError( + f'Can not open an editor for a file name containing "\n{fname}' + ) try: - subprocess.check_call([editor, fname]) + subprocess.check_call(f'{editor} "{fname}"', shell=True) + except FileNotFoundError as e: + if not e.filename: + e.filename = editor + raise except subprocess.CalledProcessError as e: raise PipError( - "Editor Subprocess exited with exit code {}" - .format(e.returncode) + "Editor Subprocess exited with exit code {}".format(e.returncode) ) - def _get_n_args(self, args, example, n): - # type: (List[str], str, int) -> Any - """Helper to make sure the command got the right number of arguments - """ + def _get_n_args(self, args: List[str], example: str, n: int) -> Any: + """Helper to make sure the command got the right number of arguments""" if len(args) != n: msg = ( - 'Got unexpected number of arguments, expected {}. ' + "Got unexpected number of arguments, expected {}. " '(example: "{} config {}")' ).format(n, get_prog(), example) raise PipError(msg) @@ -256,8 +260,7 @@ class ConfigurationCommand(Command): else: return args - def _save_configuration(self): - # type: () -> None + def _save_configuration(self) -> None: # We successfully ran a modifying command. Need to save the # configuration. try: @@ -268,8 +271,7 @@ class ConfigurationCommand(Command): ) raise PipError("Internal Error.") - def _determine_editor(self, options): - # type: (Values) -> str + def _determine_editor(self, options: Values) -> str: if options.editor is not None: return options.editor elif "VISUAL" in os.environ: diff --git a/env/Lib/site-packages/pip/_internal/commands/debug.py b/env/Lib/site-packages/pip/_internal/commands/debug.py index ead5119a..2a3e7d29 100644 --- a/env/Lib/site-packages/pip/_internal/commands/debug.py +++ b/env/Lib/site-packages/pip/_internal/commands/debug.py @@ -1,3 +1,4 @@ +import importlib.resources import locale import logging import os @@ -10,7 +11,6 @@ import pip._vendor from pip._vendor.certifi import where from pip._vendor.packaging.version import parse as parse_version -from pip import __file__ as pip_location from pip._internal.cli import cmdoptions from pip._internal.cli.base_command import Command from pip._internal.cli.cmdoptions import make_target_python @@ -23,61 +23,47 @@ from pip._internal.utils.misc import get_pip_version logger = logging.getLogger(__name__) -def show_value(name, value): - # type: (str, Any) -> None - logger.info('%s: %s', name, value) +def show_value(name: str, value: Any) -> None: + logger.info("%s: %s", name, value) -def show_sys_implementation(): - # type: () -> None - logger.info('sys.implementation:') +def show_sys_implementation() -> None: + logger.info("sys.implementation:") implementation_name = sys.implementation.name with indent_log(): - show_value('name', implementation_name) + show_value("name", implementation_name) -def create_vendor_txt_map(): - # type: () -> Dict[str, str] - vendor_txt_path = os.path.join( - os.path.dirname(pip_location), - '_vendor', - 'vendor.txt' - ) - - with open(vendor_txt_path) as f: +def create_vendor_txt_map() -> Dict[str, str]: + with importlib.resources.open_text("pip._vendor", "vendor.txt") as f: # Purge non version specifying lines. # Also, remove any space prefix or suffixes (including comments). - lines = [line.strip().split(' ', 1)[0] - for line in f.readlines() if '==' in line] + lines = [ + line.strip().split(" ", 1)[0] for line in f.readlines() if "==" in line + ] # Transform into "module" -> version dict. - return dict(line.split('==', 1) for line in lines) # type: ignore + return dict(line.split("==", 1) for line in lines) -def get_module_from_module_name(module_name): - # type: (str) -> ModuleType +def get_module_from_module_name(module_name: str) -> ModuleType: # Module name can be uppercase in vendor.txt for some reason... - module_name = module_name.lower() + module_name = module_name.lower().replace("-", "_") # PATCH: setuptools is actually only pkg_resources. - if module_name == 'setuptools': - module_name = 'pkg_resources' - - __import__( - f'pip._vendor.{module_name}', - globals(), - locals(), - level=0 - ) + if module_name == "setuptools": + module_name = "pkg_resources" + + __import__(f"pip._vendor.{module_name}", globals(), locals(), level=0) return getattr(pip._vendor, module_name) -def get_vendor_version_from_module(module_name): - # type: (str) -> Optional[str] +def get_vendor_version_from_module(module_name: str) -> Optional[str]: module = get_module_from_module_name(module_name) - version = getattr(module, '__version__', None) + version = getattr(module, "__version__", None) if not version: # Try to find version in debundled module info. + assert module.__file__ is not None env = get_environment([os.path.dirname(module.__file__)]) dist = env.get_distribution(module_name) if dist: @@ -86,35 +72,36 @@ def get_vendor_version_from_module(module_name): return version -def show_actual_vendor_versions(vendor_txt_versions): - # type: (Dict[str, str]) -> None +def show_actual_vendor_versions(vendor_txt_versions: Dict[str, str]) -> None: """Log the actual version and print extra info if there is a conflict or if the actual version could not be imported. """ for module_name, expected_version in vendor_txt_versions.items(): - extra_message = '' + extra_message = "" actual_version = get_vendor_version_from_module(module_name) if not actual_version: - extra_message = ' (Unable to locate actual module version, using'\ - ' vendor.txt specified version)' + extra_message = ( + " (Unable to locate actual module version, using" + " vendor.txt specified version)" + ) actual_version = expected_version elif parse_version(actual_version) != parse_version(expected_version): - extra_message = ' (CONFLICT: vendor.txt suggests version should'\ - ' be {})'.format(expected_version) - logger.info('%s==%s%s', module_name, actual_version, extra_message) + extra_message = ( + " (CONFLICT: vendor.txt suggests version should" + " be {})".format(expected_version) + ) + logger.info("%s==%s%s", module_name, actual_version, extra_message) -def show_vendor_versions(): - # type: () -> None - logger.info('vendored library versions:') +def show_vendor_versions() -> None: + logger.info("vendored library versions:") vendor_txt_versions = create_vendor_txt_map() with indent_log(): show_actual_vendor_versions(vendor_txt_versions) -def show_tags(options): - # type: (Values) -> None +def show_tags(options: Values) -> None: tag_limit = 10 target_python = make_target_python(options) @@ -122,11 +109,11 @@ def show_tags(options): # Display the target options that were explicitly provided. formatted_target = target_python.format_given() - suffix = '' + suffix = "" if formatted_target: - suffix = f' (target: {formatted_target})' + suffix = f" (target: {formatted_target})" - msg = 'Compatible tags: {}{}'.format(len(tags), suffix) + msg = "Compatible tags: {}{}".format(len(tags), suffix) logger.info(msg) if options.verbose < 1 and len(tags) > tag_limit: @@ -141,30 +128,28 @@ def show_tags(options): if tags_limited: msg = ( - '...\n' - '[First {tag_limit} tags shown. Pass --verbose to show all.]' + "...\n[First {tag_limit} tags shown. Pass --verbose to show all.]" ).format(tag_limit=tag_limit) logger.info(msg) -def ca_bundle_info(config): - # type: (Configuration) -> str +def ca_bundle_info(config: Configuration) -> str: levels = set() for key, _ in config.items(): - levels.add(key.split('.')[0]) + levels.add(key.split(".")[0]) if not levels: return "Not specified" - levels_that_override_global = ['install', 'wheel', 'download'] + levels_that_override_global = ["install", "wheel", "download"] global_overriding_level = [ level for level in levels if level in levels_that_override_global ] if not global_overriding_level: - return 'global' + return "global" - if 'global' in levels: - levels.remove('global') + if "global" in levels: + levels.remove("global") return ", ".join(levels) @@ -177,34 +162,33 @@ class DebugCommand(Command): %prog <options>""" ignore_require_venv = True - def add_options(self): - # type: () -> None + def add_options(self) -> None: cmdoptions.add_target_python_options(self.cmd_opts) self.parser.insert_option_group(0, self.cmd_opts) self.parser.config.load() - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: logger.warning( "This command is only meant for debugging. " "Do not use this with automation for parsing and getting these " "details, since the output and options of this command may " "change without notice." ) - show_value('pip version', get_pip_version()) - show_value('sys.version', sys.version) - show_value('sys.executable', sys.executable) - show_value('sys.getdefaultencoding', sys.getdefaultencoding()) - show_value('sys.getfilesystemencoding', sys.getfilesystemencoding()) + show_value("pip version", get_pip_version()) + show_value("sys.version", sys.version) + show_value("sys.executable", sys.executable) + show_value("sys.getdefaultencoding", sys.getdefaultencoding()) + show_value("sys.getfilesystemencoding", sys.getfilesystemencoding()) show_value( - 'locale.getpreferredencoding', locale.getpreferredencoding(), + "locale.getpreferredencoding", + locale.getpreferredencoding(), ) - show_value('sys.platform', sys.platform) + show_value("sys.platform", sys.platform) show_sys_implementation() show_value("'cert' config value", ca_bundle_info(self.parser.config)) - show_value("REQUESTS_CA_BUNDLE", os.environ.get('REQUESTS_CA_BUNDLE')) - show_value("CURL_CA_BUNDLE", os.environ.get('CURL_CA_BUNDLE')) + show_value("REQUESTS_CA_BUNDLE", os.environ.get("REQUESTS_CA_BUNDLE")) + show_value("CURL_CA_BUNDLE", os.environ.get("CURL_CA_BUNDLE")) show_value("pip._vendor.certifi.where()", where()) show_value("pip._vendor.DEBUNDLED", pip._vendor.DEBUNDLED) diff --git a/env/Lib/site-packages/pip/_internal/commands/download.py b/env/Lib/site-packages/pip/_internal/commands/download.py index 19f8d6c0..54247a78 100644 --- a/env/Lib/site-packages/pip/_internal/commands/download.py +++ b/env/Lib/site-packages/pip/_internal/commands/download.py @@ -7,7 +7,8 @@ from pip._internal.cli import cmdoptions from pip._internal.cli.cmdoptions import make_target_python from pip._internal.cli.req_command import RequirementCommand, with_cleanup from pip._internal.cli.status_codes import SUCCESS -from pip._internal.req.req_tracker import get_requirement_tracker +from pip._internal.operations.build.build_tracker import get_build_tracker +from pip._internal.req.req_install import check_legacy_setup_py_options from pip._internal.utils.misc import ensure_dir, normalize_path, write_output from pip._internal.utils.temp_dir import TempDirectory @@ -34,11 +35,9 @@ class DownloadCommand(RequirementCommand): %prog [options] <local project path> ... %prog [options] <archive url/path> ...""" - def add_options(self): - # type: () -> None + def add_options(self) -> None: self.cmd_opts.add_option(cmdoptions.constraints()) self.cmd_opts.add_option(cmdoptions.requirements()) - self.cmd_opts.add_option(cmdoptions.build_dir()) self.cmd_opts.add_option(cmdoptions.no_deps()) self.cmd_opts.add_option(cmdoptions.global_options()) self.cmd_opts.add_option(cmdoptions.no_binary()) @@ -51,14 +50,18 @@ class DownloadCommand(RequirementCommand): self.cmd_opts.add_option(cmdoptions.no_build_isolation()) self.cmd_opts.add_option(cmdoptions.use_pep517()) self.cmd_opts.add_option(cmdoptions.no_use_pep517()) + self.cmd_opts.add_option(cmdoptions.check_build_deps()) self.cmd_opts.add_option(cmdoptions.ignore_requires_python()) self.cmd_opts.add_option( - '-d', '--dest', '--destination-dir', '--destination-directory', - dest='download_dir', - metavar='dir', + "-d", + "--dest", + "--destination-dir", + "--destination-directory", + dest="download_dir", + metavar="dir", default=os.curdir, - help=("Download packages into <dir>."), + help="Download packages into <dir>.", ) cmdoptions.add_target_python_options(self.cmd_opts) @@ -72,9 +75,7 @@ class DownloadCommand(RequirementCommand): self.parser.insert_option_group(0, self.cmd_opts) @with_cleanup - def run(self, options, args): - # type: (Values, List[str]) -> int - + def run(self, options: Values, args: List[str]) -> int: options.ignore_installed = True # editable doesn't really make sense for `pip download`, but the bowels # of the RequirementSet code require that property. @@ -95,7 +96,7 @@ class DownloadCommand(RequirementCommand): ignore_requires_python=options.ignore_requires_python, ) - req_tracker = self.enter_context(get_requirement_tracker()) + build_tracker = self.enter_context(get_build_tracker()) directory = TempDirectory( delete=not options.no_clean, @@ -104,15 +105,17 @@ class DownloadCommand(RequirementCommand): ) reqs = self.get_requirements(args, options, finder, session) + check_legacy_setup_py_options(options, reqs) preparer = self.make_requirement_preparer( temp_build_dir=directory, options=options, - req_tracker=req_tracker, + build_tracker=build_tracker, session=session, finder=finder, download_dir=options.download_dir, use_user_site=False, + verbosity=self.verbosity, ) resolver = self.make_resolver( @@ -120,22 +123,25 @@ class DownloadCommand(RequirementCommand): finder=finder, options=options, ignore_requires_python=options.ignore_requires_python, + use_pep517=options.use_pep517, py_version_info=options.python_version, ) self.trace_basic_info(finder) - requirement_set = resolver.resolve( - reqs, check_supported_wheels=True - ) + requirement_set = resolver.resolve(reqs, check_supported_wheels=True) - downloaded = [] # type: List[str] + downloaded: List[str] = [] for req in requirement_set.requirements.values(): if req.satisfied_by is None: assert req.name is not None preparer.save_linked_requirement(req) downloaded.append(req.name) + + preparer.prepare_linked_requirements_more(requirement_set.requirements.values()) + requirement_set.warn_legacy_versions_and_specifiers() + if downloaded: - write_output('Successfully downloaded %s', ' '.join(downloaded)) + write_output("Successfully downloaded %s", " ".join(downloaded)) return SUCCESS diff --git a/env/Lib/site-packages/pip/_internal/commands/freeze.py b/env/Lib/site-packages/pip/_internal/commands/freeze.py index 430d1018..fd9d88a8 100644 --- a/env/Lib/site-packages/pip/_internal/commands/freeze.py +++ b/env/Lib/site-packages/pip/_internal/commands/freeze.py @@ -1,15 +1,25 @@ import sys from optparse import Values -from typing import List +from typing import AbstractSet, List from pip._internal.cli import cmdoptions from pip._internal.cli.base_command import Command from pip._internal.cli.status_codes import SUCCESS from pip._internal.operations.freeze import freeze from pip._internal.utils.compat import stdlib_pkgs -from pip._internal.utils.deprecation import deprecated -DEV_PKGS = {'pip', 'setuptools', 'distribute', 'wheel'} + +def _should_suppress_build_backends() -> bool: + return sys.version_info < (3, 12) + + +def _dev_pkgs() -> AbstractSet[str]: + pkgs = {"pip"} + + if _should_suppress_build_backends(): + pkgs |= {"setuptools", "distribute", "wheel"} + + return pkgs class FreezeCommand(Command): @@ -23,76 +33,70 @@ class FreezeCommand(Command): %prog [options]""" log_streams = ("ext://sys.stderr", "ext://sys.stderr") - def add_options(self): - # type: () -> None - self.cmd_opts.add_option( - '-r', '--requirement', - dest='requirements', - action='append', - default=[], - metavar='file', - help="Use the order in the given requirements file and its " - "comments when generating output. This option can be " - "used multiple times.") + def add_options(self) -> None: self.cmd_opts.add_option( - '-f', '--find-links', - dest='find_links', - action='append', + "-r", + "--requirement", + dest="requirements", + action="append", default=[], - metavar='URL', - help='URL for finding packages, which will be added to the ' - 'output.') + metavar="file", + help=( + "Use the order in the given requirements file and its " + "comments when generating output. This option can be " + "used multiple times." + ), + ) self.cmd_opts.add_option( - '-l', '--local', - dest='local', - action='store_true', + "-l", + "--local", + dest="local", + action="store_true", default=False, - help='If in a virtualenv that has global access, do not output ' - 'globally-installed packages.') + help=( + "If in a virtualenv that has global access, do not output " + "globally-installed packages." + ), + ) self.cmd_opts.add_option( - '--user', - dest='user', - action='store_true', + "--user", + dest="user", + action="store_true", default=False, - help='Only output packages installed in user-site.') + help="Only output packages installed in user-site.", + ) self.cmd_opts.add_option(cmdoptions.list_path()) self.cmd_opts.add_option( - '--all', - dest='freeze_all', - action='store_true', - help='Do not skip these packages in the output:' - ' {}'.format(', '.join(DEV_PKGS))) + "--all", + dest="freeze_all", + action="store_true", + help=( + "Do not skip these packages in the output:" + " {}".format(", ".join(_dev_pkgs())) + ), + ) self.cmd_opts.add_option( - '--exclude-editable', - dest='exclude_editable', - action='store_true', - help='Exclude editable package from output.') + "--exclude-editable", + dest="exclude_editable", + action="store_true", + help="Exclude editable package from output.", + ) self.cmd_opts.add_option(cmdoptions.list_exclude()) self.parser.insert_option_group(0, self.cmd_opts) - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: skip = set(stdlib_pkgs) if not options.freeze_all: - skip.update(DEV_PKGS) + skip.update(_dev_pkgs()) if options.excludes: skip.update(options.excludes) cmdoptions.check_list_path_option(options) - if options.find_links: - deprecated( - "--find-links option in pip freeze is deprecated.", - replacement=None, - gone_in="21.2", - issue=9069, - ) - for line in freeze( requirement=options.requirements, - find_links=options.find_links, local_only=options.local, user_only=options.user, paths=options.path, @@ -100,5 +104,5 @@ class FreezeCommand(Command): skip=skip, exclude_editable=options.exclude_editable, ): - sys.stdout.write(line + '\n') + sys.stdout.write(line + "\n") return SUCCESS diff --git a/env/Lib/site-packages/pip/_internal/commands/hash.py b/env/Lib/site-packages/pip/_internal/commands/hash.py index bca48dcc..042dac81 100644 --- a/env/Lib/site-packages/pip/_internal/commands/hash.py +++ b/env/Lib/site-packages/pip/_internal/commands/hash.py @@ -20,38 +20,39 @@ class HashCommand(Command): installs. """ - usage = '%prog [options] <file> ...' + usage = "%prog [options] <file> ..." ignore_require_venv = True - def add_options(self): - # type: () -> None + def add_options(self) -> None: self.cmd_opts.add_option( - '-a', '--algorithm', - dest='algorithm', + "-a", + "--algorithm", + dest="algorithm", choices=STRONG_HASHES, - action='store', + action="store", default=FAVORITE_HASH, - help='The hash algorithm to use: one of {}'.format( - ', '.join(STRONG_HASHES))) + help="The hash algorithm to use: one of {}".format( + ", ".join(STRONG_HASHES) + ), + ) self.parser.insert_option_group(0, self.cmd_opts) - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: if not args: self.parser.print_usage(sys.stderr) return ERROR algorithm = options.algorithm for path in args: - write_output('%s:\n--hash=%s:%s', - path, algorithm, _hash_of_file(path, algorithm)) + write_output( + "%s:\n--hash=%s:%s", path, algorithm, _hash_of_file(path, algorithm) + ) return SUCCESS -def _hash_of_file(path, algorithm): - # type: (str, str) -> str +def _hash_of_file(path: str, algorithm: str) -> str: """Return the hash digest of a file.""" - with open(path, 'rb') as archive: + with open(path, "rb") as archive: hash = hashlib.new(algorithm) for chunk in read_chunks(archive): hash.update(chunk) diff --git a/env/Lib/site-packages/pip/_internal/commands/help.py b/env/Lib/site-packages/pip/_internal/commands/help.py index 79d0eb49..62066318 100644 --- a/env/Lib/site-packages/pip/_internal/commands/help.py +++ b/env/Lib/site-packages/pip/_internal/commands/help.py @@ -13,8 +13,7 @@ class HelpCommand(Command): %prog <command>""" ignore_require_venv = True - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: from pip._internal.commands import ( commands_dict, create_command, @@ -34,7 +33,7 @@ class HelpCommand(Command): if guess: msg.append(f'maybe you meant "{guess}"') - raise CommandError(' - '.join(msg)) + raise CommandError(" - ".join(msg)) command = create_command(cmd_name) command.parser.print_help() diff --git a/env/Lib/site-packages/pip/_internal/commands/install.py b/env/Lib/site-packages/pip/_internal/commands/install.py index 6932f5a6..f6a30080 100644 --- a/env/Lib/site-packages/pip/_internal/commands/install.py +++ b/env/Lib/site-packages/pip/_internal/commands/install.py @@ -1,13 +1,13 @@ import errno -import logging +import json import operator import os import shutil import site from optparse import SUPPRESS_HELP, Values -from typing import Iterable, List, Optional +from typing import List, Optional -from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.rich import print_json from pip._internal.cache import WheelCache from pip._internal.cli import cmdoptions @@ -21,14 +21,19 @@ from pip._internal.cli.status_codes import ERROR, SUCCESS from pip._internal.exceptions import CommandError, InstallationError from pip._internal.locations import get_scheme from pip._internal.metadata import get_environment -from pip._internal.models.format_control import FormatControl +from pip._internal.models.installation_report import InstallationReport +from pip._internal.operations.build.build_tracker import get_build_tracker from pip._internal.operations.check import ConflictDetails, check_install_conflicts from pip._internal.req import install_given_reqs -from pip._internal.req.req_install import InstallRequirement -from pip._internal.req.req_tracker import get_requirement_tracker -from pip._internal.utils.distutils_args import parse_distutils_args +from pip._internal.req.req_install import ( + InstallRequirement, + check_legacy_setup_py_options, +) +from pip._internal.utils.compat import WINDOWS from pip._internal.utils.filesystem import test_writable_dir +from pip._internal.utils.logging import getLogger from pip._internal.utils.misc import ( + check_externally_managed, ensure_dir, get_pip_version, protect_pip_from_modification_on_windows, @@ -39,24 +44,9 @@ from pip._internal.utils.virtualenv import ( running_under_virtualenv, virtualenv_no_global, ) -from pip._internal.wheel_builder import ( - BinaryAllowedPredicate, - build, - should_build_for_install_command, -) - -logger = logging.getLogger(__name__) - +from pip._internal.wheel_builder import build, should_build_for_install_command -def get_check_binary_allowed(format_control): - # type: (FormatControl) -> BinaryAllowedPredicate - def check_binary_allowed(req): - # type: (InstallRequirement) -> bool - canonical_name = canonicalize_name(req.name or "") - allowed_formats = format_control.get_allowed_formats(canonical_name) - return "binary" in allowed_formats - - return check_binary_allowed +logger = getLogger(__name__) class InstallCommand(RequirementCommand): @@ -79,8 +69,7 @@ class InstallCommand(RequirementCommand): %prog [options] [-e] <local project path> ... %prog [options] <archive url/path> ...""" - def add_options(self): - # type: () -> None + def add_options(self) -> None: self.cmd_opts.add_option(cmdoptions.requirements()) self.cmd_opts.add_option(cmdoptions.constraints()) self.cmd_opts.add_option(cmdoptions.no_deps()) @@ -88,95 +77,129 @@ class InstallCommand(RequirementCommand): self.cmd_opts.add_option(cmdoptions.editable()) self.cmd_opts.add_option( - '-t', '--target', - dest='target_dir', - metavar='dir', + "--dry-run", + action="store_true", + dest="dry_run", + default=False, + help=( + "Don't actually install anything, just print what would be. " + "Can be used in combination with --ignore-installed " + "to 'resolve' the requirements." + ), + ) + self.cmd_opts.add_option( + "-t", + "--target", + dest="target_dir", + metavar="dir", default=None, - help='Install packages into <dir>. ' - 'By default this will not replace existing files/folders in ' - '<dir>. Use --upgrade to replace existing packages in <dir> ' - 'with new versions.' + help=( + "Install packages into <dir>. " + "By default this will not replace existing files/folders in " + "<dir>. Use --upgrade to replace existing packages in <dir> " + "with new versions." + ), ) cmdoptions.add_target_python_options(self.cmd_opts) self.cmd_opts.add_option( - '--user', - dest='use_user_site', - action='store_true', - help="Install to the Python user install directory for your " - "platform. Typically ~/.local/, or %APPDATA%\\Python on " - "Windows. (See the Python documentation for site.USER_BASE " - "for full details.)") + "--user", + dest="use_user_site", + action="store_true", + help=( + "Install to the Python user install directory for your " + "platform. Typically ~/.local/, or %APPDATA%\\Python on " + "Windows. (See the Python documentation for site.USER_BASE " + "for full details.)" + ), + ) self.cmd_opts.add_option( - '--no-user', - dest='use_user_site', - action='store_false', - help=SUPPRESS_HELP) + "--no-user", + dest="use_user_site", + action="store_false", + help=SUPPRESS_HELP, + ) self.cmd_opts.add_option( - '--root', - dest='root_path', - metavar='dir', + "--root", + dest="root_path", + metavar="dir", default=None, - help="Install everything relative to this alternate root " - "directory.") + help="Install everything relative to this alternate root directory.", + ) self.cmd_opts.add_option( - '--prefix', - dest='prefix_path', - metavar='dir', + "--prefix", + dest="prefix_path", + metavar="dir", default=None, - help="Installation prefix where lib, bin and other top-level " - "folders are placed") - - self.cmd_opts.add_option(cmdoptions.build_dir()) + help=( + "Installation prefix where lib, bin and other top-level " + "folders are placed. Note that the resulting installation may " + "contain scripts and other resources which reference the " + "Python interpreter of pip, and not that of ``--prefix``. " + "See also the ``--python`` option if the intention is to " + "install packages into another (possibly pip-free) " + "environment." + ), + ) self.cmd_opts.add_option(cmdoptions.src()) self.cmd_opts.add_option( - '-U', '--upgrade', - dest='upgrade', - action='store_true', - help='Upgrade all specified packages to the newest available ' - 'version. The handling of dependencies depends on the ' - 'upgrade-strategy used.' + "-U", + "--upgrade", + dest="upgrade", + action="store_true", + help=( + "Upgrade all specified packages to the newest available " + "version. The handling of dependencies depends on the " + "upgrade-strategy used." + ), ) self.cmd_opts.add_option( - '--upgrade-strategy', - dest='upgrade_strategy', - default='only-if-needed', - choices=['only-if-needed', 'eager'], - help='Determines how dependency upgrading should be handled ' - '[default: %default]. ' - '"eager" - dependencies are upgraded regardless of ' - 'whether the currently installed version satisfies the ' - 'requirements of the upgraded package(s). ' - '"only-if-needed" - are upgraded only when they do not ' - 'satisfy the requirements of the upgraded package(s).' + "--upgrade-strategy", + dest="upgrade_strategy", + default="only-if-needed", + choices=["only-if-needed", "eager"], + help=( + "Determines how dependency upgrading should be handled " + "[default: %default]. " + '"eager" - dependencies are upgraded regardless of ' + "whether the currently installed version satisfies the " + "requirements of the upgraded package(s). " + '"only-if-needed" - are upgraded only when they do not ' + "satisfy the requirements of the upgraded package(s)." + ), ) self.cmd_opts.add_option( - '--force-reinstall', - dest='force_reinstall', - action='store_true', - help='Reinstall all packages even if they are already ' - 'up-to-date.') + "--force-reinstall", + dest="force_reinstall", + action="store_true", + help="Reinstall all packages even if they are already up-to-date.", + ) self.cmd_opts.add_option( - '-I', '--ignore-installed', - dest='ignore_installed', - action='store_true', - help='Ignore the installed packages, overwriting them. ' - 'This can break your system if the existing package ' - 'is of a different version or was installed ' - 'with a different package manager!' + "-I", + "--ignore-installed", + dest="ignore_installed", + action="store_true", + help=( + "Ignore the installed packages, overwriting them. " + "This can break your system if the existing package " + "is of a different version or was installed " + "with a different package manager!" + ), ) self.cmd_opts.add_option(cmdoptions.ignore_requires_python()) self.cmd_opts.add_option(cmdoptions.no_build_isolation()) self.cmd_opts.add_option(cmdoptions.use_pep517()) self.cmd_opts.add_option(cmdoptions.no_use_pep517()) + self.cmd_opts.add_option(cmdoptions.check_build_deps()) + self.cmd_opts.add_option(cmdoptions.override_externally_managed()) - self.cmd_opts.add_option(cmdoptions.install_options()) + self.cmd_opts.add_option(cmdoptions.config_settings()) self.cmd_opts.add_option(cmdoptions.global_options()) self.cmd_opts.add_option( @@ -208,12 +231,12 @@ class InstallCommand(RequirementCommand): default=True, help="Do not warn about broken dependencies", ) - self.cmd_opts.add_option(cmdoptions.no_binary()) self.cmd_opts.add_option(cmdoptions.only_binary()) self.cmd_opts.add_option(cmdoptions.prefer_binary()) self.cmd_opts.add_option(cmdoptions.require_hashes()) self.cmd_opts.add_option(cmdoptions.progress_bar()) + self.cmd_opts.add_option(cmdoptions.root_user_action()) index_opts = cmdoptions.make_option_group( cmdoptions.index_group, @@ -223,22 +246,51 @@ class InstallCommand(RequirementCommand): self.parser.insert_option_group(0, index_opts) self.parser.insert_option_group(0, self.cmd_opts) + self.cmd_opts.add_option( + "--report", + dest="json_report_file", + metavar="file", + default=None, + help=( + "Generate a JSON file describing what pip did to install " + "the provided requirements. " + "Can be used in combination with --dry-run and --ignore-installed " + "to 'resolve' the requirements. " + "When - is used as file name it writes to stdout. " + "When writing to stdout, please combine with the --quiet option " + "to avoid mixing pip logging output with JSON output." + ), + ) + @with_cleanup - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: if options.use_user_site and options.target_dir is not None: raise CommandError("Can not combine '--user' and '--target'") - cmdoptions.check_install_build_global(options) + # Check whether the environment we're installing into is externally + # managed, as specified in PEP 668. Specifying --root, --target, or + # --prefix disables the check, since there's no reliable way to locate + # the EXTERNALLY-MANAGED file for those cases. An exception is also + # made specifically for "--dry-run --report" for convenience. + installing_into_current_environment = ( + not (options.dry_run and options.json_report_file) + and options.root_path is None + and options.target_dir is None + and options.prefix_path is None + ) + if ( + installing_into_current_environment + and not options.override_externally_managed + ): + check_externally_managed() + upgrade_strategy = "to-satisfy-only" if options.upgrade: upgrade_strategy = options.upgrade_strategy cmdoptions.check_dist_restriction(options, check_target=True) - install_options = options.install_options or [] - - logger.debug("Using %s", get_pip_version()) + logger.verbose("Using %s", get_pip_version()) options.use_user_site = decide_user_install( options.use_user_site, prefix_path=options.prefix_path, @@ -247,16 +299,19 @@ class InstallCommand(RequirementCommand): isolated_mode=options.isolated_mode, ) - target_temp_dir = None # type: Optional[TempDirectory] - target_temp_dir_path = None # type: Optional[str] + target_temp_dir: Optional[TempDirectory] = None + target_temp_dir_path: Optional[str] = None if options.target_dir: options.ignore_installed = True options.target_dir = os.path.abspath(options.target_dir) - if (os.path.exists(options.target_dir) and not - os.path.isdir(options.target_dir)): + if ( + # fmt: off + os.path.exists(options.target_dir) and + not os.path.isdir(options.target_dir) + # fmt: on + ): raise CommandError( - "Target path exists but is not a directory, will not " - "continue." + "Target path exists but is not a directory, will not continue." ) # Create a target directory for using with the target option @@ -275,9 +330,7 @@ class InstallCommand(RequirementCommand): target_python=target_python, ignore_requires_python=options.ignore_requires_python, ) - wheel_cache = WheelCache(options.cache_dir, options.format_control) - - req_tracker = self.enter_context(get_requirement_tracker()) + build_tracker = self.enter_context(get_build_tracker()) directory = TempDirectory( delete=not options.no_clean, @@ -287,18 +340,24 @@ class InstallCommand(RequirementCommand): try: reqs = self.get_requirements(args, options, finder, session) + check_legacy_setup_py_options(options, reqs) - reject_location_related_install_options( - reqs, options.install_options - ) + wheel_cache = WheelCache(options.cache_dir) + + # Only when installing is it permitted to use PEP 660. + # In other circumstances (pip wheel, pip download) we generate + # regular (i.e. non editable) metadata and wheels. + for req in reqs: + req.permit_editable_wheels = True preparer = self.make_requirement_preparer( temp_build_dir=directory, options=options, - req_tracker=req_tracker, + build_tracker=build_tracker, session=session, finder=finder, use_user_site=options.use_user_site, + verbosity=self.verbosity, ) resolver = self.make_resolver( preparer=preparer, @@ -319,6 +378,29 @@ class InstallCommand(RequirementCommand): reqs, check_supported_wheels=not options.target_dir ) + if options.json_report_file: + report = InstallationReport(requirement_set.requirements_to_install) + if options.json_report_file == "-": + print_json(data=report.to_dict()) + else: + with open(options.json_report_file, "w", encoding="utf-8") as f: + json.dump(report.to_dict(), f, indent=2, ensure_ascii=False) + + if options.dry_run: + # In non dry-run mode, the legacy versions and specifiers check + # will be done as part of conflict detection. + requirement_set.warn_legacy_versions_and_specifiers() + would_install_items = sorted( + (r.metadata["name"], r.metadata["version"]) + for r in requirement_set.requirements_to_install + ) + if would_install_items: + write_output( + "Would install %s", + " ".join("-".join(item) for item in would_install_items), + ) + return SUCCESS + try: pip_req = requirement_set.get_requirement("pip") except KeyError: @@ -327,19 +409,12 @@ class InstallCommand(RequirementCommand): # If we're not replacing an already installed pip, # we're not modifying it. modifying_pip = pip_req.satisfied_by is None - protect_pip_from_modification_on_windows( - modifying_pip=modifying_pip - ) - - check_binary_allowed = get_check_binary_allowed( - finder.format_control - ) + protect_pip_from_modification_on_windows(modifying_pip=modifying_pip) reqs_to_build = [ - r for r in requirement_set.requirements.values() - if should_build_for_install_command( - r, check_binary_allowed - ) + r + for r in requirement_set.requirements.values() + if should_build_for_install_command(r) ] _, build_failures = build( @@ -347,52 +422,35 @@ class InstallCommand(RequirementCommand): wheel_cache=wheel_cache, verify=True, build_options=[], - global_options=[], + global_options=global_options, ) - # If we're using PEP 517, we cannot do a direct install - # so we fail here. - pep517_build_failure_names = [ - r.name # type: ignore - for r in build_failures if r.use_pep517 - ] # type: List[str] - if pep517_build_failure_names: + if build_failures: raise InstallationError( - "Could not build wheels for {} which use" - " PEP 517 and cannot be installed directly".format( - ", ".join(pep517_build_failure_names) + "Could not build wheels for {}, which is required to " + "install pyproject.toml-based projects".format( + ", ".join(r.name for r in build_failures) # type: ignore ) ) - # For now, we just warn about failures building legacy - # requirements, as we'll fall through to a direct - # install for those. - for r in build_failures: - if not r.use_pep517: - r.legacy_install_reason = 8368 - - to_install = resolver.get_installation_order( - requirement_set - ) + to_install = resolver.get_installation_order(requirement_set) # Check for conflicts in the package set we're installing. - conflicts = None # type: Optional[ConflictDetails] + conflicts: Optional[ConflictDetails] = None should_warn_about_conflicts = ( - not options.ignore_dependencies and - options.warn_about_conflicts + not options.ignore_dependencies and options.warn_about_conflicts ) if should_warn_about_conflicts: conflicts = self._determine_conflicts(to_install) # Don't warn about script install locations if - # --target has been specified + # --target or --prefix has been specified warn_script_location = options.warn_script_location - if options.target_dir: + if options.target_dir or options.prefix_path: warn_script_location = False installed = install_given_reqs( to_install, - install_options, global_options, root=options.root_path, home=target_temp_dir_path, @@ -411,7 +469,7 @@ class InstallCommand(RequirementCommand): ) env = get_environment(lib_locations) - installed.sort(key=operator.attrgetter('name')) + installed.sort(key=operator.attrgetter("name")) items = [] for result in installed: item = result.name @@ -429,16 +487,19 @@ class InstallCommand(RequirementCommand): resolver_variant=self.determine_resolver_variant(options), ) - installed_desc = ' '.join(items) + installed_desc = " ".join(items) if installed_desc: write_output( - 'Successfully installed %s', installed_desc, + "Successfully installed %s", + installed_desc, ) except OSError as error: - show_traceback = (self.verbosity >= 1) + show_traceback = self.verbosity >= 1 message = create_os_error_message( - error, show_traceback, options.use_user_site, + error, + show_traceback, + options.use_user_site, ) logger.error(message, exc_info=show_traceback) # noqa @@ -449,12 +510,13 @@ class InstallCommand(RequirementCommand): self._handle_target_dir( options.target_dir, target_temp_dir, options.upgrade ) - - warn_if_run_as_root() + if options.root_user_action == "warn": + warn_if_run_as_root() return SUCCESS - def _handle_target_dir(self, target_dir, target_temp_dir, upgrade): - # type: (str, TempDirectory, bool) -> None + def _handle_target_dir( + self, target_dir: str, target_temp_dir: TempDirectory, upgrade: bool + ) -> None: ensure_dir(target_dir) # Checking both purelib and platlib directories for installed @@ -463,7 +525,7 @@ class InstallCommand(RequirementCommand): # Checking both purelib and platlib directories for installed # packages to be moved to target directory - scheme = get_scheme('', home=target_temp_dir.path) + scheme = get_scheme("", home=target_temp_dir.path) purelib_dir = scheme.purelib platlib_dir = scheme.platlib data_dir = scheme.data @@ -485,18 +547,18 @@ class InstallCommand(RequirementCommand): if os.path.exists(target_item_dir): if not upgrade: logger.warning( - 'Target directory %s already exists. Specify ' - '--upgrade to force replacement.', - target_item_dir + "Target directory %s already exists. Specify " + "--upgrade to force replacement.", + target_item_dir, ) continue if os.path.islink(target_item_dir): logger.warning( - 'Target directory %s already exists and is ' - 'a link. pip will not automatically replace ' - 'links, please remove if replacement is ' - 'desired.', - target_item_dir + "Target directory %s already exists and is " + "a link. pip will not automatically replace " + "links, please remove if replacement is " + "desired.", + target_item_dir, ) continue if os.path.isdir(target_item_dir): @@ -504,13 +566,11 @@ class InstallCommand(RequirementCommand): else: os.remove(target_item_dir) - shutil.move( - os.path.join(lib_dir, item), - target_item_dir - ) + shutil.move(os.path.join(lib_dir, item), target_item_dir) - def _determine_conflicts(self, to_install): - # type: (List[InstallRequirement]) -> Optional[ConflictDetails] + def _determine_conflicts( + self, to_install: List[InstallRequirement] + ) -> Optional[ConflictDetails]: try: return check_install_conflicts(to_install) except Exception: @@ -520,13 +580,14 @@ class InstallCommand(RequirementCommand): ) return None - def _warn_about_conflicts(self, conflict_details, resolver_variant): - # type: (ConflictDetails, str) -> None + def _warn_about_conflicts( + self, conflict_details: ConflictDetails, resolver_variant: str + ) -> None: package_set, (missing, conflicting) = conflict_details if not missing and not conflicting: return - parts = [] # type: List[str] + parts: List[str] = [] if resolver_variant == "legacy": parts.append( "pip's legacy dependency resolver does not consider dependency " @@ -567,7 +628,7 @@ class InstallCommand(RequirementCommand): requirement=req, dep_name=dep_name, dep_version=dep_version, - you=("you" if resolver_variant == "2020-resolver" else "you'll") + you=("you" if resolver_variant == "2020-resolver" else "you'll"), ) parts.append(message) @@ -575,15 +636,14 @@ class InstallCommand(RequirementCommand): def get_lib_location_guesses( - user=False, # type: bool - home=None, # type: Optional[str] - root=None, # type: Optional[str] - isolated=False, # type: bool - prefix=None # type: Optional[str] -): - # type:(...) -> List[str] + user: bool = False, + home: Optional[str] = None, + root: Optional[str] = None, + isolated: bool = False, + prefix: Optional[str] = None, +) -> List[str]: scheme = get_scheme( - '', + "", user=user, home=home, root=root, @@ -593,22 +653,20 @@ def get_lib_location_guesses( return [scheme.purelib, scheme.platlib] -def site_packages_writable(root, isolated): - # type: (Optional[str], bool) -> bool +def site_packages_writable(root: Optional[str], isolated: bool) -> bool: return all( - test_writable_dir(d) for d in set( - get_lib_location_guesses(root=root, isolated=isolated)) + test_writable_dir(d) + for d in set(get_lib_location_guesses(root=root, isolated=isolated)) ) def decide_user_install( - use_user_site, # type: Optional[bool] - prefix_path=None, # type: Optional[str] - target_dir=None, # type: Optional[str] - root_path=None, # type: Optional[str] - isolated_mode=False, # type: bool -): - # type: (...) -> bool + use_user_site: Optional[bool], + prefix_path: Optional[str] = None, + target_dir: Optional[str] = None, + root_path: Optional[str] = None, + isolated_mode: bool = False, +) -> bool: """Determine whether to do a user install based on the input options. If use_user_site is False, no additional checks are done. @@ -656,55 +714,16 @@ def decide_user_install( logger.debug("Non-user install because site-packages writeable") return False - logger.info("Defaulting to user installation because normal site-packages " - "is not writeable") - return True - - -def reject_location_related_install_options(requirements, options): - # type: (List[InstallRequirement], Optional[List[str]]) -> None - """If any location-changing --install-option arguments were passed for - requirements or on the command-line, then show a deprecation warning. - """ - def format_options(option_names): - # type: (Iterable[str]) -> List[str] - return ["--{}".format(name.replace("_", "-")) for name in option_names] - - offenders = [] - - for requirement in requirements: - install_options = requirement.install_options - location_options = parse_distutils_args(install_options) - if location_options: - offenders.append( - "{!r} from {}".format( - format_options(location_options.keys()), requirement - ) - ) - - if options: - location_options = parse_distutils_args(options) - if location_options: - offenders.append( - "{!r} from command line".format( - format_options(location_options.keys()) - ) - ) - - if not offenders: - return - - raise CommandError( - "Location-changing options found in --install-option: {}." - " This is unsupported, use pip-level options like --user," - " --prefix, --root, and --target instead.".format( - "; ".join(offenders) - ) + logger.info( + "Defaulting to user installation because normal site-packages " + "is not writeable" ) + return True -def create_os_error_message(error, show_traceback, using_user_site): - # type: (OSError, bool, bool) -> str +def create_os_error_message( + error: OSError, show_traceback: bool, using_user_site: bool +) -> str: """Format an error message for an OSError It may occur anytime during the execution of the install command. @@ -729,12 +748,31 @@ def create_os_error_message(error, show_traceback, using_user_site): permissions_part = "Check the permissions" if not running_under_virtualenv() and not using_user_site: - parts.extend([ - user_option_part, " or ", - permissions_part.lower(), - ]) + parts.extend( + [ + user_option_part, + " or ", + permissions_part.lower(), + ] + ) else: parts.append(permissions_part) parts.append(".\n") + # Suggest the user to enable Long Paths if path length is + # more than 260 + if ( + WINDOWS + and error.errno == errno.ENOENT + and error.filename + and len(error.filename) > 260 + ): + parts.append( + "HINT: This error might have occurred since " + "this system does not have Windows Long Path " + "support enabled. You can find information on " + "how to enable this at " + "https://pip.pypa.io/warnings/enable-long-paths\n" + ) + return "".join(parts).strip() + "\n" diff --git a/env/Lib/site-packages/pip/_internal/commands/list.py b/env/Lib/site-packages/pip/_internal/commands/list.py index dcf94326..ac103531 100644 --- a/env/Lib/site-packages/pip/_internal/commands/list.py +++ b/env/Lib/site-packages/pip/_internal/commands/list.py @@ -1,9 +1,9 @@ import json import logging from optparse import Values -from typing import Iterator, List, Set, Tuple +from typing import TYPE_CHECKING, Generator, List, Optional, Sequence, Tuple, cast -from pip._vendor.pkg_resources import Distribution +from pip._vendor.packaging.utils import canonicalize_name from pip._internal.cli import cmdoptions from pip._internal.cli.req_command import IndexGroupCommand @@ -11,17 +11,27 @@ from pip._internal.cli.status_codes import SUCCESS from pip._internal.exceptions import CommandError from pip._internal.index.collector import LinkCollector from pip._internal.index.package_finder import PackageFinder +from pip._internal.metadata import BaseDistribution, get_environment from pip._internal.models.selection_prefs import SelectionPreferences from pip._internal.network.session import PipSession from pip._internal.utils.compat import stdlib_pkgs -from pip._internal.utils.misc import ( - dist_is_editable, - get_installed_distributions, - tabulate, - write_output, -) -from pip._internal.utils.packaging import get_installer -from pip._internal.utils.parallel import map_multithread +from pip._internal.utils.misc import tabulate, write_output + +if TYPE_CHECKING: + from pip._internal.metadata.base import DistributionVersion + + class _DistWithLatestInfo(BaseDistribution): + """Give the distribution object a couple of extra fields. + + These will be populated during ``get_outdated()``. This is dirty but + makes the rest of the code much cleaner. + """ + + latest_version: DistributionVersion + latest_filetype: str + + _ProcessedDists = Sequence[_DistWithLatestInfo] + logger = logging.getLogger(__name__) @@ -37,86 +47,97 @@ class ListCommand(IndexGroupCommand): usage = """ %prog [options]""" - def add_options(self): - # type: () -> None + def add_options(self) -> None: self.cmd_opts.add_option( - '-o', '--outdated', - action='store_true', + "-o", + "--outdated", + action="store_true", default=False, - help='List outdated packages') + help="List outdated packages", + ) self.cmd_opts.add_option( - '-u', '--uptodate', - action='store_true', + "-u", + "--uptodate", + action="store_true", default=False, - help='List uptodate packages') + help="List uptodate packages", + ) self.cmd_opts.add_option( - '-e', '--editable', - action='store_true', + "-e", + "--editable", + action="store_true", default=False, - help='List editable projects.') + help="List editable projects.", + ) self.cmd_opts.add_option( - '-l', '--local', - action='store_true', + "-l", + "--local", + action="store_true", default=False, - help=('If in a virtualenv that has global access, do not list ' - 'globally-installed packages.'), + help=( + "If in a virtualenv that has global access, do not list " + "globally-installed packages." + ), ) self.cmd_opts.add_option( - '--user', - dest='user', - action='store_true', + "--user", + dest="user", + action="store_true", default=False, - help='Only output packages installed in user-site.') + help="Only output packages installed in user-site.", + ) self.cmd_opts.add_option(cmdoptions.list_path()) self.cmd_opts.add_option( - '--pre', - action='store_true', + "--pre", + action="store_true", default=False, - help=("Include pre-release and development versions. By default, " - "pip only finds stable versions."), + help=( + "Include pre-release and development versions. By default, " + "pip only finds stable versions." + ), ) self.cmd_opts.add_option( - '--format', - action='store', - dest='list_format', + "--format", + action="store", + dest="list_format", default="columns", - choices=('columns', 'freeze', 'json'), - help="Select the output format among: columns (default), freeze, " - "or json", + choices=("columns", "freeze", "json"), + help=( + "Select the output format among: columns (default), freeze, or json. " + "The 'freeze' format cannot be used with the --outdated option." + ), ) self.cmd_opts.add_option( - '--not-required', - action='store_true', - dest='not_required', - help="List packages that are not dependencies of " - "installed packages.", + "--not-required", + action="store_true", + dest="not_required", + help="List packages that are not dependencies of installed packages.", ) self.cmd_opts.add_option( - '--exclude-editable', - action='store_false', - dest='include_editable', - help='Exclude editable package from output.', + "--exclude-editable", + action="store_false", + dest="include_editable", + help="Exclude editable package from output.", ) self.cmd_opts.add_option( - '--include-editable', - action='store_true', - dest='include_editable', - help='Include editable package from output.', + "--include-editable", + action="store_true", + dest="include_editable", + help="Include editable package from output.", default=True, ) self.cmd_opts.add_option(cmdoptions.list_exclude()) - index_opts = cmdoptions.make_option_group( - cmdoptions.index_group, self.parser - ) + index_opts = cmdoptions.make_option_group(cmdoptions.index_group, self.parser) self.parser.insert_option_group(0, index_opts) self.parser.insert_option_group(0, self.cmd_opts) - def _build_package_finder(self, options, session): - # type: (Values, PipSession) -> PackageFinder + def _build_package_finder( + self, options: Values, session: PipSession + ) -> PackageFinder: """ Create a package finder appropriate to this list command. """ @@ -133,26 +154,31 @@ class ListCommand(IndexGroupCommand): selection_prefs=selection_prefs, ) - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: if options.outdated and options.uptodate: + raise CommandError("Options --outdated and --uptodate cannot be combined.") + + if options.outdated and options.list_format == "freeze": raise CommandError( - "Options --outdated and --uptodate cannot be combined.") + "List format 'freeze' cannot be used with the --outdated option." + ) cmdoptions.check_list_path_option(options) skip = set(stdlib_pkgs) if options.excludes: - skip.update(options.excludes) - - packages = get_installed_distributions( - local_only=options.local, - user_only=options.user, - editables_only=options.editable, - include_editables=options.include_editable, - paths=options.path, - skip=skip, - ) + skip.update(canonicalize_name(n) for n in options.excludes) + + packages: "_ProcessedDists" = [ + cast("_DistWithLatestInfo", d) + for d in get_environment(options.path).iter_installed_distributions( + local_only=options.local, + user_only=options.user, + editables_only=options.editable, + include_editables=options.include_editable, + skip=skip, + ) + ] # get_not_required must be called firstly in order to find and # filter out all dependencies correctly. Otherwise a package @@ -169,46 +195,58 @@ class ListCommand(IndexGroupCommand): self.output_package_listing(packages, options) return SUCCESS - def get_outdated(self, packages, options): - # type: (List[Distribution], Values) -> List[Distribution] + def get_outdated( + self, packages: "_ProcessedDists", options: Values + ) -> "_ProcessedDists": return [ - dist for dist in self.iter_packages_latest_infos(packages, options) - if dist.latest_version > dist.parsed_version + dist + for dist in self.iter_packages_latest_infos(packages, options) + if dist.latest_version > dist.version ] - def get_uptodate(self, packages, options): - # type: (List[Distribution], Values) -> List[Distribution] + def get_uptodate( + self, packages: "_ProcessedDists", options: Values + ) -> "_ProcessedDists": return [ - dist for dist in self.iter_packages_latest_infos(packages, options) - if dist.latest_version == dist.parsed_version + dist + for dist in self.iter_packages_latest_infos(packages, options) + if dist.latest_version == dist.version ] - def get_not_required(self, packages, options): - # type: (List[Distribution], Values) -> List[Distribution] - dep_keys = set() # type: Set[Distribution] - for dist in packages: - dep_keys.update(requirement.key for requirement in dist.requires()) + def get_not_required( + self, packages: "_ProcessedDists", options: Values + ) -> "_ProcessedDists": + dep_keys = { + canonicalize_name(dep.name) + for dist in packages + for dep in (dist.iter_dependencies() or ()) + } # Create a set to remove duplicate packages, and cast it to a list # to keep the return type consistent with get_outdated and # get_uptodate - return list({pkg for pkg in packages if pkg.key not in dep_keys}) + return list({pkg for pkg in packages if pkg.canonical_name not in dep_keys}) - def iter_packages_latest_infos(self, packages, options): - # type: (List[Distribution], Values) -> Iterator[Distribution] + def iter_packages_latest_infos( + self, packages: "_ProcessedDists", options: Values + ) -> Generator["_DistWithLatestInfo", None, None]: with self._build_session(options) as session: finder = self._build_package_finder(options, session) - def latest_info(dist): - # type: (Distribution) -> Distribution - all_candidates = finder.find_all_candidates(dist.key) + def latest_info( + dist: "_DistWithLatestInfo", + ) -> Optional["_DistWithLatestInfo"]: + all_candidates = finder.find_all_candidates(dist.canonical_name) if not options.pre: # Remove prereleases - all_candidates = [candidate for candidate in all_candidates - if not candidate.version.is_prerelease] + all_candidates = [ + candidate + for candidate in all_candidates + if not candidate.version.is_prerelease + ] evaluator = finder.make_candidate_evaluator( - project_name=dist.project_name, + project_name=dist.canonical_name, ) best_candidate = evaluator.sort_best_candidate(all_candidates) if best_candidate is None: @@ -216,39 +254,41 @@ class ListCommand(IndexGroupCommand): remote_version = best_candidate.version if best_candidate.link.is_wheel: - typ = 'wheel' + typ = "wheel" else: - typ = 'sdist' - # This is dirty but makes the rest of the code much cleaner + typ = "sdist" dist.latest_version = remote_version dist.latest_filetype = typ return dist - for dist in map_multithread(latest_info, packages): + for dist in map(latest_info, packages): if dist is not None: yield dist - def output_package_listing(self, packages, options): - # type: (List[Distribution], Values) -> None + def output_package_listing( + self, packages: "_ProcessedDists", options: Values + ) -> None: packages = sorted( packages, - key=lambda dist: dist.project_name.lower(), + key=lambda dist: dist.canonical_name, ) - if options.list_format == 'columns' and packages: + if options.list_format == "columns" and packages: data, header = format_for_columns(packages, options) self.output_package_listing_columns(data, header) - elif options.list_format == 'freeze': + elif options.list_format == "freeze": for dist in packages: if options.verbose >= 1: - write_output("%s==%s (%s)", dist.project_name, - dist.version, dist.location) + write_output( + "%s==%s (%s)", dist.raw_name, dist.version, dist.location + ) else: - write_output("%s==%s", dist.project_name, dist.version) - elif options.list_format == 'json': + write_output("%s==%s", dist.raw_name, dist.version) + elif options.list_format == "json": write_output(format_for_json(packages, options)) - def output_package_listing_columns(self, data, header): - # type: (List[List[str]], List[str]) -> None + def output_package_listing_columns( + self, data: List[List[str]], header: List[str] + ) -> None: # insert the header first: we need to know the size of column names if len(data) > 0: data.insert(0, header) @@ -257,63 +297,72 @@ class ListCommand(IndexGroupCommand): # Create and add a separator. if len(data) > 0: - pkg_strings.insert(1, " ".join(map(lambda x: '-' * x, sizes))) + pkg_strings.insert(1, " ".join(map(lambda x: "-" * x, sizes))) for val in pkg_strings: write_output(val) -def format_for_columns(pkgs, options): - # type: (List[Distribution], Values) -> Tuple[List[List[str]], List[str]] +def format_for_columns( + pkgs: "_ProcessedDists", options: Values +) -> Tuple[List[List[str]], List[str]]: """ Convert the package data into something usable by output_package_listing_columns. """ + header = ["Package", "Version"] + running_outdated = options.outdated - # Adjust the header for the `pip list --outdated` case. if running_outdated: - header = ["Package", "Version", "Latest", "Type"] - else: - header = ["Package", "Version"] + header.extend(["Latest", "Type"]) - data = [] - if options.verbose >= 1 or any(dist_is_editable(x) for x in pkgs): + has_editables = any(x.editable for x in pkgs) + if has_editables: + header.append("Editable project location") + + if options.verbose >= 1: header.append("Location") if options.verbose >= 1: header.append("Installer") + data = [] for proj in pkgs: # if we're working on the 'outdated' list, separate out the # latest_version and type - row = [proj.project_name, proj.version] + row = [proj.raw_name, str(proj.version)] if running_outdated: - row.append(proj.latest_version) + row.append(str(proj.latest_version)) row.append(proj.latest_filetype) - if options.verbose >= 1 or dist_is_editable(proj): - row.append(proj.location) + if has_editables: + row.append(proj.editable_project_location or "") + + if options.verbose >= 1: + row.append(proj.location or "") if options.verbose >= 1: - row.append(get_installer(proj)) + row.append(proj.installer) data.append(row) return data, header -def format_for_json(packages, options): - # type: (List[Distribution], Values) -> str +def format_for_json(packages: "_ProcessedDists", options: Values) -> str: data = [] for dist in packages: info = { - 'name': dist.project_name, - 'version': str(dist.version), + "name": dist.raw_name, + "version": str(dist.version), } if options.verbose >= 1: - info['location'] = dist.location - info['installer'] = get_installer(dist) + info["location"] = dist.location or "" + info["installer"] = dist.installer if options.outdated: - info['latest_version'] = str(dist.latest_version) - info['latest_filetype'] = dist.latest_filetype + info["latest_version"] = str(dist.latest_version) + info["latest_filetype"] = dist.latest_filetype + editable_project_location = dist.editable_project_location + if editable_project_location: + info["editable_project_location"] = editable_project_location data.append(info) return json.dumps(data) diff --git a/env/Lib/site-packages/pip/_internal/commands/search.py b/env/Lib/site-packages/pip/_internal/commands/search.py index d66e8234..03ed925b 100644 --- a/env/Lib/site-packages/pip/_internal/commands/search.py +++ b/env/Lib/site-packages/pip/_internal/commands/search.py @@ -27,6 +27,7 @@ if TYPE_CHECKING: summary: str versions: List[str] + logger = logging.getLogger(__name__) @@ -37,21 +38,21 @@ class SearchCommand(Command, SessionCommandMixin): %prog [options] <query>""" ignore_require_venv = True - def add_options(self): - # type: () -> None + def add_options(self) -> None: self.cmd_opts.add_option( - '-i', '--index', - dest='index', - metavar='URL', + "-i", + "--index", + dest="index", + metavar="URL", default=PyPI.pypi_url, - help='Base URL of Python Package Index (default %default)') + help="Base URL of Python Package Index (default %default)", + ) self.parser.insert_option_group(0, self.cmd_opts) - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: if not args: - raise CommandError('Missing required argument (search query).') + raise CommandError("Missing required argument (search query).") query = args pypi_hits = self.search(query, options) hits = transform_hits(pypi_hits) @@ -65,8 +66,7 @@ class SearchCommand(Command, SessionCommandMixin): return SUCCESS return NO_MATCHES_FOUND - def search(self, query, options): - # type: (List[str], Values) -> List[Dict[str, str]] + def search(self, query: List[str], options: Values) -> List[Dict[str, str]]: index_url = options.index session = self.get_default_session(options) @@ -74,7 +74,7 @@ class SearchCommand(Command, SessionCommandMixin): transport = PipXmlrpcTransport(index_url, session) pypi = xmlrpc.client.ServerProxy(index_url, transport) try: - hits = pypi.search({'name': query, 'summary': query}, 'or') + hits = pypi.search({"name": query, "summary": query}, "or") except xmlrpc.client.Fault as fault: message = "XMLRPC request failed [code: {code}]\n{string}".format( code=fault.faultCode, @@ -85,78 +85,90 @@ class SearchCommand(Command, SessionCommandMixin): return hits -def transform_hits(hits): - # type: (List[Dict[str, str]]) -> List[TransformedHit] +def transform_hits(hits: List[Dict[str, str]]) -> List["TransformedHit"]: """ The list from pypi is really a list of versions. We want a list of packages with the list of versions stored inline. This converts the list from pypi into one we can use. """ - packages = OrderedDict() # type: OrderedDict[str, TransformedHit] + packages: Dict[str, "TransformedHit"] = OrderedDict() for hit in hits: - name = hit['name'] - summary = hit['summary'] - version = hit['version'] + name = hit["name"] + summary = hit["summary"] + version = hit["version"] if name not in packages.keys(): packages[name] = { - 'name': name, - 'summary': summary, - 'versions': [version], + "name": name, + "summary": summary, + "versions": [version], } else: - packages[name]['versions'].append(version) + packages[name]["versions"].append(version) # if this is the highest version, replace summary and score - if version == highest_version(packages[name]['versions']): - packages[name]['summary'] = summary + if version == highest_version(packages[name]["versions"]): + packages[name]["summary"] = summary return list(packages.values()) -def print_results(hits, name_column_width=None, terminal_width=None): - # type: (List[TransformedHit], Optional[int], Optional[int]) -> None +def print_dist_installation_info(name: str, latest: str) -> None: + env = get_default_environment() + dist = env.get_distribution(name) + if dist is not None: + with indent_log(): + if dist.version == latest: + write_output("INSTALLED: %s (latest)", dist.version) + else: + write_output("INSTALLED: %s", dist.version) + if parse_version(latest).pre: + write_output( + "LATEST: %s (pre-release; install" + " with `pip install --pre`)", + latest, + ) + else: + write_output("LATEST: %s", latest) + + +def print_results( + hits: List["TransformedHit"], + name_column_width: Optional[int] = None, + terminal_width: Optional[int] = None, +) -> None: if not hits: return if name_column_width is None: - name_column_width = max([ - len(hit['name']) + len(highest_version(hit.get('versions', ['-']))) - for hit in hits - ]) + 4 + name_column_width = ( + max( + [ + len(hit["name"]) + len(highest_version(hit.get("versions", ["-"]))) + for hit in hits + ] + ) + + 4 + ) - env = get_default_environment() for hit in hits: - name = hit['name'] - summary = hit['summary'] or '' - latest = highest_version(hit.get('versions', ['-'])) + name = hit["name"] + summary = hit["summary"] or "" + latest = highest_version(hit.get("versions", ["-"])) if terminal_width is not None: target_width = terminal_width - name_column_width - 5 if target_width > 10: # wrap and indent summary to fit terminal summary_lines = textwrap.wrap(summary, target_width) - summary = ('\n' + ' ' * (name_column_width + 3)).join( - summary_lines) + summary = ("\n" + " " * (name_column_width + 3)).join(summary_lines) - name_latest = f'{name} ({latest})' - line = f'{name_latest:{name_column_width}} - {summary}' + name_latest = f"{name} ({latest})" + line = f"{name_latest:{name_column_width}} - {summary}" try: write_output(line) - dist = env.get_distribution(name) - if dist is not None: - with indent_log(): - if dist.version == latest: - write_output('INSTALLED: %s (latest)', dist.version) - else: - write_output('INSTALLED: %s', dist.version) - if parse_version(latest).pre: - write_output('LATEST: %s (pre-release; install' - ' with "pip install --pre")', latest) - else: - write_output('LATEST: %s', latest) + print_dist_installation_info(name, latest) except UnicodeEncodeError: pass -def highest_version(versions): - # type: (List[str]) -> str +def highest_version(versions: List[str]) -> str: return max(versions, key=parse_version) diff --git a/env/Lib/site-packages/pip/_internal/commands/show.py b/env/Lib/site-packages/pip/_internal/commands/show.py index 24e855a8..3f10701f 100644 --- a/env/Lib/site-packages/pip/_internal/commands/show.py +++ b/env/Lib/site-packages/pip/_internal/commands/show.py @@ -1,14 +1,12 @@ import logging -import os -from email.parser import FeedParser from optparse import Values -from typing import Dict, Iterator, List +from typing import Generator, Iterable, Iterator, List, NamedTuple, Optional -from pip._vendor import pkg_resources from pip._vendor.packaging.utils import canonicalize_name from pip._internal.cli.base_command import Command from pip._internal.cli.status_codes import ERROR, SUCCESS +from pip._internal.metadata import BaseDistribution, get_default_environment from pip._internal.utils.misc import write_output logger = logging.getLogger(__name__) @@ -25,123 +23,126 @@ class ShowCommand(Command): %prog [options] <package> ...""" ignore_require_venv = True - def add_options(self): - # type: () -> None + def add_options(self) -> None: self.cmd_opts.add_option( - '-f', '--files', - dest='files', - action='store_true', + "-f", + "--files", + dest="files", + action="store_true", default=False, - help='Show the full list of installed files for each package.') + help="Show the full list of installed files for each package.", + ) self.parser.insert_option_group(0, self.cmd_opts) - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: if not args: - logger.warning('ERROR: Please provide a package name or names.') + logger.warning("ERROR: Please provide a package name or names.") return ERROR query = args results = search_packages_info(query) if not print_results( - results, list_files=options.files, verbose=options.verbose): + results, list_files=options.files, verbose=options.verbose + ): return ERROR return SUCCESS -def search_packages_info(query): - # type: (List[str]) -> Iterator[Dict[str, str]] +class _PackageInfo(NamedTuple): + name: str + version: str + location: str + editable_project_location: Optional[str] + requires: List[str] + required_by: List[str] + installer: str + metadata_version: str + classifiers: List[str] + summary: str + homepage: str + project_urls: List[str] + author: str + author_email: str + license: str + entry_points: List[str] + files: Optional[List[str]] + + +def search_packages_info(query: List[str]) -> Generator[_PackageInfo, None, None]: """ Gather details from installed distributions. Print distribution name, version, location, and installed files. Installed files requires a pip generated 'installed-files.txt' in the distributions '.egg-info' directory. """ - installed = {} - for p in pkg_resources.working_set: - installed[canonicalize_name(p.project_name)] = p + env = get_default_environment() + installed = {dist.canonical_name: dist for dist in env.iter_all_distributions()} query_names = [canonicalize_name(name) for name in query] missing = sorted( [name for name, pkg in zip(query, query_names) if pkg not in installed] ) if missing: - logger.warning('Package(s) not found: %s', ', '.join(missing)) - - def get_requiring_packages(package_name): - # type: (str) -> List[str] - canonical_name = canonicalize_name(package_name) - return [ - pkg.project_name for pkg in pkg_resources.working_set - if canonical_name in - [canonicalize_name(required.name) for required in - pkg.requires()] - ] - - for dist in [installed[pkg] for pkg in query_names if pkg in installed]: - package = { - 'name': dist.project_name, - 'version': dist.version, - 'location': dist.location, - 'requires': [dep.project_name for dep in dist.requires()], - 'required_by': get_requiring_packages(dist.project_name) - } - file_list = None - metadata = '' - if isinstance(dist, pkg_resources.DistInfoDistribution): - # RECORDs should be part of .dist-info metadatas - if dist.has_metadata('RECORD'): - lines = dist.get_metadata_lines('RECORD') - paths = [line.split(',')[0] for line in lines] - paths = [os.path.join(dist.location, p) for p in paths] - file_list = [os.path.relpath(p, dist.location) for p in paths] - - if dist.has_metadata('METADATA'): - metadata = dist.get_metadata('METADATA') + logger.warning("Package(s) not found: %s", ", ".join(missing)) + + def _get_requiring_packages(current_dist: BaseDistribution) -> Iterator[str]: + return ( + dist.metadata["Name"] or "UNKNOWN" + for dist in installed.values() + if current_dist.canonical_name + in {canonicalize_name(d.name) for d in dist.iter_dependencies()} + ) + + for query_name in query_names: + try: + dist = installed[query_name] + except KeyError: + continue + + requires = sorted((req.name for req in dist.iter_dependencies()), key=str.lower) + required_by = sorted(_get_requiring_packages(dist), key=str.lower) + + try: + entry_points_text = dist.read_text("entry_points.txt") + entry_points = entry_points_text.splitlines(keepends=False) + except FileNotFoundError: + entry_points = [] + + files_iter = dist.iter_declared_entries() + if files_iter is None: + files: Optional[List[str]] = None else: - # Otherwise use pip's log for .egg-info's - if dist.has_metadata('installed-files.txt'): - paths = dist.get_metadata_lines('installed-files.txt') - paths = [os.path.join(dist.egg_info, p) for p in paths] - file_list = [os.path.relpath(p, dist.location) for p in paths] - - if dist.has_metadata('PKG-INFO'): - metadata = dist.get_metadata('PKG-INFO') - - if dist.has_metadata('entry_points.txt'): - entry_points = dist.get_metadata_lines('entry_points.txt') - package['entry_points'] = entry_points - - if dist.has_metadata('INSTALLER'): - for line in dist.get_metadata_lines('INSTALLER'): - if line.strip(): - package['installer'] = line.strip() - break - - # @todo: Should pkg_resources.Distribution have a - # `get_pkg_info` method? - feed_parser = FeedParser() - feed_parser.feed(metadata) - pkg_info_dict = feed_parser.close() - for key in ('metadata-version', 'summary', - 'home-page', 'author', 'author-email', 'license'): - package[key] = pkg_info_dict.get(key) - - # It looks like FeedParser cannot deal with repeated headers - classifiers = [] - for line in metadata.splitlines(): - if line.startswith('Classifier: '): - classifiers.append(line[len('Classifier: '):]) - package['classifiers'] = classifiers - - if file_list: - package['files'] = sorted(file_list) - yield package - - -def print_results(distributions, list_files=False, verbose=False): - # type: (Iterator[Dict[str, str]], bool, bool) -> bool + files = sorted(files_iter) + + metadata = dist.metadata + + yield _PackageInfo( + name=dist.raw_name, + version=str(dist.version), + location=dist.location or "", + editable_project_location=dist.editable_project_location, + requires=requires, + required_by=required_by, + installer=dist.installer, + metadata_version=dist.metadata_version or "", + classifiers=metadata.get_all("Classifier", []), + summary=metadata.get("Summary", ""), + homepage=metadata.get("Home-page", ""), + project_urls=metadata.get_all("Project-URL", []), + author=metadata.get("Author", ""), + author_email=metadata.get("Author-email", ""), + license=metadata.get("License", ""), + entry_points=entry_points, + files=files, + ) + + +def print_results( + distributions: Iterable[_PackageInfo], + list_files: bool, + verbose: bool, +) -> bool: """ Print the information from installed distributions found. """ @@ -151,31 +152,38 @@ def print_results(distributions, list_files=False, verbose=False): if i > 0: write_output("---") - write_output("Name: %s", dist.get('name', '')) - write_output("Version: %s", dist.get('version', '')) - write_output("Summary: %s", dist.get('summary', '')) - write_output("Home-page: %s", dist.get('home-page', '')) - write_output("Author: %s", dist.get('author', '')) - write_output("Author-email: %s", dist.get('author-email', '')) - write_output("License: %s", dist.get('license', '')) - write_output("Location: %s", dist.get('location', '')) - write_output("Requires: %s", ', '.join(dist.get('requires', []))) - write_output("Required-by: %s", ', '.join(dist.get('required_by', []))) + write_output("Name: %s", dist.name) + write_output("Version: %s", dist.version) + write_output("Summary: %s", dist.summary) + write_output("Home-page: %s", dist.homepage) + write_output("Author: %s", dist.author) + write_output("Author-email: %s", dist.author_email) + write_output("License: %s", dist.license) + write_output("Location: %s", dist.location) + if dist.editable_project_location is not None: + write_output( + "Editable project location: %s", dist.editable_project_location + ) + write_output("Requires: %s", ", ".join(dist.requires)) + write_output("Required-by: %s", ", ".join(dist.required_by)) if verbose: - write_output("Metadata-Version: %s", - dist.get('metadata-version', '')) - write_output("Installer: %s", dist.get('installer', '')) + write_output("Metadata-Version: %s", dist.metadata_version) + write_output("Installer: %s", dist.installer) write_output("Classifiers:") - for classifier in dist.get('classifiers', []): + for classifier in dist.classifiers: write_output(" %s", classifier) write_output("Entry-points:") - for entry in dist.get('entry_points', []): + for entry in dist.entry_points: write_output(" %s", entry.strip()) + write_output("Project-URLs:") + for project_url in dist.project_urls: + write_output(" %s", project_url) if list_files: write_output("Files:") - for line in dist.get('files', []): - write_output(" %s", line.strip()) - if "files" not in dist: - write_output("Cannot locate installed-files.txt") + if dist.files is None: + write_output("Cannot locate RECORD or installed-files.txt") + else: + for line in dist.files: + write_output(" %s", line.strip()) return results_printed diff --git a/env/Lib/site-packages/pip/_internal/commands/uninstall.py b/env/Lib/site-packages/pip/_internal/commands/uninstall.py index 9a3c9f88..f198fc31 100644 --- a/env/Lib/site-packages/pip/_internal/commands/uninstall.py +++ b/env/Lib/site-packages/pip/_internal/commands/uninstall.py @@ -1,8 +1,10 @@ +import logging from optparse import Values from typing import List from pip._vendor.packaging.utils import canonicalize_name +from pip._internal.cli import cmdoptions from pip._internal.cli.base_command import Command from pip._internal.cli.req_command import SessionCommandMixin, warn_if_run_as_root from pip._internal.cli.status_codes import SUCCESS @@ -12,7 +14,12 @@ from pip._internal.req.constructors import ( install_req_from_line, install_req_from_parsed_requirement, ) -from pip._internal.utils.misc import protect_pip_from_modification_on_windows +from pip._internal.utils.misc import ( + check_externally_managed, + protect_pip_from_modification_on_windows, +) + +logger = logging.getLogger(__name__) class UninstallCommand(Command, SessionCommandMixin): @@ -30,63 +37,77 @@ class UninstallCommand(Command, SessionCommandMixin): %prog [options] <package> ... %prog [options] -r <requirements file> ...""" - def add_options(self): - # type: () -> None + def add_options(self) -> None: self.cmd_opts.add_option( - '-r', '--requirement', - dest='requirements', - action='append', + "-r", + "--requirement", + dest="requirements", + action="append", default=[], - metavar='file', - help='Uninstall all the packages listed in the given requirements ' - 'file. This option can be used multiple times.', + metavar="file", + help=( + "Uninstall all the packages listed in the given requirements " + "file. This option can be used multiple times." + ), ) self.cmd_opts.add_option( - '-y', '--yes', - dest='yes', - action='store_true', - help="Don't ask for confirmation of uninstall deletions.") - + "-y", + "--yes", + dest="yes", + action="store_true", + help="Don't ask for confirmation of uninstall deletions.", + ) + self.cmd_opts.add_option(cmdoptions.root_user_action()) + self.cmd_opts.add_option(cmdoptions.override_externally_managed()) self.parser.insert_option_group(0, self.cmd_opts) - def run(self, options, args): - # type: (Values, List[str]) -> int + def run(self, options: Values, args: List[str]) -> int: session = self.get_default_session(options) reqs_to_uninstall = {} for name in args: req = install_req_from_line( - name, isolated=options.isolated_mode, + name, + isolated=options.isolated_mode, ) if req.name: reqs_to_uninstall[canonicalize_name(req.name)] = req + else: + logger.warning( + "Invalid requirement: %r ignored -" + " the uninstall command expects named" + " requirements.", + name, + ) for filename in options.requirements: for parsed_req in parse_requirements( - filename, - options=options, - session=session): + filename, options=options, session=session + ): req = install_req_from_parsed_requirement( - parsed_req, - isolated=options.isolated_mode + parsed_req, isolated=options.isolated_mode ) if req.name: reqs_to_uninstall[canonicalize_name(req.name)] = req if not reqs_to_uninstall: raise InstallationError( - f'You must give at least one requirement to {self.name} (see ' + f"You must give at least one requirement to {self.name} (see " f'"pip help {self.name}")' ) + if not options.override_externally_managed: + check_externally_managed() + protect_pip_from_modification_on_windows( modifying_pip="pip" in reqs_to_uninstall ) for req in reqs_to_uninstall.values(): uninstall_pathset = req.uninstall( - auto_confirm=options.yes, verbose=self.verbosity > 0, + auto_confirm=options.yes, + verbose=self.verbosity > 0, ) if uninstall_pathset: uninstall_pathset.commit() - - warn_if_run_as_root() + if options.root_user_action == "warn": + warn_if_run_as_root() return SUCCESS diff --git a/env/Lib/site-packages/pip/_internal/commands/wheel.py b/env/Lib/site-packages/pip/_internal/commands/wheel.py index ff47dbac..ed578aa2 100644 --- a/env/Lib/site-packages/pip/_internal/commands/wheel.py +++ b/env/Lib/site-packages/pip/_internal/commands/wheel.py @@ -9,8 +9,11 @@ from pip._internal.cli import cmdoptions from pip._internal.cli.req_command import RequirementCommand, with_cleanup from pip._internal.cli.status_codes import SUCCESS from pip._internal.exceptions import CommandError -from pip._internal.req.req_install import InstallRequirement -from pip._internal.req.req_tracker import get_requirement_tracker +from pip._internal.operations.build.build_tracker import get_build_tracker +from pip._internal.req.req_install import ( + InstallRequirement, + check_legacy_setup_py_options, +) from pip._internal.utils.misc import ensure_dir, normalize_path from pip._internal.utils.temp_dir import TempDirectory from pip._internal.wheel_builder import build, should_build_for_wheel_command @@ -26,10 +29,8 @@ class WheelCommand(RequirementCommand): recompiling your software during every install. For more details, see the wheel docs: https://wheel.readthedocs.io/en/latest/ - Requirements: setuptools>=0.8, and wheel. - - 'pip wheel' uses the bdist_wheel setuptools extension from the wheel - package to build individual wheels. + 'pip wheel' uses the build system interface as described here: + https://pip.pypa.io/en/stable/reference/build-system/ """ @@ -40,16 +41,17 @@ class WheelCommand(RequirementCommand): %prog [options] [-e] <local project path> ... %prog [options] <archive url/path> ...""" - def add_options(self): - # type: () -> None - + def add_options(self) -> None: self.cmd_opts.add_option( - '-w', '--wheel-dir', - dest='wheel_dir', - metavar='dir', + "-w", + "--wheel-dir", + dest="wheel_dir", + metavar="dir", default=os.curdir, - help=("Build wheels into <dir>, where the default is the " - "current working directory."), + help=( + "Build wheels into <dir>, where the default is the " + "current working directory." + ), ) self.cmd_opts.add_option(cmdoptions.no_binary()) self.cmd_opts.add_option(cmdoptions.only_binary()) @@ -57,32 +59,35 @@ class WheelCommand(RequirementCommand): self.cmd_opts.add_option(cmdoptions.no_build_isolation()) self.cmd_opts.add_option(cmdoptions.use_pep517()) self.cmd_opts.add_option(cmdoptions.no_use_pep517()) + self.cmd_opts.add_option(cmdoptions.check_build_deps()) self.cmd_opts.add_option(cmdoptions.constraints()) self.cmd_opts.add_option(cmdoptions.editable()) self.cmd_opts.add_option(cmdoptions.requirements()) self.cmd_opts.add_option(cmdoptions.src()) self.cmd_opts.add_option(cmdoptions.ignore_requires_python()) self.cmd_opts.add_option(cmdoptions.no_deps()) - self.cmd_opts.add_option(cmdoptions.build_dir()) self.cmd_opts.add_option(cmdoptions.progress_bar()) self.cmd_opts.add_option( - '--no-verify', - dest='no_verify', - action='store_true', + "--no-verify", + dest="no_verify", + action="store_true", default=False, help="Don't verify if built wheel is valid.", ) + self.cmd_opts.add_option(cmdoptions.config_settings()) self.cmd_opts.add_option(cmdoptions.build_options()) self.cmd_opts.add_option(cmdoptions.global_options()) self.cmd_opts.add_option( - '--pre', - action='store_true', + "--pre", + action="store_true", default=False, - help=("Include pre-release and development versions. By default, " - "pip only finds stable versions."), + help=( + "Include pre-release and development versions. By default, " + "pip only finds stable versions." + ), ) self.cmd_opts.add_option(cmdoptions.require_hashes()) @@ -96,19 +101,15 @@ class WheelCommand(RequirementCommand): self.parser.insert_option_group(0, self.cmd_opts) @with_cleanup - def run(self, options, args): - # type: (Values, List[str]) -> int - cmdoptions.check_install_build_global(options) - + def run(self, options: Values, args: List[str]) -> int: session = self.get_default_session(options) finder = self._build_package_finder(options, session) - wheel_cache = WheelCache(options.cache_dir, options.format_control) options.wheel_dir = normalize_path(options.wheel_dir) ensure_dir(options.wheel_dir) - req_tracker = self.enter_context(get_requirement_tracker()) + build_tracker = self.enter_context(get_build_tracker()) directory = TempDirectory( delete=not options.no_clean, @@ -117,15 +118,19 @@ class WheelCommand(RequirementCommand): ) reqs = self.get_requirements(args, options, finder, session) + check_legacy_setup_py_options(options, reqs) + + wheel_cache = WheelCache(options.cache_dir) preparer = self.make_requirement_preparer( temp_build_dir=directory, options=options, - req_tracker=req_tracker, + build_tracker=build_tracker, session=session, finder=finder, download_dir=options.wheel_dir, use_user_site=False, + verbosity=self.verbosity, ) resolver = self.make_resolver( @@ -139,17 +144,18 @@ class WheelCommand(RequirementCommand): self.trace_basic_info(finder) - requirement_set = resolver.resolve( - reqs, check_supported_wheels=True - ) + requirement_set = resolver.resolve(reqs, check_supported_wheels=True) - reqs_to_build = [] # type: List[InstallRequirement] + reqs_to_build: List[InstallRequirement] = [] for req in requirement_set.requirements.values(): if req.is_wheel: preparer.save_linked_requirement(req) elif should_build_for_wheel_command(req): reqs_to_build.append(req) + preparer.prepare_linked_requirements_more(requirement_set.requirements.values()) + requirement_set.warn_legacy_versions_and_specifiers() + # build wheels build_successes, build_failures = build( reqs_to_build, @@ -167,12 +173,11 @@ class WheelCommand(RequirementCommand): except OSError as e: logger.warning( "Building wheel for %s failed: %s", - req.name, e, + req.name, + e, ) build_failures.append(req) if len(build_failures) != 0: - raise CommandError( - "Failed to build one or more wheels" - ) + raise CommandError("Failed to build one or more wheels") return SUCCESS diff --git a/env/Lib/site-packages/pip/_internal/configuration.py b/env/Lib/site-packages/pip/_internal/configuration.py index a4698ec1..96f82495 100644 --- a/env/Lib/site-packages/pip/_internal/configuration.py +++ b/env/Lib/site-packages/pip/_internal/configuration.py @@ -13,7 +13,6 @@ Some terminology: import configparser import locale -import logging import os import sys from typing import Any, Dict, Iterable, List, NewType, Optional, Tuple @@ -24,41 +23,39 @@ from pip._internal.exceptions import ( ) from pip._internal.utils import appdirs from pip._internal.utils.compat import WINDOWS +from pip._internal.utils.logging import getLogger from pip._internal.utils.misc import ensure_dir, enum RawConfigParser = configparser.RawConfigParser # Shorthand Kind = NewType("Kind", str) -CONFIG_BASENAME = 'pip.ini' if WINDOWS else 'pip.conf' +CONFIG_BASENAME = "pip.ini" if WINDOWS else "pip.conf" ENV_NAMES_IGNORED = "version", "help" # The kinds of configurations there are. kinds = enum( - USER="user", # User Specific - GLOBAL="global", # System Wide - SITE="site", # [Virtual] Environment Specific - ENV="env", # from PIP_CONFIG_FILE + USER="user", # User Specific + GLOBAL="global", # System Wide + SITE="site", # [Virtual] Environment Specific + ENV="env", # from PIP_CONFIG_FILE ENV_VAR="env-var", # from Environment Variables ) OVERRIDE_ORDER = kinds.GLOBAL, kinds.USER, kinds.SITE, kinds.ENV, kinds.ENV_VAR VALID_LOAD_ONLY = kinds.USER, kinds.GLOBAL, kinds.SITE -logger = logging.getLogger(__name__) +logger = getLogger(__name__) # NOTE: Maybe use the optionx attribute to normalize keynames. -def _normalize_name(name): - # type: (str) -> str - """Make a name consistent regardless of source (environment or file) - """ - name = name.lower().replace('_', '-') - if name.startswith('--'): +def _normalize_name(name: str) -> str: + """Make a name consistent regardless of source (environment or file)""" + name = name.lower().replace("_", "-") + if name.startswith("--"): name = name[2:] # only prefer long opts return name -def _disassemble_key(name): - # type: (str) -> List[str] +def _disassemble_key(name: str) -> List[str]: if "." not in name: error_message = ( "Key does not contain dot separated section and key. " @@ -68,22 +65,18 @@ def _disassemble_key(name): return name.split(".", 1) -def get_configuration_files(): - # type: () -> Dict[Kind, List[str]] +def get_configuration_files() -> Dict[Kind, List[str]]: global_config_files = [ - os.path.join(path, CONFIG_BASENAME) - for path in appdirs.site_config_dirs('pip') + os.path.join(path, CONFIG_BASENAME) for path in appdirs.site_config_dirs("pip") ] site_config_file = os.path.join(sys.prefix, CONFIG_BASENAME) legacy_config_file = os.path.join( - os.path.expanduser('~'), - 'pip' if WINDOWS else '.pip', + os.path.expanduser("~"), + "pip" if WINDOWS else ".pip", CONFIG_BASENAME, ) - new_config_file = os.path.join( - appdirs.user_config_dir("pip"), CONFIG_BASENAME - ) + new_config_file = os.path.join(appdirs.user_config_dir("pip"), CONFIG_BASENAME) return { kinds.GLOBAL: global_config_files, kinds.SITE: [site_config_file], @@ -105,8 +98,7 @@ class Configuration: and the data stored is also nice. """ - def __init__(self, isolated, load_only=None): - # type: (bool, Optional[Kind]) -> None + def __init__(self, isolated: bool, load_only: Optional[Kind] = None) -> None: super().__init__() if load_only is not None and load_only not in VALID_LOAD_ONLY: @@ -119,54 +111,50 @@ class Configuration: self.load_only = load_only # Because we keep track of where we got the data from - self._parsers = { + self._parsers: Dict[Kind, List[Tuple[str, RawConfigParser]]] = { variant: [] for variant in OVERRIDE_ORDER - } # type: Dict[Kind, List[Tuple[str, RawConfigParser]]] - self._config = { + } + self._config: Dict[Kind, Dict[str, Any]] = { variant: {} for variant in OVERRIDE_ORDER - } # type: Dict[Kind, Dict[str, Any]] - self._modified_parsers = [] # type: List[Tuple[str, RawConfigParser]] + } + self._modified_parsers: List[Tuple[str, RawConfigParser]] = [] - def load(self): - # type: () -> None - """Loads configuration from configuration files and environment - """ + def load(self) -> None: + """Loads configuration from configuration files and environment""" self._load_config_files() if not self.isolated: self._load_environment_vars() - def get_file_to_edit(self): - # type: () -> Optional[str] - """Returns the file with highest priority in configuration - """ - assert self.load_only is not None, \ - "Need to be specified a file to be editing" + def get_file_to_edit(self) -> Optional[str]: + """Returns the file with highest priority in configuration""" + assert self.load_only is not None, "Need to be specified a file to be editing" try: return self._get_parser_to_modify()[0] except IndexError: return None - def items(self): - # type: () -> Iterable[Tuple[str, Any]] + def items(self) -> Iterable[Tuple[str, Any]]: """Returns key-value pairs like dict.items() representing the loaded configuration """ return self._dictionary.items() - def get_value(self, key): - # type: (str) -> Any - """Get a value from the configuration. - """ + def get_value(self, key: str) -> Any: + """Get a value from the configuration.""" + orig_key = key + key = _normalize_name(key) try: return self._dictionary[key] except KeyError: - raise ConfigurationError(f"No such key - {key}") - - def set_value(self, key, value): - # type: (str, Any) -> None - """Modify a value in the configuration. - """ + # disassembling triggers a more useful error message than simply + # "No such key" in the case that the key isn't in the form command.option + _disassemble_key(key) + raise ConfigurationError(f"No such key - {orig_key}") + + def set_value(self, key: str, value: Any) -> None: + """Modify a value in the configuration.""" + key = _normalize_name(key) self._ensure_have_load_only() assert self.load_only @@ -183,21 +171,23 @@ class Configuration: self._config[self.load_only][key] = value self._mark_as_modified(fname, parser) - def unset_value(self, key): - # type: (str) -> None + def unset_value(self, key: str) -> None: """Unset a value in the configuration.""" + orig_key = key + key = _normalize_name(key) self._ensure_have_load_only() assert self.load_only if key not in self._config[self.load_only]: - raise ConfigurationError(f"No such key - {key}") + raise ConfigurationError(f"No such key - {orig_key}") fname, parser = self._get_parser_to_modify() if parser is not None: section, name = _disassemble_key(key) - if not (parser.has_section(section) - and parser.remove_option(section, name)): + if not ( + parser.has_section(section) and parser.remove_option(section, name) + ): # The option was not removed. raise ConfigurationError( "Fatal Internal error [id=1]. Please report as a bug." @@ -210,10 +200,8 @@ class Configuration: del self._config[self.load_only][key] - def save(self): - # type: () -> None - """Save the current in-memory state. - """ + def save(self) -> None: + """Save the current in-memory state.""" self._ensure_have_load_only() for fname, parser in self._modified_parsers: @@ -222,24 +210,28 @@ class Configuration: # Ensure directory exists. ensure_dir(os.path.dirname(fname)) - with open(fname, "w") as f: - parser.write(f) + # Ensure directory's permission(need to be writeable) + try: + with open(fname, "w") as f: + parser.write(f) + except OSError as error: + raise ConfigurationError( + f"An error occurred while writing to the configuration file " + f"{fname}: {error}" + ) # # Private routines # - def _ensure_have_load_only(self): - # type: () -> None + def _ensure_have_load_only(self) -> None: if self.load_only is None: raise ConfigurationError("Needed a specific file to be modifying.") logger.debug("Will be working with %s variant only", self.load_only) @property - def _dictionary(self): - # type: () -> Dict[str, Any] - """A dictionary representing the loaded configuration. - """ + def _dictionary(self) -> Dict[str, Any]: + """A dictionary representing the loaded configuration.""" # NOTE: Dictionaries are not populated if not loaded. So, conditionals # are not needed here. retval = {} @@ -249,10 +241,8 @@ class Configuration: return retval - def _load_config_files(self): - # type: () -> None - """Loads configuration from configuration files - """ + def _load_config_files(self) -> None: + """Loads configuration from configuration files""" config_files = dict(self.iter_config_files()) if config_files[kinds.ENV][0:1] == [os.devnull]: logger.debug( @@ -266,9 +256,7 @@ class Configuration: # If there's specific variant set in `load_only`, load only # that variant, not the others. if self.load_only is not None and variant != self.load_only: - logger.debug( - "Skipping file '%s' (variant: %s)", fname, variant - ) + logger.debug("Skipping file '%s' (variant: %s)", fname, variant) continue parser = self._load_file(variant, fname) @@ -276,9 +264,8 @@ class Configuration: # Keeping track of the parsers used self._parsers[variant].append((fname, parser)) - def _load_file(self, variant, fname): - # type: (Kind, str) -> RawConfigParser - logger.debug("For variant '%s', will try loading '%s'", variant, fname) + def _load_file(self, variant: Kind, fname: str) -> RawConfigParser: + logger.verbose("For variant '%s', will try loading '%s'", variant, fname) parser = self._construct_parser(fname) for section in parser.sections(): @@ -287,22 +274,20 @@ class Configuration: return parser - def _construct_parser(self, fname): - # type: (str) -> RawConfigParser + def _construct_parser(self, fname: str) -> RawConfigParser: parser = configparser.RawConfigParser() # If there is no such file, don't bother reading it but create the # parser anyway, to hold the data. # Doing this is useful when modifying and saving files, where we don't # need to construct a parser. if os.path.exists(fname): + locale_encoding = locale.getpreferredencoding(False) try: - parser.read(fname) + parser.read(fname, encoding=locale_encoding) except UnicodeDecodeError: # See https://github.com/pypa/pip/issues/4963 raise ConfigurationFileCouldNotBeLoaded( - reason="contains invalid {} characters".format( - locale.getpreferredencoding(False) - ), + reason=f"contains invalid {locale_encoding} characters", fname=fname, ) except configparser.Error as error: @@ -310,16 +295,15 @@ class Configuration: raise ConfigurationFileCouldNotBeLoaded(error=error) return parser - def _load_environment_vars(self): - # type: () -> None - """Loads configuration from environment variables - """ + def _load_environment_vars(self) -> None: + """Loads configuration from environment variables""" self._config[kinds.ENV_VAR].update( self._normalized_keys(":env:", self.get_environ_vars()) ) - def _normalized_keys(self, section, items): - # type: (str, Iterable[Tuple[str, Any]]) -> Dict[str, Any] + def _normalized_keys( + self, section: str, items: Iterable[Tuple[str, Any]] + ) -> Dict[str, Any]: """Normalizes items to construct a dictionary with normalized keys. This routine is where the names become keys and are made the same @@ -331,8 +315,7 @@ class Configuration: normalized[key] = val return normalized - def get_environ_vars(self): - # type: () -> Iterable[Tuple[str, str]] + def get_environ_vars(self) -> Iterable[Tuple[str, str]]: """Returns a generator with all environmental vars with prefix PIP_""" for key, val in os.environ.items(): if key.startswith("PIP_"): @@ -341,8 +324,7 @@ class Configuration: yield name, val # XXX: This is patched in the tests. - def iter_config_files(self): - # type: () -> Iterable[Tuple[Kind, List[str]]] + def iter_config_files(self) -> Iterable[Tuple[Kind, List[str]]]: """Yields variant and configuration files associated with it. This should be treated like items of a dictionary. @@ -350,7 +332,7 @@ class Configuration: # SMELL: Move the conditions out of this function # environment variables have the lowest priority - config_file = os.environ.get('PIP_CONFIG_FILE', None) + config_file = os.environ.get("PIP_CONFIG_FILE", None) if config_file is not None: yield kinds.ENV, [config_file] else: @@ -372,13 +354,11 @@ class Configuration: # finally virtualenv configuration first trumping others yield kinds.SITE, config_files[kinds.SITE] - def get_values_in_config(self, variant): - # type: (Kind) -> Dict[str, Any] + def get_values_in_config(self, variant: Kind) -> Dict[str, Any]: """Get values present in a config file""" return self._config[variant] - def _get_parser_to_modify(self): - # type: () -> Tuple[str, RawConfigParser] + def _get_parser_to_modify(self) -> Tuple[str, RawConfigParser]: # Determine which parser to modify assert self.load_only parsers = self._parsers[self.load_only] @@ -392,12 +372,10 @@ class Configuration: return parsers[-1] # XXX: This is patched in the tests. - def _mark_as_modified(self, fname, parser): - # type: (str, RawConfigParser) -> None + def _mark_as_modified(self, fname: str, parser: RawConfigParser) -> None: file_parser_tuple = (fname, parser) if file_parser_tuple not in self._modified_parsers: self._modified_parsers.append(file_parser_tuple) - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return f"{self.__class__.__name__}({self._dictionary!r})" diff --git a/env/Lib/site-packages/pip/_internal/distributions/__init__.py b/env/Lib/site-packages/pip/_internal/distributions/__init__.py index a222f248..9a89a838 100644 --- a/env/Lib/site-packages/pip/_internal/distributions/__init__.py +++ b/env/Lib/site-packages/pip/_internal/distributions/__init__.py @@ -4,8 +4,9 @@ from pip._internal.distributions.wheel import WheelDistribution from pip._internal.req.req_install import InstallRequirement -def make_distribution_for_install_requirement(install_req): - # type: (InstallRequirement) -> AbstractDistribution +def make_distribution_for_install_requirement( + install_req: InstallRequirement, +) -> AbstractDistribution: """Returns a Distribution for the given InstallRequirement""" # Editable requirements will always be source distributions. They use the # legacy logic until we create a modern standard for them. diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 22cfea607a2612213cf9fd6af0869fe66f430c81..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 796 zcmYe~<>g{vU|^UdaWFN3nStRkh=Yuo7#J8F7#J9eZ5S9BQW#Pga~N_NqZk=MY^EHh zT;?cdFq=7tC6_gd70hPIVasKYVrOJXVNGFcVTj^LVGm}|<ah}(SCjFUh+|T5Nl{{Q ziA!d2Nl|7}X-Q^&o+jfhq2T<|qU2OGQNi$x)YKd_K_Sn);*!LioS@Xg(#)dN+|<01 zWJZwjPz+*&T<#2Vxe5aVLk&X~LlIvIV+}(yV=#!vR3uZv4B^2<H5seSgHlUMi}H#U z5*3hbR7lG&QYgttRY=b)OU+Zjv|N+r7DsAIW=UdFPHGV|0|Ub?j?Cita*)f5SQr=> zG#PJkXF{ADUzA$7lA(x`fq~&yhqF~oXmM&$aZGAXN@h`ve_pCfQD#}Hg04cSpJ$kB zP_So+W3Ym!pNqerYp|zdOt7o3YjB8bkb+rEK!8t7qKR%!etKqcNoICTYF=54Pi9g~ zab`)XZb4#lc4B&JaZEvGfqr~uUP)?EUSf`Z3Q~X<>&M4u=4F<|$LkeT-qOrX%ubC* zmXA-%FN#NUb15{O*+D@HPBW}*j2z4$T*S@5z~HCJc}t-nvp^4SogT7r#d=AJ#i>Q0 zNV%nmPgyZo7dQ;@szU^Blq{-wMX7~)MX7}_#}~0OFff3f2o7{40_2NZ95%W6DWy57 RcAzv<%)!9Gz{3cJ%m9p)=PCdI diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-39.pyc deleted file mode 100644 index ca1348f8b68113bf2f0bcdd08af1f0b2a626cbfe..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1852 zcmYe~<>g{vU|^UdaWM5R3j@Pr5C<8vGB7YWFfcF_2QV-&q%fo~<}gHoXr>&-T&5@{ zMi84hhdGxeiUrJO$zjc9i(&(_S##KPIiffi8Qd9C*izVA7*g0%8L~K2IC`0*xKbE{ z88kUxg6#6sWW2@UUr>^npO=`U$#{#$C9}AsC^M-PB%;Z9i#H%KIXf{u)h#nGCACPC z@s^NhUU5lcPEJs2VQFSjYHn&?NixVFWXufZ6x%Q`Fr+d>F{Us?F{Lm@F}E|MF{Uu3 zFt>0-v81wQv8Ax2u(mKXGe)t4d0>Y&Ge&W=Gq5m3aRxJJa@-PeOe!uZN=z<6c32`W z69a>zLQ-OJszP#3VsWuTT7Hp2Mq*w{PG(-ZLMFtCiAg!B3W-G}nQ4j1CB=GNTnY*b z3LzP(3PlLFLv$wQRhDF6>P%Hg1j*;*<d+v)L9{FADwL-x<dznfC?usSfNdzrS4c@M zNiE9F%u7`$K{Z|>FEKY2Y_EcXf<}H3NON*xo_dKwa(+=!YH~?VCB)efoq73rx}^o_ zMTse?3dxDZshUtnE9infSOAHOVukX|k_?67)RNKy6u;<zj0d|dF{d~m=0KSB=<duc zLeUI1G{3Y27J8uINK8q|1SN#T9GD?+Cuo2|9OT>L#9UB_CKl)Cfr6{3G*7oAGdEQs zCAA<mFC{fEIWx6b6JOvZ7o{eaq$(sTAjhymeo|Iya*0A}ML~Ws$SEZm@Ni5_$}dY* z$W1LtOi3(B)B`&$nF*TaKop1#!k~0mEW*IRP{Pp6uz+zP10zEXV+}(*Qwl>c!%9X! zP3Bvy#ia$QMYlNO<1_OzOXA~iF&Cv4YBJqoDNfBvD+1-um5jGI<Kw}pEIxiE!><-+ ztC-N@)S}{;)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0e?Qk?Psf;GS6|oQ z5Z53DvzUMYpO{1w-JJaN%;J*F?3mQNvKXJtq?qE&l2lz-(8d&G7U;)k=9Q!t<t66m zryym>Vtr7O*DI(j;$&c8kOGwrEMO0FF;>Z9%P4v<e<d@5)Il+b4Z_YK13-QRg-;VB zC{&8r85kH=GTsvQ%P;ZFEyw|9@YEF7qN4mFO~xW_1_p*AJ~+Y8z`$@zE<Lp*z92h2 zz9_XgzqBYhwKyKx&GH~iK(WEVTxE>ajrjE^gJKcta0U<?pUaB`7#J8dnZfS7#g+yx zv~KYym1gFo#Ag=g=OltsGr9+43yM+;5{pt%oE;BKUn)rMH^S<EyxKLnK#2=f48+IZ z;);*Y%}*)KNsW)c#S<T2Selpvm0^#MPsvY?j|WHWE#}0e<Xe1+(2_4VwIm}yrAP=A z?4qC$=Y^)n<kXy;_;@7m@PL$nBBh9pfq?-Ov&A4G4n`J!9#$4cE*2I>u#6_-El!aC zz^Pi3y9kt$Zn2eA7G&n77lGpHmSjO@fnI!BYF<iykseCq7J=g6mJ(PVmPqwL0bQX7 zO~LVya4!NS&0B(~3X4(;i$L|-Ep|sIXW!J4M6i31yZ}yIATQkFuz`e?9Vo(!L7w4Y N<YD4r;$h@r1_02P5MKZQ diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-39.pyc deleted file mode 100644 index bf4c62f802ccbd67d548592d650a465dacbe934c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1197 zcmYe~<>g{vU|^UdaWHi@69dCz5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0 zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U~%pAp$!XC_^$?+0oz9!=> z4*!CZ%>2B>98JbsJT95VB}JJ@r63Va##<teNyQ~aiOD5s;=BQg$=QkNscxBhDXB%t zAd`?W6U?;=3=9mZ3{i|J3{gxej8V)fOexGQ3{fm8EGeul3{k8pY{3kg?6*Wc^NLFn zb8=EsknO4J2udv|N-a*!D=Ah;%u~pODN-na*sjOLrJ$go5R#EutdNqQTC9+lU!stg znwp}Jm{+M#P?TDbSd<9zi9%wrLP<udLQ!gAX=YJsib7^yT7FS3L@pz-SRpZ|C^a#q z5^P*jYHFTBa(-?>X-R5|9#|-u5y^KTHV8X|qJx8hfuV*Wiy@0Km|-QOpC;2S=AzWX zTRg>yC7H!(nW-u9NtK$6w^)i(bJA8a6mc^!F#PItwu%WYPAw{qNzF;gEQ;~ZOLZyA zEK60;RS5O-408<%_6%_hR`B$5@%M8L_H>L1cJ*})4si`qFpCKY@QFz@(ap(E&nzy< z%#KOTD~s{TOo}PaEJ@Xc21{{FL1uw|d}dxrYEfQdj(!SKoEGcDLs74w@|IkBYDs)S zc6xkKYH@yPQF3Z=JhEy5kQYIb$-q=)f;Eox@EefKj1+JnHay@!2|9%#n4yTBfdLXO zn#@I@JaCIG4V<WM@h6pL=A^`D7U$=HBMKaN5Q2w+f#H@cB!W{>TpXX9T9TNOSdu7$ z<aA@~PRFa?Pm}EyM|^x<Vs2`D{4K8d_}u)I(i{+*CqBNgG%*J%!yX@>lAjzOU&IUY z2PnWGP6Wj?gavYJ5gP*o11HEyAO;5`3mXRuSj<n8^A=l4WkF_MdJ!m~Z%Gzp7U;#7 zrRJsN7wMtIOc5yjZYhA}VR5U699zYDNr}a&MWB$qrG%;s6rvS+(DV@x3E(1Dkc&a? efw&XZ#kV+YAU?JOMOiT@o%1m9F!3<*FarQ;3{gk` diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-39.pyc deleted file mode 100644 index 4444383634cc4cff58b6e2d53db64ccce1a260e7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3460 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 diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-39.pyc deleted file mode 100644 index 04dee280ffb115c30d1eebd36b931e88e6cc71bd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1541 zcmYe~<>g{vU|^UdaWHi&3j@Pr5C<8vFfcGUFfcF_2QV-&q%fo~<}l<kMlmvi*i1Q0 zxy(__U^a6OOD<~^E11oa!<Ne)#SUh(=5XY4MsYGSxHF`%rLea!q_C&5HZw<YrEml@ zXmY*;*`>*Ni#;l{z%4T;Rg>`+k4t88Nl|7}X-Q^&o+jfh5yzzBlA^@q5;Sq%fW+kN z#Pn3R%)FG;B2C6yDh1i;@kOb{`K3k4sm1XrNXEpc<rl@5XQZa)B!etO#!N5|DljlG zq%uS?rZ7Y?r7%V@r!b{3w=hJpq_Cv0wlGAormzJwXtLiD3<nv5?3Sv+pwxn*)Z)~< zl46BK1+X;=$hPZoaVaP$D1>BW7AvIWrxq*Z<(DYrrKYARB<58r6cnWvBo-xte5;UH z4AEY!keryOkd&&Bl3A3RT#{3%P?}een4F!Oq6aoAnGwkgARllrFfcfSqA7uafuV*W ziy@1#n8%Bui4n|ZDwY7TOPIkt#uUaBre3Cgm0HFUmKvxEh)gqcI0F+y3Ns4>3qvzA zBSSEQAwzMH0Rtl#Mlvumq%a3FXtGo-^2tw3DOM=SNL9#9ElEsCEJ;*IE6UFWi$Fpk zEi)%oAv3QeUm-U&H@~P-Au%sSp(wSav?#AwArb5iP^ch>q(VtXVu?a&acZ$bW{D0s zn2J(!Dl_xa74q}Yjm|HEn^BZnSejXsnwy$e0tp|G!6BNAx405>a`MZgG7HR1{4`l_ zF&Cv4-r~>6PfpB<2RSdkAh9Il7E4}YZfX%I6pPpx7#K8}Zm|@n=A_+XtXj!X#K*wE z@T=9?DkiizwWv5IH76yrD8@f8)ukx2ELA~QA=J+^%rz+3GsH1i!PC#h-_JGJ(=jI4 z)z>vR#5G94EG8hpCnnKEHzz+mv$!NPJ0>-+EXF4@DW*8HBvls_r-|vQ#W4k$1^V%s zc_pbud5Jmt$cd*|9~_)|1(mnt(o;*~aVK&CQ2g_N5(YaD6AzORBNHRv|0)BF^s0y7 zm}F*<5l{?bgVGu}ZGp;y6oz01O-4U(xM(sLfvmg5mIls(xA>DvGjmenGmG<cz{we` z2tx2PFfiPbg(US<)T{|lKOpCWVu69FN*~kFc=h^evfbi{j|W9$eEco0`1suXl+v8k z`1o5q@$rSFi8)Xi_W1ae{N(ufB2ZWr2{SN2A{gREP*fLz99qQAz`y`17K=gYfrF8S zl|uk5=BLShi@hqd0F-vX3Fek$L1uwod|7H<N`8?ZO4JmAg6@_ASRNL!dMFXAmy}qX zS_BHzTS}<PK*3p|2TdIDkkBn+1qC6*KDc?MC7C(Jdf)^CPP<@NBKZdHrCS^}kRY)G S#bz<cbD%WB!^p$P!wdl2K(i|V diff --git a/env/Lib/site-packages/pip/_internal/distributions/base.py b/env/Lib/site-packages/pip/_internal/distributions/base.py index 78ee91e7..75ce2dc9 100644 --- a/env/Lib/site-packages/pip/_internal/distributions/base.py +++ b/env/Lib/site-packages/pip/_internal/distributions/base.py @@ -1,9 +1,7 @@ import abc -from typing import Optional - -from pip._vendor.pkg_resources import Distribution from pip._internal.index.package_finder import PackageFinder +from pip._internal.metadata.base import BaseDistribution from pip._internal.req import InstallRequirement @@ -23,17 +21,19 @@ class AbstractDistribution(metaclass=abc.ABCMeta): above metadata. """ - def __init__(self, req): - # type: (InstallRequirement) -> None + def __init__(self, req: InstallRequirement) -> None: super().__init__() self.req = req @abc.abstractmethod - def get_pkg_resources_distribution(self): - # type: () -> Optional[Distribution] + def get_metadata_distribution(self) -> BaseDistribution: raise NotImplementedError() @abc.abstractmethod - def prepare_distribution_metadata(self, finder, build_isolation): - # type: (PackageFinder, bool) -> None + def prepare_distribution_metadata( + self, + finder: PackageFinder, + build_isolation: bool, + check_build_deps: bool, + ) -> None: raise NotImplementedError() diff --git a/env/Lib/site-packages/pip/_internal/distributions/installed.py b/env/Lib/site-packages/pip/_internal/distributions/installed.py index b19dfacb..edb38aa1 100644 --- a/env/Lib/site-packages/pip/_internal/distributions/installed.py +++ b/env/Lib/site-packages/pip/_internal/distributions/installed.py @@ -1,9 +1,6 @@ -from typing import Optional - -from pip._vendor.pkg_resources import Distribution - from pip._internal.distributions.base import AbstractDistribution from pip._internal.index.package_finder import PackageFinder +from pip._internal.metadata import BaseDistribution class InstalledDistribution(AbstractDistribution): @@ -13,10 +10,14 @@ class InstalledDistribution(AbstractDistribution): been computed. """ - def get_pkg_resources_distribution(self): - # type: () -> Optional[Distribution] + def get_metadata_distribution(self) -> BaseDistribution: + assert self.req.satisfied_by is not None, "not actually installed" return self.req.satisfied_by - def prepare_distribution_metadata(self, finder, build_isolation): - # type: (PackageFinder, bool) -> None + def prepare_distribution_metadata( + self, + finder: PackageFinder, + build_isolation: bool, + check_build_deps: bool, + ) -> None: pass diff --git a/env/Lib/site-packages/pip/_internal/distributions/sdist.py b/env/Lib/site-packages/pip/_internal/distributions/sdist.py index c873a9f1..4c256479 100644 --- a/env/Lib/site-packages/pip/_internal/distributions/sdist.py +++ b/env/Lib/site-packages/pip/_internal/distributions/sdist.py @@ -1,12 +1,11 @@ import logging -from typing import Set, Tuple - -from pip._vendor.pkg_resources import Distribution +from typing import Iterable, Set, Tuple from pip._internal.build_env import BuildEnvironment from pip._internal.distributions.base import AbstractDistribution from pip._internal.exceptions import InstallationError from pip._internal.index.package_finder import PackageFinder +from pip._internal.metadata import BaseDistribution from pip._internal.utils.subprocess import runner_with_spinner_message logger = logging.getLogger(__name__) @@ -19,40 +18,49 @@ class SourceDistribution(AbstractDistribution): generated, either using PEP 517 or using the legacy `setup.py egg_info`. """ - def get_pkg_resources_distribution(self): - # type: () -> Distribution + def get_metadata_distribution(self) -> BaseDistribution: return self.req.get_dist() - def prepare_distribution_metadata(self, finder, build_isolation): - # type: (PackageFinder, bool) -> None + def prepare_distribution_metadata( + self, + finder: PackageFinder, + build_isolation: bool, + check_build_deps: bool, + ) -> None: # Load pyproject.toml, to determine whether PEP 517 is to be used self.req.load_pyproject_toml() # Set up the build isolation, if this requirement should be isolated should_isolate = self.req.use_pep517 and build_isolation if should_isolate: - self._setup_isolation(finder) - - self.req.prepare_metadata() - - def _setup_isolation(self, finder): - # type: (PackageFinder) -> None - def _raise_conflicts(conflicting_with, conflicting_reqs): - # type: (str, Set[Tuple[str, str]]) -> None - format_string = ( - "Some build dependencies for {requirement} " - "conflict with {conflicting_with}: {description}." + # Setup an isolated environment and install the build backend static + # requirements in it. + self._prepare_build_backend(finder) + # Check that if the requirement is editable, it either supports PEP 660 or + # has a setup.py or a setup.cfg. This cannot be done earlier because we need + # to setup the build backend to verify it supports build_editable, nor can + # it be done later, because we want to avoid installing build requirements + # needlessly. Doing it here also works around setuptools generating + # UNKNOWN.egg-info when running get_requires_for_build_wheel on a directory + # without setup.py nor setup.cfg. + self.req.isolated_editable_sanity_check() + # Install the dynamic build requirements. + self._install_build_reqs(finder) + # Check if the current environment provides build dependencies + should_check_deps = self.req.use_pep517 and check_build_deps + if should_check_deps: + pyproject_requires = self.req.pyproject_requires + assert pyproject_requires is not None + conflicting, missing = self.req.build_env.check_requirements( + pyproject_requires ) - error_message = format_string.format( - requirement=self.req, - conflicting_with=conflicting_with, - description=", ".join( - f"{installed} is incompatible with {wanted}" - for installed, wanted in sorted(conflicting) - ), - ) - raise InstallationError(error_message) + if conflicting: + self._raise_conflicts("the backend dependencies", conflicting) + if missing: + self._raise_missing_reqs(missing) + self.req.prepare_metadata() + def _prepare_build_backend(self, finder: PackageFinder) -> None: # Isolate in a BuildEnvironment and install the build-time # requirements. pyproject_requires = self.req.pyproject_requires @@ -60,13 +68,13 @@ class SourceDistribution(AbstractDistribution): self.req.build_env = BuildEnvironment() self.req.build_env.install_requirements( - finder, pyproject_requires, "overlay", "Installing build dependencies" + finder, pyproject_requires, "overlay", kind="build dependencies" ) conflicting, missing = self.req.build_env.check_requirements( self.req.requirements_to_check ) if conflicting: - _raise_conflicts("PEP 517/518 supported requirements", conflicting) + self._raise_conflicts("PEP 517/518 supported requirements", conflicting) if missing: logger.warning( "Missing build requirements in pyproject.toml for %s.", @@ -77,19 +85,66 @@ class SourceDistribution(AbstractDistribution): "pip cannot fall back to setuptools without %s.", " and ".join(map(repr, sorted(missing))), ) - # Install any extra build dependencies that the backend requests. - # This must be done in a second pass, as the pyproject.toml - # dependencies must be installed before we can call the backend. + + def _get_build_requires_wheel(self) -> Iterable[str]: with self.req.build_env: runner = runner_with_spinner_message("Getting requirements to build wheel") backend = self.req.pep517_backend assert backend is not None with backend.subprocess_runner(runner): - reqs = backend.get_requires_for_build_wheel() + return backend.get_requires_for_build_wheel() - conflicting, missing = self.req.build_env.check_requirements(reqs) + def _get_build_requires_editable(self) -> Iterable[str]: + with self.req.build_env: + runner = runner_with_spinner_message( + "Getting requirements to build editable" + ) + backend = self.req.pep517_backend + assert backend is not None + with backend.subprocess_runner(runner): + return backend.get_requires_for_build_editable() + + def _install_build_reqs(self, finder: PackageFinder) -> None: + # Install any extra build dependencies that the backend requests. + # This must be done in a second pass, as the pyproject.toml + # dependencies must be installed before we can call the backend. + if ( + self.req.editable + and self.req.permit_editable_wheels + and self.req.supports_pyproject_editable() + ): + build_reqs = self._get_build_requires_editable() + else: + build_reqs = self._get_build_requires_wheel() + conflicting, missing = self.req.build_env.check_requirements(build_reqs) if conflicting: - _raise_conflicts("the backend dependencies", conflicting) + self._raise_conflicts("the backend dependencies", conflicting) self.req.build_env.install_requirements( - finder, missing, "normal", "Installing backend dependencies" + finder, missing, "normal", kind="backend dependencies" + ) + + def _raise_conflicts( + self, conflicting_with: str, conflicting_reqs: Set[Tuple[str, str]] + ) -> None: + format_string = ( + "Some build dependencies for {requirement} " + "conflict with {conflicting_with}: {description}." + ) + error_message = format_string.format( + requirement=self.req, + conflicting_with=conflicting_with, + description=", ".join( + f"{installed} is incompatible with {wanted}" + for installed, wanted in sorted(conflicting_reqs) + ), + ) + raise InstallationError(error_message) + + def _raise_missing_reqs(self, missing: Set[str]) -> None: + format_string = ( + "Some build dependencies for {requirement} are missing: {missing}." + ) + error_message = format_string.format( + requirement=self.req, missing=", ".join(map(repr, sorted(missing))) ) + raise InstallationError(error_message) diff --git a/env/Lib/site-packages/pip/_internal/distributions/wheel.py b/env/Lib/site-packages/pip/_internal/distributions/wheel.py index d0384797..03aac775 100644 --- a/env/Lib/site-packages/pip/_internal/distributions/wheel.py +++ b/env/Lib/site-packages/pip/_internal/distributions/wheel.py @@ -1,10 +1,12 @@ -from zipfile import ZipFile - -from pip._vendor.pkg_resources import Distribution +from pip._vendor.packaging.utils import canonicalize_name from pip._internal.distributions.base import AbstractDistribution from pip._internal.index.package_finder import PackageFinder -from pip._internal.utils.wheel import pkg_resources_distribution_for_wheel +from pip._internal.metadata import ( + BaseDistribution, + FilesystemWheel, + get_wheel_distribution, +) class WheelDistribution(AbstractDistribution): @@ -13,22 +15,20 @@ class WheelDistribution(AbstractDistribution): This does not need any preparation as wheels can be directly unpacked. """ - def get_pkg_resources_distribution(self): - # type: () -> Distribution + def get_metadata_distribution(self) -> BaseDistribution: """Loads the metadata from the wheel file into memory and returns a Distribution that uses it, not relying on the wheel file or requirement. """ - # Set as part of preparation during download. - assert self.req.local_file_path - # Wheels are never unnamed. - assert self.req.name - - with ZipFile(self.req.local_file_path, allowZip64=True) as z: - return pkg_resources_distribution_for_wheel( - z, self.req.name, self.req.local_file_path - ) - - def prepare_distribution_metadata(self, finder, build_isolation): - # type: (PackageFinder, bool) -> None + assert self.req.local_file_path, "Set as part of preparation during download" + assert self.req.name, "Wheels are never unnamed" + wheel = FilesystemWheel(self.req.local_file_path) + return get_wheel_distribution(wheel, canonicalize_name(self.req.name)) + + def prepare_distribution_metadata( + self, + finder: PackageFinder, + build_isolation: bool, + check_build_deps: bool, + ) -> None: pass diff --git a/env/Lib/site-packages/pip/_internal/exceptions.py b/env/Lib/site-packages/pip/_internal/exceptions.py index 8aacf812..d95fe44b 100644 --- a/env/Lib/site-packages/pip/_internal/exceptions.py +++ b/env/Lib/site-packages/pip/_internal/exceptions.py @@ -1,22 +1,181 @@ -"""Exceptions used throughout package""" +"""Exceptions used throughout package. + +This module MUST NOT try to import from anything within `pip._internal` to +operate. This is expected to be importable from any/all files within the +subpackage and, thus, should not depend on them. +""" import configparser +import contextlib +import locale +import logging +import pathlib +import re +import sys from itertools import chain, groupby, repeat -from typing import TYPE_CHECKING, Dict, List, Optional +from typing import TYPE_CHECKING, Dict, Iterator, List, Optional, Union -from pip._vendor.pkg_resources import Distribution from pip._vendor.requests.models import Request, Response +from pip._vendor.rich.console import Console, ConsoleOptions, RenderResult +from pip._vendor.rich.markup import escape +from pip._vendor.rich.text import Text if TYPE_CHECKING: from hashlib import _Hash + from typing import Literal + from pip._internal.metadata import BaseDistribution from pip._internal.req.req_install import InstallRequirement +logger = logging.getLogger(__name__) + + +# +# Scaffolding +# +def _is_kebab_case(s: str) -> bool: + return re.match(r"^[a-z]+(-[a-z]+)*$", s) is not None + + +def _prefix_with_indent( + s: Union[Text, str], + console: Console, + *, + prefix: str, + indent: str, +) -> Text: + if isinstance(s, Text): + text = s + else: + text = console.render_str(s) + + return console.render_str(prefix, overflow="ignore") + console.render_str( + f"\n{indent}", overflow="ignore" + ).join(text.split(allow_blank=True)) + class PipError(Exception): - """Base pip exception""" + """The base pip error.""" + + +class DiagnosticPipError(PipError): + """An error, that presents diagnostic information to the user. + + This contains a bunch of logic, to enable pretty presentation of our error + messages. Each error gets a unique reference. Each error can also include + additional context, a hint and/or a note -- which are presented with the + main error message in a consistent style. + + This is adapted from the error output styling in `sphinx-theme-builder`. + """ + + reference: str + + def __init__( + self, + *, + kind: 'Literal["error", "warning"]' = "error", + reference: Optional[str] = None, + message: Union[str, Text], + context: Optional[Union[str, Text]], + hint_stmt: Optional[Union[str, Text]], + note_stmt: Optional[Union[str, Text]] = None, + link: Optional[str] = None, + ) -> None: + # Ensure a proper reference is provided. + if reference is None: + assert hasattr(self, "reference"), "error reference not provided!" + reference = self.reference + assert _is_kebab_case(reference), "error reference must be kebab-case!" + + self.kind = kind + self.reference = reference + + self.message = message + self.context = context + + self.note_stmt = note_stmt + self.hint_stmt = hint_stmt + + self.link = link + + super().__init__(f"<{self.__class__.__name__}: {self.reference}>") + + def __repr__(self) -> str: + return ( + f"<{self.__class__.__name__}(" + f"reference={self.reference!r}, " + f"message={self.message!r}, " + f"context={self.context!r}, " + f"note_stmt={self.note_stmt!r}, " + f"hint_stmt={self.hint_stmt!r}" + ")>" + ) + + def __rich_console__( + self, + console: Console, + options: ConsoleOptions, + ) -> RenderResult: + colour = "red" if self.kind == "error" else "yellow" + + yield f"[{colour} bold]{self.kind}[/]: [bold]{self.reference}[/]" + yield "" + + if not options.ascii_only: + # Present the main message, with relevant context indented. + if self.context is not None: + yield _prefix_with_indent( + self.message, + console, + prefix=f"[{colour}]×[/] ", + indent=f"[{colour}]│[/] ", + ) + yield _prefix_with_indent( + self.context, + console, + prefix=f"[{colour}]╰─>[/] ", + indent=f"[{colour}] [/] ", + ) + else: + yield _prefix_with_indent( + self.message, + console, + prefix="[red]×[/] ", + indent=" ", + ) + else: + yield self.message + if self.context is not None: + yield "" + yield self.context + + if self.note_stmt is not None or self.hint_stmt is not None: + yield "" + + if self.note_stmt is not None: + yield _prefix_with_indent( + self.note_stmt, + console, + prefix="[magenta bold]note[/]: ", + indent=" ", + ) + if self.hint_stmt is not None: + yield _prefix_with_indent( + self.hint_stmt, + console, + prefix="[cyan bold]hint[/]: ", + indent=" ", + ) + + if self.link is not None: + yield "" + yield f"Link: {self.link}" +# +# Actual Errors +# class ConfigurationError(PipError): """General exception in configuration""" @@ -29,17 +188,54 @@ class UninstallationError(PipError): """General exception during uninstallation""" +class MissingPyProjectBuildRequires(DiagnosticPipError): + """Raised when pyproject.toml has `build-system`, but no `build-system.requires`.""" + + reference = "missing-pyproject-build-system-requires" + + def __init__(self, *, package: str) -> None: + super().__init__( + message=f"Can not process {escape(package)}", + context=Text( + "This package has an invalid pyproject.toml file.\n" + "The [build-system] table is missing the mandatory `requires` key." + ), + note_stmt="This is an issue with the package mentioned above, not pip.", + hint_stmt=Text("See PEP 518 for the detailed specification."), + ) + + +class InvalidPyProjectBuildRequires(DiagnosticPipError): + """Raised when pyproject.toml an invalid `build-system.requires`.""" + + reference = "invalid-pyproject-build-system-requires" + + def __init__(self, *, package: str, reason: str) -> None: + super().__init__( + message=f"Can not process {escape(package)}", + context=Text( + "This package has an invalid `build-system.requires` key in " + f"pyproject.toml.\n{reason}" + ), + note_stmt="This is an issue with the package mentioned above, not pip.", + hint_stmt=Text("See PEP 518 for the detailed specification."), + ) + + class NoneMetadataError(PipError): - """ - Raised when accessing "METADATA" or "PKG-INFO" metadata for a - pip._vendor.pkg_resources.Distribution object and - `dist.has_metadata('METADATA')` returns True but - `dist.get_metadata('METADATA')` returns None (and similarly for - "PKG-INFO"). + """Raised when accessing a Distribution's "METADATA" or "PKG-INFO". + + This signifies an inconsistency, when the Distribution claims to have + the metadata file (if not, raise ``FileNotFoundError`` instead), but is + not actually able to produce its content. This may be due to permission + errors. """ - def __init__(self, dist, metadata_name): - # type: (Distribution, str) -> None + def __init__( + self, + dist: "BaseDistribution", + metadata_name: str, + ) -> None: """ :param dist: A Distribution object. :param metadata_name: The name of the metadata being accessed @@ -48,28 +244,24 @@ class NoneMetadataError(PipError): self.dist = dist self.metadata_name = metadata_name - def __str__(self): - # type: () -> str + def __str__(self) -> str: # Use `dist` in the error message because its stringification # includes more information, like the version and location. - return ( - 'None {} metadata found for distribution: {}'.format( - self.metadata_name, self.dist, - ) + return "None {} metadata found for distribution: {}".format( + self.metadata_name, + self.dist, ) class UserInstallationInvalid(InstallationError): """A --user install is requested on an environment without user site.""" - def __str__(self): - # type: () -> str + def __str__(self) -> str: return "User base directory is not specified" class InvalidSchemeCombination(InstallationError): - def __str__(self): - # type: () -> str + def __str__(self) -> str: before = ", ".join(str(a) for a in self.args[:-1]) return f"Cannot set {before} and {self.args[-1]} together" @@ -102,8 +294,12 @@ class PreviousBuildDirError(PipError): class NetworkConnectionError(PipError): """HTTP connection error""" - def __init__(self, error_msg, response=None, request=None): - # type: (str, Response, Request) -> None + def __init__( + self, + error_msg: str, + response: Optional[Response] = None, + request: Optional[Request] = None, + ) -> None: """ Initialize NetworkConnectionError with `request` and `response` objects. @@ -111,13 +307,15 @@ class NetworkConnectionError(PipError): self.response = response self.request = request self.error_msg = error_msg - if (self.response is not None and not self.request and - hasattr(response, 'request')): + if ( + self.response is not None + and not self.request + and hasattr(response, "request") + ): self.request = self.response.request super().__init__(error_msg, response, request) - def __str__(self): - # type: () -> str + def __str__(self) -> str: return str(self.error_msg) @@ -129,74 +327,122 @@ class UnsupportedWheel(InstallationError): """Unsupported wheel.""" +class InvalidWheel(InstallationError): + """Invalid (e.g. corrupt) wheel.""" + + def __init__(self, location: str, name: str): + self.location = location + self.name = name + + def __str__(self) -> str: + return f"Wheel '{self.name}' located at {self.location} is invalid." + + class MetadataInconsistent(InstallationError): """Built metadata contains inconsistent information. This is raised when the metadata contains values (e.g. name and version) - that do not match the information previously obtained from sdist filename - or user-supplied ``#egg=`` value. + that do not match the information previously obtained from sdist filename, + user-supplied ``#egg=`` value, or an install requirement name. """ - def __init__(self, ireq, field, f_val, m_val): - # type: (InstallRequirement, str, str, str) -> None + + def __init__( + self, ireq: "InstallRequirement", field: str, f_val: str, m_val: str + ) -> None: self.ireq = ireq self.field = field self.f_val = f_val self.m_val = m_val - def __str__(self): - # type: () -> str - template = ( - "Requested {} has inconsistent {}: " - "filename has {!r}, but metadata has {!r}" + def __str__(self) -> str: + return ( + f"Requested {self.ireq} has inconsistent {self.field}: " + f"expected {self.f_val!r}, but metadata has {self.m_val!r}" ) - return template.format(self.ireq, self.field, self.f_val, self.m_val) -class InstallationSubprocessError(InstallationError): - """A subprocess call failed during installation.""" - def __init__(self, returncode, description): - # type: (int, str) -> None - self.returncode = returncode - self.description = description +class InstallationSubprocessError(DiagnosticPipError, InstallationError): + """A subprocess call failed.""" - def __str__(self): - # type: () -> str - return ( - "Command errored out with exit status {}: {} " - "Check the logs for full command output." - ).format(self.returncode, self.description) + reference = "subprocess-exited-with-error" + + def __init__( + self, + *, + command_description: str, + exit_code: int, + output_lines: Optional[List[str]], + ) -> None: + if output_lines is None: + output_prompt = Text("See above for output.") + else: + output_prompt = ( + Text.from_markup(f"[red][{len(output_lines)} lines of output][/]\n") + + Text("".join(output_lines)) + + Text.from_markup(R"[red]\[end of output][/]") + ) + + super().__init__( + message=( + f"[green]{escape(command_description)}[/] did not run successfully.\n" + f"exit code: {exit_code}" + ), + context=output_prompt, + hint_stmt=None, + note_stmt=( + "This error originates from a subprocess, and is likely not a " + "problem with pip." + ), + ) + + self.command_description = command_description + self.exit_code = exit_code + + def __str__(self) -> str: + return f"{self.command_description} exited with {self.exit_code}" + + +class MetadataGenerationFailed(InstallationSubprocessError, InstallationError): + reference = "metadata-generation-failed" + + def __init__( + self, + *, + package_details: str, + ) -> None: + super(InstallationSubprocessError, self).__init__( + message="Encountered error while generating package metadata.", + context=escape(package_details), + hint_stmt="See above for details.", + note_stmt="This is an issue with the package mentioned above, not pip.", + ) + + def __str__(self) -> str: + return "metadata generation failed" class HashErrors(InstallationError): """Multiple HashError instances rolled into one for reporting""" - def __init__(self): - # type: () -> None - self.errors = [] # type: List[HashError] + def __init__(self) -> None: + self.errors: List["HashError"] = [] - def append(self, error): - # type: (HashError) -> None + def append(self, error: "HashError") -> None: self.errors.append(error) - def __str__(self): - # type: () -> str + def __str__(self) -> str: lines = [] self.errors.sort(key=lambda e: e.order) for cls, errors_of_cls in groupby(self.errors, lambda e: e.__class__): lines.append(cls.head) lines.extend(e.body() for e in errors_of_cls) if lines: - return '\n'.join(lines) - return '' + return "\n".join(lines) + return "" - def __nonzero__(self): - # type: () -> bool + def __bool__(self) -> bool: return bool(self.errors) - def __bool__(self): - # type: () -> bool - return self.__nonzero__() - class HashError(InstallationError): """ @@ -214,12 +460,12 @@ class HashError(InstallationError): typically available earlier. """ - req = None # type: Optional[InstallRequirement] - head = '' - order = -1 # type: int - def body(self): - # type: () -> str + req: Optional["InstallRequirement"] = None + head = "" + order: int = -1 + + def body(self) -> str: """Return a summary of me for display under the heading. This default implementation simply prints a description of the @@ -229,21 +475,19 @@ class HashError(InstallationError): its link already populated by the resolver's _populate_link(). """ - return f' {self._requirement_name()}' + return f" {self._requirement_name()}" - def __str__(self): - # type: () -> str - return f'{self.head}\n{self.body()}' + def __str__(self) -> str: + return f"{self.head}\n{self.body()}" - def _requirement_name(self): - # type: () -> str + def _requirement_name(self) -> str: """Return a description of the requirement that triggered me. This default implementation returns long description of the req, with line numbers """ - return str(self.req) if self.req else 'unknown package' + return str(self.req) if self.req else "unknown package" class VcsHashUnsupported(HashError): @@ -251,8 +495,10 @@ class VcsHashUnsupported(HashError): we don't have a method for hashing those.""" order = 0 - head = ("Can't verify hashes for these requirements because we don't " - "have a way to hash version control repositories:") + head = ( + "Can't verify hashes for these requirements because we don't " + "have a way to hash version control repositories:" + ) class DirectoryUrlHashUnsupported(HashError): @@ -260,32 +506,34 @@ class DirectoryUrlHashUnsupported(HashError): we don't have a method for hashing those.""" order = 1 - head = ("Can't verify hashes for these file:// requirements because they " - "point to directories:") + head = ( + "Can't verify hashes for these file:// requirements because they " + "point to directories:" + ) class HashMissing(HashError): """A hash was needed for a requirement but is absent.""" order = 2 - head = ('Hashes are required in --require-hashes mode, but they are ' - 'missing from some requirements. Here is a list of those ' - 'requirements along with the hashes their downloaded archives ' - 'actually had. Add lines like these to your requirements files to ' - 'prevent tampering. (If you did not enable --require-hashes ' - 'manually, note that it turns on automatically when any package ' - 'has a hash.)') - - def __init__(self, gotten_hash): - # type: (str) -> None + head = ( + "Hashes are required in --require-hashes mode, but they are " + "missing from some requirements. Here is a list of those " + "requirements along with the hashes their downloaded archives " + "actually had. Add lines like these to your requirements files to " + "prevent tampering. (If you did not enable --require-hashes " + "manually, note that it turns on automatically when any package " + "has a hash.)" + ) + + def __init__(self, gotten_hash: str) -> None: """ :param gotten_hash: The hash of the (possibly malicious) archive we just downloaded """ self.gotten_hash = gotten_hash - def body(self): - # type: () -> str + def body(self) -> str: # Dodge circular import. from pip._internal.utils.hashes import FAVORITE_HASH @@ -294,13 +542,16 @@ class HashMissing(HashError): # In the case of URL-based requirements, display the original URL # seen in the requirements file rather than the package name, # so the output can be directly copied into the requirements file. - package = (self.req.original_link if self.req.original_link - # In case someone feeds something downright stupid - # to InstallRequirement's constructor. - else getattr(self.req, 'req', None)) - return ' {} --hash={}:{}'.format(package or 'unknown package', - FAVORITE_HASH, - self.gotten_hash) + package = ( + self.req.original_link + if self.req.is_direct + # In case someone feeds something downright stupid + # to InstallRequirement's constructor. + else getattr(self.req, "req", None) + ) + return " {} --hash={}:{}".format( + package or "unknown package", FAVORITE_HASH, self.gotten_hash + ) class HashUnpinned(HashError): @@ -308,8 +559,10 @@ class HashUnpinned(HashError): version.""" order = 3 - head = ('In --require-hashes mode, all requirements must have their ' - 'versions pinned with ==. These do not:') + head = ( + "In --require-hashes mode, all requirements must have their " + "versions pinned with ==. These do not:" + ) class HashMismatch(HashError): @@ -321,14 +574,16 @@ class HashMismatch(HashError): improve its error message. """ - order = 4 - head = ('THESE PACKAGES DO NOT MATCH THE HASHES FROM THE REQUIREMENTS ' - 'FILE. If you have updated the package versions, please update ' - 'the hashes. Otherwise, examine the package contents carefully; ' - 'someone may have tampered with them.') - def __init__(self, allowed, gots): - # type: (Dict[str, List[str]], Dict[str, _Hash]) -> None + order = 4 + head = ( + "THESE PACKAGES DO NOT MATCH THE HASHES FROM THE REQUIREMENTS " + "FILE. If you have updated the package versions, please update " + "the hashes. Otherwise, examine the package contents carefully; " + "someone may have tampered with them." + ) + + def __init__(self, allowed: Dict[str, List[str]], gots: Dict[str, "_Hash"]) -> None: """ :param allowed: A dict of algorithm names pointing to lists of allowed hex digests @@ -338,13 +593,10 @@ class HashMismatch(HashError): self.allowed = allowed self.gots = gots - def body(self): - # type: () -> str - return ' {}:\n{}'.format(self._requirement_name(), - self._hash_comparison()) + def body(self) -> str: + return " {}:\n{}".format(self._requirement_name(), self._hash_comparison()) - def _hash_comparison(self): - # type: () -> str + def _hash_comparison(self) -> str: """ Return a comparison of actual and expected hash values. @@ -355,20 +607,22 @@ class HashMismatch(HashError): Got bcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdef """ - def hash_then_or(hash_name): - # type: (str) -> chain[str] + + def hash_then_or(hash_name: str) -> "chain[str]": # For now, all the decent hashes have 6-char names, so we can get # away with hard-coding space literals. - return chain([hash_name], repeat(' or')) + return chain([hash_name], repeat(" or")) - lines = [] # type: List[str] + lines: List[str] = [] for hash_name, expecteds in self.allowed.items(): prefix = hash_then_or(hash_name) - lines.extend((' Expected {} {}'.format(next(prefix), e)) - for e in expecteds) - lines.append(' Got {}\n'.format( - self.gots[hash_name].hexdigest())) - return '\n'.join(lines) + lines.extend( + (" Expected {} {}".format(next(prefix), e)) for e in expecteds + ) + lines.append( + " Got {}\n".format(self.gots[hash_name].hexdigest()) + ) + return "\n".join(lines) class UnsupportedPythonVersion(InstallationError): @@ -377,21 +631,103 @@ class UnsupportedPythonVersion(InstallationError): class ConfigurationFileCouldNotBeLoaded(ConfigurationError): - """When there are errors while loading a configuration file - """ - - def __init__(self, reason="could not be loaded", fname=None, error=None): - # type: (str, Optional[str], Optional[configparser.Error]) -> None + """When there are errors while loading a configuration file""" + + def __init__( + self, + reason: str = "could not be loaded", + fname: Optional[str] = None, + error: Optional[configparser.Error] = None, + ) -> None: super().__init__(error) self.reason = reason self.fname = fname self.error = error - def __str__(self): - # type: () -> str + def __str__(self) -> str: if self.fname is not None: message_part = f" in {self.fname}." else: assert self.error is not None message_part = f".\n{self.error}\n" return f"Configuration file {self.reason}{message_part}" + + +_DEFAULT_EXTERNALLY_MANAGED_ERROR = f"""\ +The Python environment under {sys.prefix} is managed externally, and may not be +manipulated by the user. Please use specific tooling from the distributor of +the Python installation to interact with this environment instead. +""" + + +class ExternallyManagedEnvironment(DiagnosticPipError): + """The current environment is externally managed. + + This is raised when the current environment is externally managed, as + defined by `PEP 668`_. The ``EXTERNALLY-MANAGED`` configuration is checked + and displayed when the error is bubbled up to the user. + + :param error: The error message read from ``EXTERNALLY-MANAGED``. + """ + + reference = "externally-managed-environment" + + def __init__(self, error: Optional[str]) -> None: + if error is None: + context = Text(_DEFAULT_EXTERNALLY_MANAGED_ERROR) + else: + context = Text(error) + super().__init__( + message="This environment is externally managed", + context=context, + note_stmt=( + "If you believe this is a mistake, please contact your " + "Python installation or OS distribution provider. " + "You can override this, at the risk of breaking your Python " + "installation or OS, by passing --break-system-packages." + ), + hint_stmt=Text("See PEP 668 for the detailed specification."), + ) + + @staticmethod + def _iter_externally_managed_error_keys() -> Iterator[str]: + # LC_MESSAGES is in POSIX, but not the C standard. The most common + # platform that does not implement this category is Windows, where + # using other categories for console message localization is equally + # unreliable, so we fall back to the locale-less vendor message. This + # can always be re-evaluated when a vendor proposes a new alternative. + try: + category = locale.LC_MESSAGES + except AttributeError: + lang: Optional[str] = None + else: + lang, _ = locale.getlocale(category) + if lang is not None: + yield f"Error-{lang}" + for sep in ("-", "_"): + before, found, _ = lang.partition(sep) + if not found: + continue + yield f"Error-{before}" + yield "Error" + + @classmethod + def from_config( + cls, + config: Union[pathlib.Path, str], + ) -> "ExternallyManagedEnvironment": + parser = configparser.ConfigParser(interpolation=None) + try: + parser.read(config, encoding="utf-8") + section = parser["externally-managed"] + for key in cls._iter_externally_managed_error_keys(): + with contextlib.suppress(KeyError): + return cls(section[key]) + except KeyError: + pass + except (OSError, UnicodeDecodeError, configparser.ParsingError): + from pip._internal.utils._log import VERBOSE + + exc_info = logger.isEnabledFor(VERBOSE) + logger.warning("Failed to read %s", config, exc_info=exc_info) + return cls(None) diff --git a/env/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 939ce339da6f6dd46dc49dfe7dc6f01388fc675d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 254 zcmYe~<>g{vU|^UdaWGYmfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}WzJ@Zmh zD-<&GN>YmwlS?x5^AwWvQ&PG7G#PKP$H%ASC&$OHWGG@{V1N+68l0_SLW@(2iepl9 zQZkET{PR*>iZaVm6?7Fs{XD~5gMvLn9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u z5>0e-^3yYmOER-#QuE4Ud@_?_iZe@6bqf-cvlG)(i(?8h3-sf`4$4c+(a!|APd`3B dGcU6wK3=b&@)n0pZhlH>PO2TqPoF`a1OUECN7DcR diff --git a/env/Lib/site-packages/pip/_internal/index/__pycache__/collector.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/index/__pycache__/collector.cpython-39.pyc deleted file mode 100644 index 27d81be3d6ba5610338b7779be4547135d610ef2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15110 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 diff --git a/env/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-39.pyc deleted file mode 100644 index 5dfc01e38d37202e7a989098e24e25fbc388311d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26637 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�(tYJuDs$l}1g4fJg!<fxf#8Jb< z#K6c9%uonA8HiyvLke>Z<7|ex%;4G^v}uSX@f)m}2r6}oQ$Z&yl;jtwLx&I`n^G0> zA&ZWoBR=ZIpyh^;W6{Bfp+TFC&?Y17%rDT|85^h;J8c_iF0=!8(m*2@3Q91QN(vgq zC8@cZ3ebg1ph^xjHvp4|3|c^qM?EMKvQ`0V3oeI&M@GOMJ<xdunZ*iusi~lY2Z}TE zl0o~p!RHP^{F7OgngaHdLP~xr<lyGKRM0>cc+C;G-3eLKn~|yjUhtcfnwJhba2qt{ znF^l30G;8bUJNk=)TPt|?I497(`p4>9&Tr62R{W>!B#;%Ek8d#J}I$C*HF(u9c&9o z1*%t}>U5J5ix5h{Cmw_M%)!cy_~O(84Oqy5m&ikW237=Ft8D?c;TNN>UzGsDpWuFi zf+lm(G*A`-owZi92GoCMxy1o9t_U=Pb&D~xXbwmTIA?$fQ1-YbhTSbEK_wEn8Wk2` z<X~iC6k+6IED~U3V8BS}purRH@EvH*4RQ)Q=p6MFMsbE(Cg?eqjFoDj#fP9FQqUZN z0YeQ#4O0p@)q{p#i)}!n;L&O3s$T)1gZaVp2+-6AJ0%fZohB;aOP=5`!j?qAkqiqF zTuC3a=>u_QBKWL+Jq1_2bUlT%{Cr&_JwveZc#<?c?hz>xdd46$v4fYmgG~Wtm!#C3 z{JeC~AUh<pK$d}PGJyjc8jnSMppp$7g}l)4hzB2L2R;xFt!gO(H5i|O;!Xh6YvE*K z6k-I8*Me#l7DlkFCZn6CUlI7o5>Sy^^bV9LK7k0(67XAWC6%BVt0GX_u?RFQR|G1} zia^C#5vWC41RAX^0>ychXhCLyUVK?<UP^wE9>jl{dFkMT%%h~R%ISel{3`+-&TvZ_ zyMoe^%$#EIjBS)Gb`{VtC;}zUBG3jcaFu^c0<0Q*SaV)tjvjOiN`78(5vYDI0$2Q? zFaa-tzXdTHt{S}VLJvBclV4N>8VD!?jkMpALp3%xKP5G%SP$NvECNmM+)~D>2-^OI zE;R(N!Mi1iRV8SkuL#sWzom#(9(lb@kvOOxRKcMRdKm<0i9%X&5ooOMmJ(K_C~Jto ztEp~5q6{7;P_Ke_cYyaA+!91JsVKFuNE+lAw7>*Mp&n>_tE93ZwYUhhkP6*!h#JTS zrXpF8A&~R{w;iGYIur+<??8`Xh>G0I;$-kD7W62ENF!1us1t=<O=%uT6)5F`&bP#F z4R}EhXb=o^av^9iIQ|xAdTNOe_-uYi(+D(_ShOCLk3eH{w>X?Y_hf`5rr#2VcQJz@ zhb?)hR)SBRgseOOoe2e5r3qe&4j$wJwOJr#04P5r<#9y0&0&)ZK3dTZ)Kx5wV_;xl zVFgWagRlw{4<i&ZNw5jP*w|?%4rVSU2_~`sOdJe<xwQG}8F)Cn`9%11`RW<``05!z Ikds3i0Kkl>UH||9 diff --git a/env/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-39.pyc deleted file mode 100644 index 95716c84af0063ff8579f014fe617974883333f9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7219 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 diff --git a/env/Lib/site-packages/pip/_internal/index/collector.py b/env/Lib/site-packages/pip/_internal/index/collector.py index 0721e368..b3e293ea 100644 --- a/env/Lib/site-packages/pip/_internal/index/collector.py +++ b/env/Lib/site-packages/pip/_internal/index/collector.py @@ -2,30 +2,32 @@ The main purpose of this module is to expose LinkCollector.collect_sources(). """ -import cgi import collections +import email.message import functools -import html import itertools +import json import logging import os -import re import urllib.parse import urllib.request -import xml.etree.ElementTree +from html.parser import HTMLParser from optparse import Values from typing import ( + TYPE_CHECKING, Callable, + Dict, Iterable, List, MutableMapping, NamedTuple, Optional, Sequence, + Tuple, Union, ) -from pip._vendor import html5lib, requests +from pip._vendor import requests from pip._vendor.requests import Response from pip._vendor.requests.exceptions import RetryError, SSLError @@ -35,92 +37,111 @@ from pip._internal.models.search_scope import SearchScope from pip._internal.network.session import PipSession from pip._internal.network.utils import raise_for_status from pip._internal.utils.filetypes import is_archive_file -from pip._internal.utils.misc import pairwise, redact_auth_from_url +from pip._internal.utils.misc import redact_auth_from_url from pip._internal.vcs import vcs from .sources import CandidatesFromPage, LinkSource, build_source +if TYPE_CHECKING: + from typing import Protocol +else: + Protocol = object + logger = logging.getLogger(__name__) -HTMLElement = xml.etree.ElementTree.Element ResponseHeaders = MutableMapping[str, str] -def _match_vcs_scheme(url): - # type: (str) -> Optional[str] +def _match_vcs_scheme(url: str) -> Optional[str]: """Look for VCS schemes in the URL. Returns the matched VCS scheme, or None if there's no match. """ for scheme in vcs.schemes: - if url.lower().startswith(scheme) and url[len(scheme)] in '+:': + if url.lower().startswith(scheme) and url[len(scheme)] in "+:": return scheme return None -class _NotHTML(Exception): - def __init__(self, content_type, request_desc): - # type: (str, str) -> None +class _NotAPIContent(Exception): + def __init__(self, content_type: str, request_desc: str) -> None: super().__init__(content_type, request_desc) self.content_type = content_type self.request_desc = request_desc -def _ensure_html_header(response): - # type: (Response) -> None - """Check the Content-Type header to ensure the response contains HTML. +def _ensure_api_header(response: Response) -> None: + """ + Check the Content-Type header to ensure the response contains a Simple + API Response. - Raises `_NotHTML` if the content type is not text/html. + Raises `_NotAPIContent` if the content type is not a valid content-type. """ - content_type = response.headers.get("Content-Type", "") - if not content_type.lower().startswith("text/html"): - raise _NotHTML(content_type, response.request.method) + content_type = response.headers.get("Content-Type", "Unknown") + + content_type_l = content_type.lower() + if content_type_l.startswith( + ( + "text/html", + "application/vnd.pypi.simple.v1+html", + "application/vnd.pypi.simple.v1+json", + ) + ): + return + + raise _NotAPIContent(content_type, response.request.method) class _NotHTTP(Exception): pass -def _ensure_html_response(url, session): - # type: (str, PipSession) -> None - """Send a HEAD request to the URL, and ensure the response contains HTML. +def _ensure_api_response(url: str, session: PipSession) -> None: + """ + Send a HEAD request to the URL, and ensure the response contains a simple + API Response. Raises `_NotHTTP` if the URL is not available for a HEAD request, or - `_NotHTML` if the content type is not text/html. + `_NotAPIContent` if the content type is not a valid content type. """ scheme, netloc, path, query, fragment = urllib.parse.urlsplit(url) - if scheme not in {'http', 'https'}: + if scheme not in {"http", "https"}: raise _NotHTTP() resp = session.head(url, allow_redirects=True) raise_for_status(resp) - _ensure_html_header(resp) + _ensure_api_header(resp) -def _get_html_response(url, session): - # type: (str, PipSession) -> Response - """Access an HTML page with GET, and return the response. +def _get_simple_response(url: str, session: PipSession) -> Response: + """Access an Simple API response with GET, and return the response. This consists of three parts: 1. If the URL looks suspiciously like an archive, send a HEAD first to - check the Content-Type is HTML, to avoid downloading a large file. - Raise `_NotHTTP` if the content type cannot be determined, or - `_NotHTML` if it is not HTML. + check the Content-Type is HTML or Simple API, to avoid downloading a + large file. Raise `_NotHTTP` if the content type cannot be determined, or + `_NotAPIContent` if it is not HTML or a Simple API. 2. Actually perform the request. Raise HTTP exceptions on network failures. - 3. Check the Content-Type header to make sure we got HTML, and raise - `_NotHTML` otherwise. + 3. Check the Content-Type header to make sure we got a Simple API response, + and raise `_NotAPIContent` otherwise. """ if is_archive_file(Link(url).filename): - _ensure_html_response(url, session=session) + _ensure_api_response(url, session=session) - logger.debug('Getting page %s', redact_auth_from_url(url)) + logger.debug("Getting page %s", redact_auth_from_url(url)) resp = session.get( url, headers={ - "Accept": "text/html", + "Accept": ", ".join( + [ + "application/vnd.pypi.simple.v1+json", + "application/vnd.pypi.simple.v1+html; q=0.1", + "text/html; q=0.01", + ] + ), # We don't want to blindly returned cached data for # /simple/, because authors generally expecting that # twine upload && pip install will function, but if @@ -142,175 +163,61 @@ def _get_html_response(url, session): # The check for archives above only works if the url ends with # something that looks like an archive. However that is not a # requirement of an url. Unless we issue a HEAD request on every - # url we cannot know ahead of time for sure if something is HTML - # or not. However we can check after we've downloaded it. - _ensure_html_header(resp) + # url we cannot know ahead of time for sure if something is a + # Simple API response or not. However we can check after we've + # downloaded it. + _ensure_api_header(resp) + + logger.debug( + "Fetched page %s as %s", + redact_auth_from_url(url), + resp.headers.get("Content-Type", "Unknown"), + ) return resp -def _get_encoding_from_headers(headers): - # type: (ResponseHeaders) -> Optional[str] - """Determine if we have any encoding information in our headers. - """ +def _get_encoding_from_headers(headers: ResponseHeaders) -> Optional[str]: + """Determine if we have any encoding information in our headers.""" if headers and "Content-Type" in headers: - content_type, params = cgi.parse_header(headers["Content-Type"]) - if "charset" in params: - return params['charset'] + m = email.message.Message() + m["content-type"] = headers["Content-Type"] + charset = m.get_param("charset") + if charset: + return str(charset) return None -def _determine_base_url(document, page_url): - # type: (HTMLElement, str) -> str - """Determine the HTML document's base URL. - - This looks for a ``<base>`` tag in the HTML document. If present, its href - attribute denotes the base URL of anchor tags in the document. If there is - no such tag (or if it does not have a valid href attribute), the HTML - file's URL is used as the base URL. - - :param document: An HTML document representation. The current - implementation expects the result of ``html5lib.parse()``. - :param page_url: The URL of the HTML document. - """ - for base in document.findall(".//base"): - href = base.get("href") - if href is not None: - return href - return page_url - - -def _clean_url_path_part(part): - # type: (str) -> str - """ - Clean a "part" of a URL path (i.e. after splitting on "@" characters). - """ - # We unquote prior to quoting to make sure nothing is double quoted. - return urllib.parse.quote(urllib.parse.unquote(part)) - - -def _clean_file_url_path(part): - # type: (str) -> str - """ - Clean the first part of a URL path that corresponds to a local - filesystem path (i.e. the first part after splitting on "@" characters). - """ - # We unquote prior to quoting to make sure nothing is double quoted. - # Also, on Windows the path part might contain a drive letter which - # should not be quoted. On Linux where drive letters do not - # exist, the colon should be quoted. We rely on urllib.request - # to do the right thing here. - return urllib.request.pathname2url(urllib.request.url2pathname(part)) - - -# percent-encoded: / -_reserved_chars_re = re.compile('(@|%2F)', re.IGNORECASE) - - -def _clean_url_path(path, is_local_path): - # type: (str, bool) -> str - """ - Clean the path portion of a URL. - """ - if is_local_path: - clean_func = _clean_file_url_path - else: - clean_func = _clean_url_path_part - - # Split on the reserved characters prior to cleaning so that - # revision strings in VCS URLs are properly preserved. - parts = _reserved_chars_re.split(path) - - cleaned_parts = [] - for to_clean, reserved in pairwise(itertools.chain(parts, [''])): - cleaned_parts.append(clean_func(to_clean)) - # Normalize %xx escapes (e.g. %2f -> %2F) - cleaned_parts.append(reserved.upper()) - - return ''.join(cleaned_parts) - - -def _clean_link(url): - # type: (str) -> str - """ - Make sure a link is fully quoted. - For example, if ' ' occurs in the URL, it will be replaced with "%20", - and without double-quoting other characters. - """ - # Split the URL into parts according to the general structure - # `scheme://netloc/path;parameters?query#fragment`. - result = urllib.parse.urlparse(url) - # If the netloc is empty, then the URL refers to a local filesystem path. - is_local_path = not result.netloc - path = _clean_url_path(result.path, is_local_path=is_local_path) - return urllib.parse.urlunparse(result._replace(path=path)) - - -def _create_link_from_element( - anchor, # type: HTMLElement - page_url, # type: str - base_url, # type: str -): - # type: (...) -> Optional[Link] - """ - Convert an anchor element in a simple repository page to a Link. - """ - href = anchor.get("href") - if not href: - return None - - url = _clean_link(urllib.parse.urljoin(base_url, href)) - pyrequire = anchor.get('data-requires-python') - pyrequire = html.unescape(pyrequire) if pyrequire else None - - yanked_reason = anchor.get('data-yanked') - if yanked_reason: - yanked_reason = html.unescape(yanked_reason) - - link = Link( - url, - comes_from=page_url, - requires_python=pyrequire, - yanked_reason=yanked_reason, - ) - - return link - - class CacheablePageContent: - def __init__(self, page): - # type: (HTMLPage) -> None + def __init__(self, page: "IndexContent") -> None: assert page.cache_link_parsing self.page = page - def __eq__(self, other): - # type: (object) -> bool - return (isinstance(other, type(self)) and - self.page.url == other.page.url) + def __eq__(self, other: object) -> bool: + return isinstance(other, type(self)) and self.page.url == other.page.url - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash(self.page.url) -def with_cached_html_pages( - fn, # type: Callable[[HTMLPage], Iterable[Link]] -): - # type: (...) -> Callable[[HTMLPage], List[Link]] +class ParseLinks(Protocol): + def __call__(self, page: "IndexContent") -> Iterable[Link]: + ... + + +def with_cached_index_content(fn: ParseLinks) -> ParseLinks: """ - Given a function that parses an Iterable[Link] from an HTMLPage, cache the - function's result (keyed by CacheablePageContent), unless the HTMLPage + Given a function that parses an Iterable[Link] from an IndexContent, cache the + function's result (keyed by CacheablePageContent), unless the IndexContent `page` has `page.cache_link_parsing == False`. """ @functools.lru_cache(maxsize=None) - def wrapper(cacheable_page): - # type: (CacheablePageContent) -> List[Link] + def wrapper(cacheable_page: CacheablePageContent) -> List[Link]: return list(fn(cacheable_page.page)) @functools.wraps(fn) - def wrapper_wrapper(page): - # type: (HTMLPage) -> List[Link] + def wrapper_wrapper(page: "IndexContent") -> List[Link]: if page.cache_link_parsing: return wrapper(CacheablePageContent(page)) return list(fn(page)) @@ -318,42 +225,46 @@ def with_cached_html_pages( return wrapper_wrapper -@with_cached_html_pages -def parse_links(page): - # type: (HTMLPage) -> Iterable[Link] +@with_cached_index_content +def parse_links(page: "IndexContent") -> Iterable[Link]: """ - Parse an HTML document, and yield its anchor elements as Link objects. + Parse a Simple API's Index Content, and yield its anchor elements as Link objects. """ - document = html5lib.parse( - page.content, - transport_encoding=page.encoding, - namespaceHTMLElements=False, - ) + + content_type_l = page.content_type.lower() + if content_type_l.startswith("application/vnd.pypi.simple.v1+json"): + data = json.loads(page.content) + for file in data.get("files", []): + link = Link.from_json(file, page.url) + if link is None: + continue + yield link + return + + parser = HTMLLinkParser(page.url) + encoding = page.encoding or "utf-8" + parser.feed(page.content.decode(encoding)) url = page.url - base_url = _determine_base_url(document, url) - for anchor in document.findall(".//a"): - link = _create_link_from_element( - anchor, - page_url=url, - base_url=base_url, - ) + base_url = parser.base_url or url + for anchor in parser.anchors: + link = Link.from_element(anchor, page_url=url, base_url=base_url) if link is None: continue yield link -class HTMLPage: - """Represents one page, along with its URL""" +class IndexContent: + """Represents one response (or page), along with its URL""" def __init__( self, - content, # type: bytes - encoding, # type: Optional[str] - url, # type: str - cache_link_parsing=True, # type: bool - ): - # type: (...) -> None + content: bytes, + content_type: str, + encoding: Optional[str], + url: str, + cache_link_parsing: bool = True, + ) -> None: """ :param encoding: the encoding to decode the given content. :param url: the URL from which the HTML was downloaded. @@ -362,90 +273,124 @@ class HTMLPage: have this set to False, for example. """ self.content = content + self.content_type = content_type self.encoding = encoding self.url = url self.cache_link_parsing = cache_link_parsing - def __str__(self): - # type: () -> str + def __str__(self) -> str: return redact_auth_from_url(self.url) -def _handle_get_page_fail( - link, # type: Link - reason, # type: Union[str, Exception] - meth=None # type: Optional[Callable[..., None]] -): - # type: (...) -> None +class HTMLLinkParser(HTMLParser): + """ + HTMLParser that keeps the first base HREF and a list of all anchor + elements' attributes. + """ + + def __init__(self, url: str) -> None: + super().__init__(convert_charrefs=True) + + self.url: str = url + self.base_url: Optional[str] = None + self.anchors: List[Dict[str, Optional[str]]] = [] + + def handle_starttag(self, tag: str, attrs: List[Tuple[str, Optional[str]]]) -> None: + if tag == "base" and self.base_url is None: + href = self.get_href(attrs) + if href is not None: + self.base_url = href + elif tag == "a": + self.anchors.append(dict(attrs)) + + def get_href(self, attrs: List[Tuple[str, Optional[str]]]) -> Optional[str]: + for name, value in attrs: + if name == "href": + return value + return None + + +def _handle_get_simple_fail( + link: Link, + reason: Union[str, Exception], + meth: Optional[Callable[..., None]] = None, +) -> None: if meth is None: meth = logger.debug meth("Could not fetch URL %s: %s - skipping", link, reason) -def _make_html_page(response, cache_link_parsing=True): - # type: (Response, bool) -> HTMLPage +def _make_index_content( + response: Response, cache_link_parsing: bool = True +) -> IndexContent: encoding = _get_encoding_from_headers(response.headers) - return HTMLPage( + return IndexContent( response.content, + response.headers["Content-Type"], encoding=encoding, url=response.url, - cache_link_parsing=cache_link_parsing) - + cache_link_parsing=cache_link_parsing, + ) -def _get_html_page(link, session=None): - # type: (Link, Optional[PipSession]) -> Optional[HTMLPage] - if session is None: - raise TypeError( - "_get_html_page() missing 1 required keyword argument: 'session'" - ) - url = link.url.split('#', 1)[0] +def _get_index_content(link: Link, *, session: PipSession) -> Optional["IndexContent"]: + url = link.url.split("#", 1)[0] # Check for VCS schemes that do not support lookup as web pages. vcs_scheme = _match_vcs_scheme(url) if vcs_scheme: - logger.warning('Cannot look at %s URL %s because it does not support ' - 'lookup as web pages.', vcs_scheme, link) + logger.warning( + "Cannot look at %s URL %s because it does not support lookup as web pages.", + vcs_scheme, + link, + ) return None # Tack index.html onto file:// URLs that point to directories scheme, _, path, _, _, _ = urllib.parse.urlparse(url) - if (scheme == 'file' and os.path.isdir(urllib.request.url2pathname(path))): + if scheme == "file" and os.path.isdir(urllib.request.url2pathname(path)): # add trailing slash if not present so urljoin doesn't trim # final segment - if not url.endswith('/'): - url += '/' - url = urllib.parse.urljoin(url, 'index.html') - logger.debug(' file: URL is directory, getting %s', url) + if not url.endswith("/"): + url += "/" + # TODO: In the future, it would be nice if pip supported PEP 691 + # style responses in the file:// URLs, however there's no + # standard file extension for application/vnd.pypi.simple.v1+json + # so we'll need to come up with something on our own. + url = urllib.parse.urljoin(url, "index.html") + logger.debug(" file: URL is directory, getting %s", url) try: - resp = _get_html_response(url, session=session) + resp = _get_simple_response(url, session=session) except _NotHTTP: logger.warning( - 'Skipping page %s because it looks like an archive, and cannot ' - 'be checked by a HTTP HEAD request.', link, + "Skipping page %s because it looks like an archive, and cannot " + "be checked by a HTTP HEAD request.", + link, ) - except _NotHTML as exc: + except _NotAPIContent as exc: logger.warning( - 'Skipping page %s because the %s request got Content-Type: %s.' - 'The only supported Content-Type is text/html', - link, exc.request_desc, exc.content_type, + "Skipping page %s because the %s request got Content-Type: %s. " + "The only supported Content-Types are application/vnd.pypi.simple.v1+json, " + "application/vnd.pypi.simple.v1+html, and text/html", + link, + exc.request_desc, + exc.content_type, ) except NetworkConnectionError as exc: - _handle_get_page_fail(link, exc) + _handle_get_simple_fail(link, exc) except RetryError as exc: - _handle_get_page_fail(link, exc) + _handle_get_simple_fail(link, exc) except SSLError as exc: reason = "There was a problem confirming the ssl certificate: " reason += str(exc) - _handle_get_page_fail(link, reason, meth=logger.info) + _handle_get_simple_fail(link, reason, meth=logger.info) except requests.ConnectionError as exc: - _handle_get_page_fail(link, f"connection error: {exc}") + _handle_get_simple_fail(link, f"connection error: {exc}") except requests.Timeout: - _handle_get_page_fail(link, "timed out") + _handle_get_simple_fail(link, "timed out") else: - return _make_html_page(resp, - cache_link_parsing=link.cache_link_parsing) + return _make_index_content(resp, cache_link_parsing=link.cache_link_parsing) return None @@ -465,16 +410,19 @@ class LinkCollector: def __init__( self, - session, # type: PipSession - search_scope, # type: SearchScope - ): - # type: (...) -> None + session: PipSession, + search_scope: SearchScope, + ) -> None: self.search_scope = search_scope self.session = session @classmethod - def create(cls, session, options, suppress_no_index=False): - # type: (PipSession, Values, bool) -> LinkCollector + def create( + cls, + session: PipSession, + options: Values, + suppress_no_index: bool = False, + ) -> "LinkCollector": """ :param session: The Session to use to make requests. :param suppress_no_index: Whether to ignore the --no-index option @@ -483,8 +431,8 @@ class LinkCollector: index_urls = [options.index_url] + options.extra_index_urls if options.no_index and not suppress_no_index: logger.debug( - 'Ignoring indexes: %s', - ','.join(redact_auth_from_url(url) for url in index_urls), + "Ignoring indexes: %s", + ",".join(redact_auth_from_url(url) for url in index_urls), ) index_urls = [] @@ -492,24 +440,25 @@ class LinkCollector: find_links = options.find_links or [] search_scope = SearchScope.create( - find_links=find_links, index_urls=index_urls, + find_links=find_links, + index_urls=index_urls, + no_index=options.no_index, ) link_collector = LinkCollector( - session=session, search_scope=search_scope, + session=session, + search_scope=search_scope, ) return link_collector @property - def find_links(self): - # type: () -> List[str] + def find_links(self) -> List[str]: return self.search_scope.find_links - def fetch_page(self, location): - # type: (Link) -> Optional[HTMLPage] + def fetch_response(self, location: Link) -> Optional[IndexContent]: """ Fetch an HTML page containing package links. """ - return _get_html_page(location, session=self.session) + return _get_index_content(location, session=self.session) def collect_sources( self, diff --git a/env/Lib/site-packages/pip/_internal/index/package_finder.py b/env/Lib/site-packages/pip/_internal/index/package_finder.py index 7f2e04e7..b6f8d57e 100644 --- a/env/Lib/site-packages/pip/_internal/index/package_finder.py +++ b/env/Lib/site-packages/pip/_internal/index/package_finder.py @@ -1,13 +1,11 @@ """Routines related to PyPI, indexes""" -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - +import enum import functools import itertools import logging import re -from typing import FrozenSet, Iterable, List, Optional, Set, Tuple, Union +from typing import TYPE_CHECKING, FrozenSet, Iterable, List, Optional, Set, Tuple, Union from pip._vendor.packaging import specifiers from pip._vendor.packaging.tags import Tag @@ -30,31 +28,31 @@ from pip._internal.models.selection_prefs import SelectionPreferences from pip._internal.models.target_python import TargetPython from pip._internal.models.wheel import Wheel from pip._internal.req import InstallRequirement +from pip._internal.utils._log import getLogger from pip._internal.utils.filetypes import WHEEL_EXTENSION from pip._internal.utils.hashes import Hashes from pip._internal.utils.logging import indent_log from pip._internal.utils.misc import build_netloc from pip._internal.utils.packaging import check_requires_python from pip._internal.utils.unpacking import SUPPORTED_EXTENSIONS -from pip._internal.utils.urls import url_to_path -__all__ = ['FormatControl', 'BestCandidateResult', 'PackageFinder'] +if TYPE_CHECKING: + from pip._vendor.typing_extensions import TypeGuard + +__all__ = ["FormatControl", "BestCandidateResult", "PackageFinder"] -logger = logging.getLogger(__name__) +logger = getLogger(__name__) BuildTag = Union[Tuple[()], Tuple[int, str]] -CandidateSortingKey = ( - Tuple[int, int, int, _BaseVersion, Optional[int], BuildTag] -) +CandidateSortingKey = Tuple[int, int, int, _BaseVersion, Optional[int], BuildTag] def _check_link_requires_python( - link, # type: Link - version_info, # type: Tuple[int, int, int] - ignore_requires_python=False, # type: bool -): - # type: (...) -> bool + link: Link, + version_info: Tuple[int, int, int], + ignore_requires_python: bool = False, +) -> bool: """ Return whether the given Python version is compatible with a link's "Requires-Python" value. @@ -66,39 +64,54 @@ def _check_link_requires_python( """ try: is_compatible = check_requires_python( - link.requires_python, version_info=version_info, + link.requires_python, + version_info=version_info, ) except specifiers.InvalidSpecifier: logger.debug( "Ignoring invalid Requires-Python (%r) for link: %s", - link.requires_python, link, + link.requires_python, + link, ) else: if not is_compatible: - version = '.'.join(map(str, version_info)) + version = ".".join(map(str, version_info)) if not ignore_requires_python: - logger.debug( - 'Link requires a different Python (%s not in: %r): %s', - version, link.requires_python, link, + logger.verbose( + "Link requires a different Python (%s not in: %r): %s", + version, + link.requires_python, + link, ) return False logger.debug( - 'Ignoring failed Requires-Python check (%s not in: %r) ' - 'for link: %s', - version, link.requires_python, link, + "Ignoring failed Requires-Python check (%s not in: %r) for link: %s", + version, + link.requires_python, + link, ) return True +class LinkType(enum.Enum): + candidate = enum.auto() + different_project = enum.auto() + yanked = enum.auto() + format_unsupported = enum.auto() + format_invalid = enum.auto() + platform_mismatch = enum.auto() + requires_python_mismatch = enum.auto() + + class LinkEvaluator: """ Responsible for evaluating links for a particular project. """ - _py_version_re = re.compile(r'-py([123]\.?[0-9]?)$') + _py_version_re = re.compile(r"-py([123]\.?[0-9]?)$") # Don't include an allow_yanked default value to make sure each call # site considers whether yanked releases are allowed. This also causes @@ -106,14 +119,13 @@ class LinkEvaluator: # people when reading the code. def __init__( self, - project_name, # type: str - canonical_name, # type: str - formats, # type: FrozenSet[str] - target_python, # type: TargetPython - allow_yanked, # type: bool - ignore_requires_python=None, # type: Optional[bool] - ): - # type: (...) -> None + project_name: str, + canonical_name: str, + formats: FrozenSet[str], + target_python: TargetPython, + allow_yanked: bool, + ignore_requires_python: Optional[bool] = None, + ) -> None: """ :param project_name: The user supplied package name. :param canonical_name: The canonical package name. @@ -142,20 +154,20 @@ class LinkEvaluator: self.project_name = project_name - def evaluate_link(self, link): - # type: (Link) -> Tuple[bool, Optional[str]] + def evaluate_link(self, link: Link) -> Tuple[LinkType, str]: """ Determine whether a link is a candidate for installation. - :return: A tuple (is_candidate, result), where `result` is (1) a - version string if `is_candidate` is True, and (2) if - `is_candidate` is False, an optional string to log the reason - the link fails to qualify. + :return: A tuple (result, detail), where *result* is an enum + representing whether the evaluation found a candidate, or the reason + why one is not found. If a candidate is found, *detail* will be the + candidate's version string; if one is not found, it contains the + reason the link fails to qualify. """ version = None if link.is_yanked and not self._allow_yanked: - reason = link.yanked_reason or '<none given>' - return (False, f'yanked for reason: {reason}') + reason = link.yanked_reason or "<none given>" + return (LinkType.yanked, f"yanked for reason: {reason}") if link.egg_fragment: egg_info = link.egg_fragment @@ -163,80 +175,85 @@ class LinkEvaluator: else: egg_info, ext = link.splitext() if not ext: - return (False, 'not a file') + return (LinkType.format_unsupported, "not a file") if ext not in SUPPORTED_EXTENSIONS: - return (False, f'unsupported archive format: {ext}') + return ( + LinkType.format_unsupported, + f"unsupported archive format: {ext}", + ) if "binary" not in self._formats and ext == WHEEL_EXTENSION: - reason = 'No binaries permitted for {}'.format( - self.project_name) - return (False, reason) - if "macosx10" in link.path and ext == '.zip': - return (False, 'macosx10 one') + reason = f"No binaries permitted for {self.project_name}" + return (LinkType.format_unsupported, reason) + if "macosx10" in link.path and ext == ".zip": + return (LinkType.format_unsupported, "macosx10 one") if ext == WHEEL_EXTENSION: try: wheel = Wheel(link.filename) except InvalidWheelFilename: - return (False, 'invalid wheel filename') + return ( + LinkType.format_invalid, + "invalid wheel filename", + ) if canonicalize_name(wheel.name) != self._canonical_name: - reason = 'wrong project name (not {})'.format( - self.project_name) - return (False, reason) + reason = f"wrong project name (not {self.project_name})" + return (LinkType.different_project, reason) supported_tags = self._target_python.get_tags() if not wheel.supported(supported_tags): # Include the wheel's tags in the reason string to # simplify troubleshooting compatibility issues. - file_tags = wheel.get_formatted_file_tags() + file_tags = ", ".join(wheel.get_formatted_file_tags()) reason = ( - "none of the wheel's tags ({}) are compatible " - "(run pip debug --verbose to show compatible tags)".format( - ', '.join(file_tags) - ) + f"none of the wheel's tags ({file_tags}) are compatible " + f"(run pip debug --verbose to show compatible tags)" ) - return (False, reason) + return (LinkType.platform_mismatch, reason) version = wheel.version # This should be up by the self.ok_binary check, but see issue 2700. if "source" not in self._formats and ext != WHEEL_EXTENSION: - reason = f'No sources permitted for {self.project_name}' - return (False, reason) + reason = f"No sources permitted for {self.project_name}" + return (LinkType.format_unsupported, reason) if not version: version = _extract_version_from_fragment( - egg_info, self._canonical_name, + egg_info, + self._canonical_name, ) if not version: - reason = f'Missing project version for {self.project_name}' - return (False, reason) + reason = f"Missing project version for {self.project_name}" + return (LinkType.format_invalid, reason) match = self._py_version_re.search(version) if match: - version = version[:match.start()] + version = version[: match.start()] py_version = match.group(1) if py_version != self._target_python.py_version: - return (False, 'Python version is incorrect') + return ( + LinkType.platform_mismatch, + "Python version is incorrect", + ) supports_python = _check_link_requires_python( - link, version_info=self._target_python.py_version_info, + link, + version_info=self._target_python.py_version_info, ignore_requires_python=self._ignore_requires_python, ) if not supports_python: - # Return None for the reason text to suppress calling - # _log_skipped_link(). - return (False, None) + reason = f"{version} Requires-Python {link.requires_python}" + return (LinkType.requires_python_mismatch, reason) - logger.debug('Found link %s, version: %s', link, version) + logger.debug("Found link %s, version: %s", link, version) - return (True, version) + return (LinkType.candidate, version) def filter_unallowed_hashes( - candidates, # type: List[InstallationCandidate] - hashes, # type: Hashes - project_name, # type: str -): - # type: (...) -> List[InstallationCandidate] + candidates: List[InstallationCandidate], + hashes: Optional[Hashes], + project_name: str, +) -> List[InstallationCandidate]: """ Filter out candidates whose hashes aren't allowed, and return a new list of candidates. @@ -254,8 +271,8 @@ def filter_unallowed_hashes( """ if not hashes: logger.debug( - 'Given no hashes to check %s links for project %r: ' - 'discarding no candidates', + "Given no hashes to check %s links for project %r: " + "discarding no candidates", len(candidates), project_name, ) @@ -285,22 +302,22 @@ def filter_unallowed_hashes( filtered = list(candidates) if len(filtered) == len(candidates): - discard_message = 'discarding no candidates' + discard_message = "discarding no candidates" else: - discard_message = 'discarding {} non-matches:\n {}'.format( + discard_message = "discarding {} non-matches:\n {}".format( len(non_matches), - '\n '.join(str(candidate.link) for candidate in non_matches) + "\n ".join(str(candidate.link) for candidate in non_matches), ) logger.debug( - 'Checked %s links for project %r against %s hashes ' - '(%s matches, %s no digest): %s', + "Checked %s links for project %r against %s hashes " + "(%s matches, %s no digest): %s", len(candidates), project_name, hashes.digest_count, match_count, len(matches_or_no_digest) - match_count, - discard_message + discard_message, ) return filtered @@ -315,10 +332,9 @@ class CandidatePreferences: def __init__( self, - prefer_binary=False, # type: bool - allow_all_prereleases=False, # type: bool - ): - # type: (...) -> None + prefer_binary: bool = False, + allow_all_prereleases: bool = False, + ) -> None: """ :param allow_all_prereleases: Whether to allow all pre-releases. """ @@ -335,11 +351,10 @@ class BestCandidateResult: def __init__( self, - candidates, # type: List[InstallationCandidate] - applicable_candidates, # type: List[InstallationCandidate] - best_candidate, # type: Optional[InstallationCandidate] - ): - # type: (...) -> None + candidates: List[InstallationCandidate], + applicable_candidates: List[InstallationCandidate], + best_candidate: Optional[InstallationCandidate], + ) -> None: """ :param candidates: A sequence of all available candidates found. :param applicable_candidates: The applicable candidates. @@ -358,16 +373,12 @@ class BestCandidateResult: self.best_candidate = best_candidate - def iter_all(self): - # type: () -> Iterable[InstallationCandidate] - """Iterate through all candidates. - """ + def iter_all(self) -> Iterable[InstallationCandidate]: + """Iterate through all candidates.""" return iter(self._candidates) - def iter_applicable(self): - # type: () -> Iterable[InstallationCandidate] - """Iterate through the applicable candidates. - """ + def iter_applicable(self) -> Iterable[InstallationCandidate]: + """Iterate through the applicable candidates.""" return iter(self._applicable_candidates) @@ -381,14 +392,13 @@ class CandidateEvaluator: @classmethod def create( cls, - project_name, # type: str - target_python=None, # type: Optional[TargetPython] - prefer_binary=False, # type: bool - allow_all_prereleases=False, # type: bool - specifier=None, # type: Optional[specifiers.BaseSpecifier] - hashes=None, # type: Optional[Hashes] - ): - # type: (...) -> CandidateEvaluator + project_name: str, + target_python: Optional[TargetPython] = None, + prefer_binary: bool = False, + allow_all_prereleases: bool = False, + specifier: Optional[specifiers.BaseSpecifier] = None, + hashes: Optional[Hashes] = None, + ) -> "CandidateEvaluator": """Create a CandidateEvaluator object. :param target_python: The target Python interpreter to use when @@ -417,14 +427,13 @@ class CandidateEvaluator: def __init__( self, - project_name, # type: str - supported_tags, # type: List[Tag] - specifier, # type: specifiers.BaseSpecifier - prefer_binary=False, # type: bool - allow_all_prereleases=False, # type: bool - hashes=None, # type: Optional[Hashes] - ): - # type: (...) -> None + project_name: str, + supported_tags: List[Tag], + specifier: specifiers.BaseSpecifier, + prefer_binary: bool = False, + allow_all_prereleases: bool = False, + hashes: Optional[Hashes] = None, + ) -> None: """ :param supported_tags: The PEP 425 tags supported by the target Python in order of preference (most preferred first). @@ -444,9 +453,8 @@ class CandidateEvaluator: def get_applicable_candidates( self, - candidates, # type: List[InstallationCandidate] - ): - # type: (...) -> List[InstallationCandidate] + candidates: List[InstallationCandidate], + ) -> List[InstallationCandidate]: """ Return the applicable candidates from a list of candidates. """ @@ -454,7 +462,8 @@ class CandidateEvaluator: allow_prereleases = self._allow_all_prereleases or None specifier = self._specifier versions = { - str(v) for v in specifier.filter( + str(v) + for v in specifier.filter( # We turn the version object into a str here because otherwise # when we're debundled but setuptools isn't, Python will see # packaging.version.Version and @@ -468,9 +477,7 @@ class CandidateEvaluator: } # Again, converting version to str to deal with debundling. - applicable_candidates = [ - c for c in candidates if str(c.version) in versions - ] + applicable_candidates = [c for c in candidates if str(c.version) in versions] filtered_applicable_candidates = filter_unallowed_hashes( candidates=applicable_candidates, @@ -480,8 +487,7 @@ class CandidateEvaluator: return sorted(filtered_applicable_candidates, key=self._sort_key) - def _sort_key(self, candidate): - # type: (InstallationCandidate) -> CandidateSortingKey + def _sort_key(self, candidate: InstallationCandidate) -> CandidateSortingKey: """ Function to pass as the `key` argument to a call to sorted() to sort InstallationCandidates by preference. @@ -513,16 +519,18 @@ class CandidateEvaluator: """ valid_tags = self._supported_tags support_num = len(valid_tags) - build_tag = () # type: BuildTag + build_tag: BuildTag = () binary_preference = 0 link = candidate.link if link.is_wheel: # can raise InvalidWheelFilename wheel = Wheel(link.filename) try: - pri = -(wheel.find_most_preferred_tag( - valid_tags, self._wheel_tag_preferences - )) + pri = -( + wheel.find_most_preferred_tag( + valid_tags, self._wheel_tag_preferences + ) + ) except ValueError: raise UnsupportedWheel( "{} is not a supported wheel for this platform. It " @@ -531,7 +539,8 @@ class CandidateEvaluator: if self._prefer_binary: binary_preference = 1 if wheel.build_tag is not None: - match = re.match(r'^(\d+)(.*)$', wheel.build_tag) + match = re.match(r"^(\d+)(.*)$", wheel.build_tag) + assert match is not None, "guaranteed by filename validation" build_tag_groups = match.groups() build_tag = (int(build_tag_groups[0]), build_tag_groups[1]) else: # sdist @@ -539,15 +548,18 @@ class CandidateEvaluator: has_allowed_hash = int(link.is_hash_allowed(self._hashes)) yank_value = -1 * int(link.is_yanked) # -1 for yanked. return ( - has_allowed_hash, yank_value, binary_preference, candidate.version, - pri, build_tag, + has_allowed_hash, + yank_value, + binary_preference, + candidate.version, + pri, + build_tag, ) def sort_best_candidate( self, - candidates, # type: List[InstallationCandidate] - ): - # type: (...) -> Optional[InstallationCandidate] + candidates: List[InstallationCandidate], + ) -> Optional[InstallationCandidate]: """ Return the best candidate per the instance's sort order, or None if no candidate is acceptable. @@ -559,9 +571,8 @@ class CandidateEvaluator: def compute_best_candidate( self, - candidates, # type: List[InstallationCandidate] - ): - # type: (...) -> BestCandidateResult + candidates: List[InstallationCandidate], + ) -> BestCandidateResult: """ Compute and return a `BestCandidateResult` instance. """ @@ -585,14 +596,13 @@ class PackageFinder: def __init__( self, - link_collector, # type: LinkCollector - target_python, # type: TargetPython - allow_yanked, # type: bool - format_control=None, # type: Optional[FormatControl] - candidate_prefs=None, # type: CandidatePreferences - ignore_requires_python=None, # type: Optional[bool] - ): - # type: (...) -> None + link_collector: LinkCollector, + target_python: TargetPython, + allow_yanked: bool, + format_control: Optional[FormatControl] = None, + candidate_prefs: Optional[CandidatePreferences] = None, + ignore_requires_python: Optional[bool] = None, + ) -> None: """ This constructor is primarily meant to be used by the create() class method and from tests. @@ -617,7 +627,7 @@ class PackageFinder: self.format_control = format_control # These are boring links that have already been logged somehow. - self._logged_links = set() # type: Set[Link] + self._logged_links: Set[Tuple[Link, LinkType, str]] = set() # Don't include an allow_yanked default value to make sure each call # site considers whether yanked releases are allowed. This also causes @@ -626,11 +636,10 @@ class PackageFinder: @classmethod def create( cls, - link_collector, # type: LinkCollector - selection_prefs, # type: SelectionPreferences - target_python=None, # type: Optional[TargetPython] - ): - # type: (...) -> PackageFinder + link_collector: LinkCollector, + selection_prefs: SelectionPreferences, + target_python: Optional[TargetPython] = None, + ) -> "PackageFinder": """Create a PackageFinder. :param selection_prefs: The candidate selection preferences, as a @@ -657,56 +666,53 @@ class PackageFinder: ) @property - def target_python(self): - # type: () -> TargetPython + def target_python(self) -> TargetPython: return self._target_python @property - def search_scope(self): - # type: () -> SearchScope + def search_scope(self) -> SearchScope: return self._link_collector.search_scope @search_scope.setter - def search_scope(self, search_scope): - # type: (SearchScope) -> None + def search_scope(self, search_scope: SearchScope) -> None: self._link_collector.search_scope = search_scope @property - def find_links(self): - # type: () -> List[str] + def find_links(self) -> List[str]: return self._link_collector.find_links @property - def index_urls(self): - # type: () -> List[str] + def index_urls(self) -> List[str]: return self.search_scope.index_urls @property - def trusted_hosts(self): - # type: () -> Iterable[str] + def trusted_hosts(self) -> Iterable[str]: for host_port in self._link_collector.session.pip_trusted_origins: yield build_netloc(*host_port) @property - def allow_all_prereleases(self): - # type: () -> bool + def allow_all_prereleases(self) -> bool: return self._candidate_prefs.allow_all_prereleases - def set_allow_all_prereleases(self): - # type: () -> None + def set_allow_all_prereleases(self) -> None: self._candidate_prefs.allow_all_prereleases = True @property - def prefer_binary(self): - # type: () -> bool + def prefer_binary(self) -> bool: return self._candidate_prefs.prefer_binary - def set_prefer_binary(self): - # type: () -> None + def set_prefer_binary(self) -> None: self._candidate_prefs.prefer_binary = True - def make_link_evaluator(self, project_name): - # type: (str) -> LinkEvaluator + def requires_python_skipped_reasons(self) -> List[str]: + reasons = { + detail + for _, result, detail in self._logged_links + if result == LinkType.requires_python_mismatch + } + return sorted(reasons) + + def make_link_evaluator(self, project_name: str) -> LinkEvaluator: canonical_name = canonicalize_name(project_name) formats = self.format_control.get_allowed_formats(canonical_name) @@ -719,14 +725,13 @@ class PackageFinder: ignore_requires_python=self._ignore_requires_python, ) - def _sort_links(self, links): - # type: (Iterable[Link]) -> List[Link] + def _sort_links(self, links: Iterable[Link]) -> List[Link]: """ Returns elements of links in order, non-egg links first, egg links second, while eliminating duplicates """ eggs, no_eggs = [], [] - seen = set() # type: Set[Link] + seen: Set[Link] = set() for link in links: if link not in seen: seen.add(link) @@ -736,34 +741,35 @@ class PackageFinder: no_eggs.append(link) return no_eggs + eggs - def _log_skipped_link(self, link, reason): - # type: (Link, str) -> None - if link not in self._logged_links: + def _log_skipped_link(self, link: Link, result: LinkType, detail: str) -> None: + entry = (link, result, detail) + if entry not in self._logged_links: # Put the link at the end so the reason is more visible and because # the link string is usually very long. - logger.debug('Skipping link: %s: %s', reason, link) - self._logged_links.add(link) + logger.debug("Skipping link: %s: %s", detail, link) + self._logged_links.add(entry) - def get_install_candidate(self, link_evaluator, link): - # type: (LinkEvaluator, Link) -> Optional[InstallationCandidate] + def get_install_candidate( + self, link_evaluator: LinkEvaluator, link: Link + ) -> Optional[InstallationCandidate]: """ If the link is a candidate for install, convert it to an InstallationCandidate and return it. Otherwise, return None. """ - is_candidate, result = link_evaluator.evaluate_link(link) - if not is_candidate: - if result: - self._log_skipped_link(link, reason=result) + result, detail = link_evaluator.evaluate_link(link) + if result != LinkType.candidate: + self._log_skipped_link(link, result, detail) return None return InstallationCandidate( name=link_evaluator.project_name, link=link, - version=result, + version=detail, ) - def evaluate_links(self, link_evaluator, links): - # type: (LinkEvaluator, Iterable[Link]) -> List[InstallationCandidate] + def evaluate_links( + self, link_evaluator: LinkEvaluator, links: Iterable[Link] + ) -> List[InstallationCandidate]: """ Convert links that are candidates to InstallationCandidate objects. """ @@ -775,16 +781,18 @@ class PackageFinder: return candidates - def process_project_url(self, project_url, link_evaluator): - # type: (Link, LinkEvaluator) -> List[InstallationCandidate] + def process_project_url( + self, project_url: Link, link_evaluator: LinkEvaluator + ) -> List[InstallationCandidate]: logger.debug( - 'Fetching project page and analyzing links: %s', project_url, + "Fetching project page and analyzing links: %s", + project_url, ) - html_page = self._link_collector.fetch_page(project_url) - if html_page is None: + index_response = self._link_collector.fetch_response(project_url) + if index_response is None: return [] - page_links = list(parse_links(html_page)) + page_links = list(parse_links(index_response)) with indent_log(): package_links = self.evaluate_links( @@ -795,8 +803,7 @@ class PackageFinder: return package_links @functools.lru_cache(maxsize=None) - def find_all_candidates(self, project_name): - # type: (str) -> List[InstallationCandidate] + def find_all_candidates(self, project_name: str) -> List[InstallationCandidate]: """Find all available InstallationCandidate for project_name This checks index_urls and find_links. @@ -835,7 +842,14 @@ class PackageFinder: ) if logger.isEnabledFor(logging.DEBUG) and file_candidates: - paths = [url_to_path(c.link.url) for c in file_candidates] + paths = [] + for candidate in file_candidates: + assert candidate.link.url # we need to have a URL + try: + paths.append(candidate.link.file_path) + except Exception: + paths.append(candidate.link.url) # it's not a local file + logger.debug("Local files found: %s", ", ".join(paths)) # This is an intentional priority ordering @@ -843,13 +857,11 @@ class PackageFinder: def make_candidate_evaluator( self, - project_name, # type: str - specifier=None, # type: Optional[specifiers.BaseSpecifier] - hashes=None, # type: Optional[Hashes] - ): - # type: (...) -> CandidateEvaluator - """Create a CandidateEvaluator object to use. - """ + project_name: str, + specifier: Optional[specifiers.BaseSpecifier] = None, + hashes: Optional[Hashes] = None, + ) -> CandidateEvaluator: + """Create a CandidateEvaluator object to use.""" candidate_prefs = self._candidate_prefs return CandidateEvaluator.create( project_name=project_name, @@ -863,11 +875,10 @@ class PackageFinder: @functools.lru_cache(maxsize=None) def find_best_candidate( self, - project_name, # type: str - specifier=None, # type: Optional[specifiers.BaseSpecifier] - hashes=None, # type: Optional[Hashes] - ): - # type: (...) -> BestCandidateResult + project_name: str, + specifier: Optional[specifiers.BaseSpecifier] = None, + hashes: Optional[Hashes] = None, + ) -> BestCandidateResult: """Find matches for the given project and specifier. :param specifier: An optional object implementing `filter` @@ -884,8 +895,9 @@ class PackageFinder: ) return candidate_evaluator.compute_best_candidate(candidates) - def find_requirement(self, req, upgrade): - # type: (InstallRequirement, bool) -> Optional[InstallationCandidate] + def find_requirement( + self, req: InstallRequirement, upgrade: bool + ) -> Optional[InstallationCandidate]: """Try to find a Link matching req Expects req, an InstallRequirement and upgrade, a boolean @@ -894,80 +906,86 @@ class PackageFinder: """ hashes = req.hashes(trust_internet=False) best_candidate_result = self.find_best_candidate( - req.name, specifier=req.specifier, hashes=hashes, + req.name, + specifier=req.specifier, + hashes=hashes, ) best_candidate = best_candidate_result.best_candidate - installed_version = None # type: Optional[_BaseVersion] + installed_version: Optional[_BaseVersion] = None if req.satisfied_by is not None: - installed_version = parse_version(req.satisfied_by.version) + installed_version = req.satisfied_by.version - def _format_versions(cand_iter): - # type: (Iterable[InstallationCandidate]) -> str + def _format_versions(cand_iter: Iterable[InstallationCandidate]) -> str: # This repeated parse_version and str() conversion is needed to # handle different vendoring sources from pip and pkg_resources. # If we stop using the pkg_resources provided specifier and start # using our own, we can drop the cast to str(). - return ", ".join(sorted( - {str(c.version) for c in cand_iter}, - key=parse_version, - )) or "none" + return ( + ", ".join( + sorted( + {str(c.version) for c in cand_iter}, + key=parse_version, + ) + ) + or "none" + ) if installed_version is None and best_candidate is None: logger.critical( - 'Could not find a version that satisfies the requirement %s ' - '(from versions: %s)', + "Could not find a version that satisfies the requirement %s " + "(from versions: %s)", req, _format_versions(best_candidate_result.iter_all()), ) raise DistributionNotFound( - 'No matching distribution found for {}'.format( - req) + "No matching distribution found for {}".format(req) ) - best_installed = False - if installed_version and ( - best_candidate is None or - best_candidate.version <= installed_version): - best_installed = True + def _should_install_candidate( + candidate: Optional[InstallationCandidate], + ) -> "TypeGuard[InstallationCandidate]": + if installed_version is None: + return True + if best_candidate is None: + return False + return best_candidate.version > installed_version if not upgrade and installed_version is not None: - if best_installed: + if _should_install_candidate(best_candidate): logger.debug( - 'Existing installed version (%s) is most up-to-date and ' - 'satisfies requirement', + "Existing installed version (%s) satisfies requirement " + "(most up-to-date version is %s)", installed_version, + best_candidate.version, ) else: logger.debug( - 'Existing installed version (%s) satisfies requirement ' - '(most up-to-date version is %s)', + "Existing installed version (%s) is most up-to-date and " + "satisfies requirement", installed_version, - best_candidate.version, ) return None - if best_installed: - # We have an existing version, and its the best version + if _should_install_candidate(best_candidate): logger.debug( - 'Installed version (%s) is most up-to-date (past versions: ' - '%s)', - installed_version, + "Using version %s (newest of versions: %s)", + best_candidate.version, _format_versions(best_candidate_result.iter_applicable()), ) - raise BestVersionAlreadyInstalled + return best_candidate + # We have an existing version, and its the best version logger.debug( - 'Using version %s (newest of versions: %s)', - best_candidate.version, + "Installed version (%s) is most up-to-date (past versions: %s)", + installed_version, _format_versions(best_candidate_result.iter_applicable()), ) - return best_candidate + raise BestVersionAlreadyInstalled -def _find_name_version_sep(fragment, canonical_name): - # type: (str, str) -> int +def _find_name_version_sep(fragment: str, canonical_name: str) -> int: """Find the separator's index based on the package's canonical name. :param fragment: A <package>+<version> filename "fragment" (stem) or @@ -993,8 +1011,7 @@ def _find_name_version_sep(fragment, canonical_name): raise ValueError(f"{fragment} does not match {canonical_name}") -def _extract_version_from_fragment(fragment, canonical_name): - # type: (str, str) -> Optional[str] +def _extract_version_from_fragment(fragment: str, canonical_name: str) -> Optional[str]: """Parse the version string from a <package>+<version> filename "fragment" (stem) or egg fragment. diff --git a/env/Lib/site-packages/pip/_internal/index/sources.py b/env/Lib/site-packages/pip/_internal/index/sources.py index eec3f12f..cd9cb8d4 100644 --- a/env/Lib/site-packages/pip/_internal/index/sources.py +++ b/env/Lib/site-packages/pip/_internal/index/sources.py @@ -171,7 +171,6 @@ def build_source( expand_dir: bool, cache_link_parsing: bool, ) -> Tuple[Optional[str], Optional[LinkSource]]: - path: Optional[str] = None url: Optional[str] = None if os.path.exists(location): # Is a local path. diff --git a/env/Lib/site-packages/pip/_internal/locations/__init__.py b/env/Lib/site-packages/pip/_internal/locations/__init__.py index 3acb51bc..d54bc63e 100644 --- a/env/Lib/site-packages/pip/_internal/locations/__init__.py +++ b/env/Lib/site-packages/pip/_internal/locations/__init__.py @@ -1,16 +1,22 @@ +import functools import logging +import os import pathlib import sys import sysconfig -from typing import List, Optional +from typing import Any, Dict, Generator, Optional, Tuple from pip._internal.models.scheme import SCHEME_KEYS, Scheme +from pip._internal.utils.compat import WINDOWS +from pip._internal.utils.deprecation import deprecated +from pip._internal.utils.virtualenv import running_under_virtualenv -from . import _distutils, _sysconfig +from . import _sysconfig from .base import ( USER_CACHE_DIR, get_major_minor_version, get_src_prefix, + is_osx_framework, site_packages, user_site, ) @@ -21,7 +27,6 @@ __all__ = [ "get_bin_user", "get_major_minor_version", "get_platlib", - "get_prefixed_libs", "get_purelib", "get_scheme", "get_src_prefix", @@ -33,28 +38,177 @@ __all__ = [ logger = logging.getLogger(__name__) -def _default_base(*, user: bool) -> str: - if user: - base = sysconfig.get_config_var("userbase") - else: - base = sysconfig.get_config_var("base") - assert base is not None - return base +_PLATLIBDIR: str = getattr(sys, "platlibdir", "lib") +_USE_SYSCONFIG_DEFAULT = sys.version_info >= (3, 10) -def _warn_if_mismatch(old: pathlib.Path, new: pathlib.Path, *, key: str) -> bool: - if old == new: + +def _should_use_sysconfig() -> bool: + """This function determines the value of _USE_SYSCONFIG. + + By default, pip uses sysconfig on Python 3.10+. + But Python distributors can override this decision by setting: + sysconfig._PIP_USE_SYSCONFIG = True / False + Rationale in https://github.com/pypa/pip/issues/10647 + + This is a function for testability, but should be constant during any one + run. + """ + return bool(getattr(sysconfig, "_PIP_USE_SYSCONFIG", _USE_SYSCONFIG_DEFAULT)) + + +_USE_SYSCONFIG = _should_use_sysconfig() + +if not _USE_SYSCONFIG: + # Import distutils lazily to avoid deprecation warnings, + # but import it soon enough that it is in memory and available during + # a pip reinstall. + from . import _distutils + +# Be noisy about incompatibilities if this platforms "should" be using +# sysconfig, but is explicitly opting out and using distutils instead. +if _USE_SYSCONFIG_DEFAULT and not _USE_SYSCONFIG: + _MISMATCH_LEVEL = logging.WARNING +else: + _MISMATCH_LEVEL = logging.DEBUG + + +def _looks_like_bpo_44860() -> bool: + """The resolution to bpo-44860 will change this incorrect platlib. + + See <https://bugs.python.org/issue44860>. + """ + from distutils.command.install import INSTALL_SCHEMES + + try: + unix_user_platlib = INSTALL_SCHEMES["unix_user"]["platlib"] + except KeyError: + return False + return unix_user_platlib == "$usersite" + + +def _looks_like_red_hat_patched_platlib_purelib(scheme: Dict[str, str]) -> bool: + platlib = scheme["platlib"] + if "/$platlibdir/" in platlib: + platlib = platlib.replace("/$platlibdir/", f"/{_PLATLIBDIR}/") + if "/lib64/" not in platlib: + return False + unpatched = platlib.replace("/lib64/", "/lib/") + return unpatched.replace("$platbase/", "$base/") == scheme["purelib"] + + +@functools.lru_cache(maxsize=None) +def _looks_like_red_hat_lib() -> bool: + """Red Hat patches platlib in unix_prefix and unix_home, but not purelib. + + This is the only way I can see to tell a Red Hat-patched Python. + """ + from distutils.command.install import INSTALL_SCHEMES + + return all( + k in INSTALL_SCHEMES + and _looks_like_red_hat_patched_platlib_purelib(INSTALL_SCHEMES[k]) + for k in ("unix_prefix", "unix_home") + ) + + +@functools.lru_cache(maxsize=None) +def _looks_like_debian_scheme() -> bool: + """Debian adds two additional schemes.""" + from distutils.command.install import INSTALL_SCHEMES + + return "deb_system" in INSTALL_SCHEMES and "unix_local" in INSTALL_SCHEMES + + +@functools.lru_cache(maxsize=None) +def _looks_like_red_hat_scheme() -> bool: + """Red Hat patches ``sys.prefix`` and ``sys.exec_prefix``. + + Red Hat's ``00251-change-user-install-location.patch`` changes the install + command's ``prefix`` and ``exec_prefix`` to append ``"/local"``. This is + (fortunately?) done quite unconditionally, so we create a default command + object without any configuration to detect this. + """ + from distutils.command.install import install + from distutils.dist import Distribution + + cmd: Any = install(Distribution()) + cmd.finalize_options() + return ( + cmd.exec_prefix == f"{os.path.normpath(sys.exec_prefix)}/local" + and cmd.prefix == f"{os.path.normpath(sys.prefix)}/local" + ) + + +@functools.lru_cache(maxsize=None) +def _looks_like_slackware_scheme() -> bool: + """Slackware patches sysconfig but fails to patch distutils and site. + + Slackware changes sysconfig's user scheme to use ``"lib64"`` for the lib + path, but does not do the same to the site module. + """ + if user_site is None: # User-site not available. + return False + try: + paths = sysconfig.get_paths(scheme="posix_user", expand=False) + except KeyError: # User-site not available. return False - issue_url = "https://github.com/pypa/pip/issues/9617" + return "/lib64/" in paths["purelib"] and "/lib64/" not in user_site + + +@functools.lru_cache(maxsize=None) +def _looks_like_msys2_mingw_scheme() -> bool: + """MSYS2 patches distutils and sysconfig to use a UNIX-like scheme. + + However, MSYS2 incorrectly patches sysconfig ``nt`` scheme. The fix is + likely going to be included in their 3.10 release, so we ignore the warning. + See msys2/MINGW-packages#9319. + + MSYS2 MINGW's patch uses lowercase ``"lib"`` instead of the usual uppercase, + and is missing the final ``"site-packages"``. + """ + paths = sysconfig.get_paths("nt", expand=False) + return all( + "Lib" not in p and "lib" in p and not p.endswith("site-packages") + for p in (paths[key] for key in ("platlib", "purelib")) + ) + + +def _fix_abiflags(parts: Tuple[str]) -> Generator[str, None, None]: + ldversion = sysconfig.get_config_var("LDVERSION") + abiflags = getattr(sys, "abiflags", None) + + # LDVERSION does not end with sys.abiflags. Just return the path unchanged. + if not ldversion or not abiflags or not ldversion.endswith(abiflags): + yield from parts + return + + # Strip sys.abiflags from LDVERSION-based path components. + for part in parts: + if part.endswith(ldversion): + part = part[: (0 - len(abiflags))] + yield part + + +@functools.lru_cache(maxsize=None) +def _warn_mismatched(old: pathlib.Path, new: pathlib.Path, *, key: str) -> None: + issue_url = "https://github.com/pypa/pip/issues/10151" message = ( "Value for %s does not match. Please report this to <%s>" "\ndistutils: %s" "\nsysconfig: %s" ) - logger.debug(message, key, issue_url, old, new) + logger.log(_MISMATCH_LEVEL, message, key, issue_url, old, new) + + +def _warn_if_mismatch(old: pathlib.Path, new: pathlib.Path, *, key: str) -> bool: + if old == new: + return False + _warn_mismatched(old, new, key=key) return True +@functools.lru_cache(maxsize=None) def _log_context( *, user: bool = False, @@ -62,22 +216,26 @@ def _log_context( root: Optional[str] = None, prefix: Optional[str] = None, ) -> None: - message = ( - "Additional context:" "\nuser = %r" "\nhome = %r" "\nroot = %r" "\nprefix = %r" - ) - logger.debug(message, user, home, root, prefix) + parts = [ + "Additional context:", + "user = %r", + "home = %r", + "root = %r", + "prefix = %r", + ] + + logger.log(_MISMATCH_LEVEL, "\n".join(parts), user, home, root, prefix) def get_scheme( - dist_name, # type: str - user=False, # type: bool - home=None, # type: Optional[str] - root=None, # type: Optional[str] - isolated=False, # type: bool - prefix=None, # type: Optional[str] -): - # type: (...) -> Scheme - old = _distutils.get_scheme( + dist_name: str, + user: bool = False, + home: Optional[str] = None, + root: Optional[str] = None, + isolated: bool = False, + prefix: Optional[str] = None, +) -> Scheme: + new = _sysconfig.get_scheme( dist_name, user=user, home=home, @@ -85,7 +243,10 @@ def get_scheme( isolated=isolated, prefix=prefix, ) - new = _sysconfig.get_scheme( + if _USE_SYSCONFIG: + return new + + old = _distutils.get_scheme( dist_name, user=user, home=home, @@ -94,13 +255,14 @@ def get_scheme( prefix=prefix, ) - base = prefix or home or _default_base(user=user) - warned = [] + warning_contexts = [] for k in SCHEME_KEYS: - # Extra join because distutils can return relative paths. - old_v = pathlib.Path(base, getattr(old, k)) + old_v = pathlib.Path(getattr(old, k)) new_v = pathlib.Path(getattr(new, k)) + if old_v == new_v: + continue + # distutils incorrectly put PyPy packages under ``site-packages/python`` # in the ``posix_home`` scheme, but PyPy devs said they expect the # directory name to be ``pypy`` instead. So we treat this as a bug fix @@ -110,75 +272,196 @@ def get_scheme( and home is not None and k in ("platlib", "purelib") and old_v.parent == new_v.parent - and old_v.name == "python" - and new_v.name == "pypy" + and old_v.name.startswith("python") + and new_v.name.startswith("pypy") ) if skip_pypy_special_case: continue - warned.append(_warn_if_mismatch(old_v, new_v, key=f"scheme.{k}")) + # sysconfig's ``osx_framework_user`` does not include ``pythonX.Y`` in + # the ``include`` value, but distutils's ``headers`` does. We'll let + # CPython decide whether this is a bug or feature. See bpo-43948. + skip_osx_framework_user_special_case = ( + user + and is_osx_framework() + and k == "headers" + and old_v.parent.parent == new_v.parent + and old_v.parent.name.startswith("python") + ) + if skip_osx_framework_user_special_case: + continue + + # On Red Hat and derived Linux distributions, distutils is patched to + # use "lib64" instead of "lib" for platlib. + if k == "platlib" and _looks_like_red_hat_lib(): + continue + + # On Python 3.9+, sysconfig's posix_user scheme sets platlib against + # sys.platlibdir, but distutils's unix_user incorrectly coninutes + # using the same $usersite for both platlib and purelib. This creates a + # mismatch when sys.platlibdir is not "lib". + skip_bpo_44860 = ( + user + and k == "platlib" + and not WINDOWS + and sys.version_info >= (3, 9) + and _PLATLIBDIR != "lib" + and _looks_like_bpo_44860() + ) + if skip_bpo_44860: + continue + + # Slackware incorrectly patches posix_user to use lib64 instead of lib, + # but not usersite to match the location. + skip_slackware_user_scheme = ( + user + and k in ("platlib", "purelib") + and not WINDOWS + and _looks_like_slackware_scheme() + ) + if skip_slackware_user_scheme: + continue + + # Both Debian and Red Hat patch Python to place the system site under + # /usr/local instead of /usr. Debian also places lib in dist-packages + # instead of site-packages, but the /usr/local check should cover it. + skip_linux_system_special_case = ( + not (user or home or prefix or running_under_virtualenv()) + and old_v.parts[1:3] == ("usr", "local") + and len(new_v.parts) > 1 + and new_v.parts[1] == "usr" + and (len(new_v.parts) < 3 or new_v.parts[2] != "local") + and (_looks_like_red_hat_scheme() or _looks_like_debian_scheme()) + ) + if skip_linux_system_special_case: + continue + + # On Python 3.7 and earlier, sysconfig does not include sys.abiflags in + # the "pythonX.Y" part of the path, but distutils does. + skip_sysconfig_abiflag_bug = ( + sys.version_info < (3, 8) + and not WINDOWS + and k in ("headers", "platlib", "purelib") + and tuple(_fix_abiflags(old_v.parts)) == new_v.parts + ) + if skip_sysconfig_abiflag_bug: + continue + + # MSYS2 MINGW's sysconfig patch does not include the "site-packages" + # part of the path. This is incorrect and will be fixed in MSYS. + skip_msys2_mingw_bug = ( + WINDOWS and k in ("platlib", "purelib") and _looks_like_msys2_mingw_scheme() + ) + if skip_msys2_mingw_bug: + continue + + # CPython's POSIX install script invokes pip (via ensurepip) against the + # interpreter located in the source tree, not the install site. This + # triggers special logic in sysconfig that's not present in distutils. + # https://github.com/python/cpython/blob/8c21941ddaf/Lib/sysconfig.py#L178-L194 + skip_cpython_build = ( + sysconfig.is_python_build(check_home=True) + and not WINDOWS + and k in ("headers", "include", "platinclude") + ) + if skip_cpython_build: + continue + + warning_contexts.append((old_v, new_v, f"scheme.{k}")) + + if not warning_contexts: + return old + + # Check if this path mismatch is caused by distutils config files. Those + # files will no longer work once we switch to sysconfig, so this raises a + # deprecation message for them. + default_old = _distutils.distutils_scheme( + dist_name, + user, + home, + root, + isolated, + prefix, + ignore_config_files=True, + ) + if any(default_old[k] != getattr(old, k) for k in SCHEME_KEYS): + deprecated( + reason=( + "Configuring installation scheme with distutils config files " + "is deprecated and will no longer work in the near future. If you " + "are using a Homebrew or Linuxbrew Python, please see discussion " + "at https://github.com/Homebrew/homebrew-core/issues/76621" + ), + replacement=None, + gone_in=None, + ) + return old - if any(warned): - _log_context(user=user, home=home, root=root, prefix=prefix) + # Post warnings about this mismatch so user can report them back. + for old_v, new_v, key in warning_contexts: + _warn_mismatched(old_v, new_v, key=key) + _log_context(user=user, home=home, root=root, prefix=prefix) return old -def get_bin_prefix(): - # type: () -> str - old = _distutils.get_bin_prefix() +def get_bin_prefix() -> str: new = _sysconfig.get_bin_prefix() + if _USE_SYSCONFIG: + return new + + old = _distutils.get_bin_prefix() if _warn_if_mismatch(pathlib.Path(old), pathlib.Path(new), key="bin_prefix"): _log_context() return old -def get_bin_user(): - # type: () -> str +def get_bin_user() -> str: return _sysconfig.get_scheme("", user=True).scripts -def get_purelib(): - # type: () -> str +def _looks_like_deb_system_dist_packages(value: str) -> bool: + """Check if the value is Debian's APT-controlled dist-packages. + + Debian's ``distutils.sysconfig.get_python_lib()`` implementation returns the + default package path controlled by APT, but does not patch ``sysconfig`` to + do the same. This is similar to the bug worked around in ``get_scheme()``, + but here the default is ``deb_system`` instead of ``unix_local``. Ultimately + we can't do anything about this Debian bug, and this detection allows us to + skip the warning when needed. + """ + if not _looks_like_debian_scheme(): + return False + if value == "/usr/lib/python3/dist-packages": + return True + return False + + +def get_purelib() -> str: """Return the default pure-Python lib location.""" - old = _distutils.get_purelib() new = _sysconfig.get_purelib() + if _USE_SYSCONFIG: + return new + + old = _distutils.get_purelib() + if _looks_like_deb_system_dist_packages(old): + return old if _warn_if_mismatch(pathlib.Path(old), pathlib.Path(new), key="purelib"): _log_context() return old -def get_platlib(): - # type: () -> str +def get_platlib() -> str: """Return the default platform-shared lib location.""" - old = _distutils.get_platlib() new = _sysconfig.get_platlib() + if _USE_SYSCONFIG: + return new + + from . import _distutils + + old = _distutils.get_platlib() + if _looks_like_deb_system_dist_packages(old): + return old if _warn_if_mismatch(pathlib.Path(old), pathlib.Path(new), key="platlib"): _log_context() return old - - -def get_prefixed_libs(prefix): - # type: (str) -> List[str] - """Return the lib locations under ``prefix``.""" - old_pure, old_plat = _distutils.get_prefixed_libs(prefix) - new_pure, new_plat = _sysconfig.get_prefixed_libs(prefix) - - warned = [ - _warn_if_mismatch( - pathlib.Path(old_pure), - pathlib.Path(new_pure), - key="prefixed-purelib", - ), - _warn_if_mismatch( - pathlib.Path(old_plat), - pathlib.Path(new_plat), - key="prefixed-platlib", - ), - ] - if any(warned): - _log_context(prefix=prefix) - - if old_pure == old_plat: - return [old_pure] - return [old_pure, old_plat] diff --git a/env/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 3d19e8715c4d0408347699bbbce4e079c03c082b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3710 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 diff --git a/env/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-39.pyc deleted file mode 100644 index e13efd8ecdfb8353e2a5b63eff73d5ebe58194ce..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3907 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 diff --git a/env/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-39.pyc deleted file mode 100644 index 92a05c6453ca8f227db8ed333822ae0bdf066118..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4525 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 WgO8Dmm4Oioe{p$maB#44umS)&w4jCn diff --git a/env/Lib/site-packages/pip/_internal/locations/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/locations/__pycache__/base.cpython-39.pyc deleted file mode 100644 index eed182270bed2d109b288c03b2fe65a134ee2e86..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1238 zcmYe~<>g{vU|^UdaWM55D+9x05C<7^FfcGUFfcF__c1Uqq%fo~<}gG-XvQc;FrO)k z2~0CbF@tHAD3%n46s8>3T(&4SMvz+O9QIs}C=N!3RJH}2DJ%;aqqtI;7jUPrE@X`2 zNnuN2Z()eyP2ou4Y+;DvtKvyzT)@AOAxa>eAy0yZAyu%lgOLFQQyH^_q68ut@|X-5 zQW%37G`U`aT<WLEc#A!;pdcl)s92NnmPAo$US4KidVFbKN@`JjS!Pj5X<|-lUfC_? zg3N+j>;<JosX3WR$sn!Bn2CXb!5QRH9*{>FvlvPkvzYoAf*CZKs#3WW6ciMKQcFsU z@)SxkQWbI&v+|2{b2IbuixkRIi;6Sz^Az&az*5PjMMbH3B?<wRB^mj73W>!Ei3-If zMVWc&Itr<J>3U$Jl#KPvl@#)e6qJnh3=NbZf>o^5wR+XHn#{M@((;RP6H9I}7grYF z;(=NapP84IzmlPdlYs$3{AzHviU}=FEh>&l%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi z3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwuiAglk&B;&CEH25+j!Dfci}A@!iYd-4 zN!2Y#OwLYBPc4oq$Sly0&&(@HEy_#G(a*_GPAtjH&nwnXN-R#*E2z9Bo}O9~4-SlY zaA3qk-6{wQNKl9}uoZDLFfgEmHX{QA11MR6Lpy?jfuV$<nW0Dm6y6J%OIWg4Qy3RA z)iUInREa^w7#FZDWPpf<GvvvzFqE)YdV!JzBSQ(x0*(}>g^Y|0kc0u&!CAww5R^ce z{cbTA7bREOhGe8Fq~+(Nq!uYu=9elY7NshrR-`7EmSpCoD->iFD5MqT=PD#8<|*Xm zE9B(orKc7tB!RS)=B4OqauqQ%FfiO=$}hgfQjl1Zaf>A@KQph09VEzBP?VaMS#gUk zJ+&mcJmnU<f3Ry&QGU@ameh*Ol3VPFNyQ*7nvA!&ii?utA*vB^SOm&_xA;K8h>(^7 zg&rR$aWb(n3NbS=iZSvq39uB2F)%P_3K#K$>}3H(6vPRf#g)a$`FUxX>9^QQDho36 z(xZe6G7I$J5vNyLl9^Ln1d5Maa#&>a5SawxQ@+yT)S~$0#N>?B_>|0|TYRCxu0iq6 zj?Nyg@h+Z0w>UuV1$pZhFUT43u=E0sYp^qK38$x)fJ_0&!=!I<f<)p$Lbv!FOG=6| zlS)fcA;HB7wj$Uw#1$!Uz)2k(LL4@^`6;D2sdk{mQ!E2YL5v&_$i&0Q!_39Z#mvFU MA;`qc!^p!30L-^j>;M1& diff --git a/env/Lib/site-packages/pip/_internal/locations/_distutils.py b/env/Lib/site-packages/pip/_internal/locations/_distutils.py index 2d7ab732..92bd9317 100644 --- a/env/Lib/site-packages/pip/_internal/locations/_distutils.py +++ b/env/Lib/site-packages/pip/_internal/locations/_distutils.py @@ -3,13 +3,25 @@ # The following comment should be removed at some point in the future. # mypy: strict-optional=False +# If pip's going to use distutils, it should not be using the copy that setuptools +# might have injected into the environment. This is done by removing the injected +# shim, if it's injected. +# +# See https://github.com/pypa/pip/issues/8761 for the original discussion and +# rationale for why this is done within pip. +try: + __import__("_distutils_hack").remove_shim() +except (ImportError, AttributeError): + pass + +import logging import os import sys from distutils.cmd import Command as DistutilsCommand from distutils.command.install import SCHEME_KEYS from distutils.command.install import install as distutils_install_command from distutils.sysconfig import get_python_lib -from typing import Dict, List, Optional, Tuple, Union, cast +from typing import Dict, List, Optional, Union, cast from pip._internal.models.scheme import Scheme from pip._internal.utils.compat import WINDOWS @@ -17,23 +29,40 @@ from pip._internal.utils.virtualenv import running_under_virtualenv from .base import get_major_minor_version +logger = logging.getLogger(__name__) -def _distutils_scheme( - dist_name, user=False, home=None, root=None, isolated=False, prefix=None -): - # type:(str, bool, str, str, bool, str) -> Dict[str, str] + +def distutils_scheme( + dist_name: str, + user: bool = False, + home: Optional[str] = None, + root: Optional[str] = None, + isolated: bool = False, + prefix: Optional[str] = None, + *, + ignore_config_files: bool = False, +) -> Dict[str, str]: """ Return a distutils install scheme """ from distutils.dist import Distribution - dist_args = {"name": dist_name} # type: Dict[str, Union[str, List[str]]] + dist_args: Dict[str, Union[str, List[str]]] = {"name": dist_name} if isolated: dist_args["script_args"] = ["--no-user-cfg"] d = Distribution(dist_args) - d.parse_config_files() - obj = None # type: Optional[DistutilsCommand] + if not ignore_config_files: + try: + d.parse_config_files() + except UnicodeDecodeError: + # Typeshed does not include find_config_files() for some reason. + paths = d.find_config_files() # type: ignore + logger.warning( + "Ignore distutils configs in %s due to encoding errors.", + ", ".join(os.path.basename(p) for p in paths), + ) + obj: Optional[DistutilsCommand] = None obj = d.get_command_obj("install", create=True) assert obj is not None i = cast(distutils_install_command, obj) @@ -63,8 +92,14 @@ def _distutils_scheme( scheme.update(dict(purelib=i.install_lib, platlib=i.install_lib)) if running_under_virtualenv(): + if home: + prefix = home + elif user: + prefix = i.install_userbase + else: + prefix = i.prefix scheme["headers"] = os.path.join( - i.prefix, + prefix, "include", "site", f"python{get_major_minor_version()}", @@ -73,23 +108,19 @@ def _distutils_scheme( if root is not None: path_no_drive = os.path.splitdrive(os.path.abspath(scheme["headers"]))[1] - scheme["headers"] = os.path.join( - root, - path_no_drive[1:], - ) + scheme["headers"] = os.path.join(root, path_no_drive[1:]) return scheme def get_scheme( - dist_name, # type: str - user=False, # type: bool - home=None, # type: Optional[str] - root=None, # type: Optional[str] - isolated=False, # type: bool - prefix=None, # type: Optional[str] -): - # type: (...) -> Scheme + dist_name: str, + user: bool = False, + home: Optional[str] = None, + root: Optional[str] = None, + isolated: bool = False, + prefix: Optional[str] = None, +) -> Scheme: """ Get the "scheme" corresponding to the input parameters. The distutils documentation provides the context for the available schemes: @@ -107,7 +138,7 @@ def get_scheme( :param prefix: indicates to use the "prefix" scheme and provides the base directory for the same """ - scheme = _distutils_scheme(dist_name, user, home, root, isolated, prefix) + scheme = distutils_scheme(dist_name, user, home, root, isolated, prefix) return Scheme( platlib=scheme["platlib"], purelib=scheme["purelib"], @@ -117,34 +148,26 @@ def get_scheme( ) -def get_bin_prefix(): - # type: () -> str +def get_bin_prefix() -> str: + # XXX: In old virtualenv versions, sys.prefix can contain '..' components, + # so we need to call normpath to eliminate them. + prefix = os.path.normpath(sys.prefix) if WINDOWS: - bin_py = os.path.join(sys.prefix, "Scripts") + bin_py = os.path.join(prefix, "Scripts") # buildout uses 'bin' on Windows too? if not os.path.exists(bin_py): - bin_py = os.path.join(sys.prefix, "bin") + bin_py = os.path.join(prefix, "bin") return bin_py # Forcing to use /usr/local/bin for standard macOS framework installs # Also log to ~/Library/Logs/ for use with the Console.app log viewer - if sys.platform[:6] == "darwin" and sys.prefix[:16] == "/System/Library/": + if sys.platform[:6] == "darwin" and prefix[:16] == "/System/Library/": return "/usr/local/bin" - return os.path.join(sys.prefix, "bin") + return os.path.join(prefix, "bin") -def get_purelib(): - # type: () -> str +def get_purelib() -> str: return get_python_lib(plat_specific=False) -def get_platlib(): - # type: () -> str +def get_platlib() -> str: return get_python_lib(plat_specific=True) - - -def get_prefixed_libs(prefix): - # type: (str) -> Tuple[str, str] - return ( - get_python_lib(plat_specific=False, prefix=prefix), - get_python_lib(plat_specific=True, prefix=prefix), - ) diff --git a/env/Lib/site-packages/pip/_internal/locations/_sysconfig.py b/env/Lib/site-packages/pip/_internal/locations/_sysconfig.py index 03366ce6..97aef1f1 100644 --- a/env/Lib/site-packages/pip/_internal/locations/_sysconfig.py +++ b/env/Lib/site-packages/pip/_internal/locations/_sysconfig.py @@ -1,4 +1,3 @@ -import distutils.util # FIXME: For change_root. import logging import os import sys @@ -9,14 +8,14 @@ from pip._internal.exceptions import InvalidSchemeCombination, UserInstallationI from pip._internal.models.scheme import SCHEME_KEYS, Scheme from pip._internal.utils.virtualenv import running_under_virtualenv -from .base import get_major_minor_version +from .base import change_root, get_major_minor_version, is_osx_framework logger = logging.getLogger(__name__) # Notes on _infer_* functions. -# Unfortunately ``_get_default_scheme()`` is private, so there's no way to -# ask things like "what is the '_prefix' scheme on this platform". These +# Unfortunately ``get_default_scheme()`` didn't exist before 3.10, so there's no +# way to ask things like "what is the '_prefix' scheme on this platform". These # functions try to answer that with some heuristics while accounting for ad-hoc # platforms not covered by CPython's default sysconfig implementation. If the # ad-hoc implementation does not fully implement sysconfig, we'll fall back to @@ -24,13 +23,42 @@ logger = logging.getLogger(__name__) _AVAILABLE_SCHEMES = set(sysconfig.get_scheme_names()) +_PREFERRED_SCHEME_API = getattr(sysconfig, "get_preferred_scheme", None) -def _infer_prefix(): - # type: () -> str + +def _should_use_osx_framework_prefix() -> bool: + """Check for Apple's ``osx_framework_library`` scheme. + + Python distributed by Apple's Command Line Tools has this special scheme + that's used when: + + * This is a framework build. + * We are installing into the system prefix. + + This does not account for ``pip install --prefix`` (also means we're not + installing to the system prefix), which should use ``posix_prefix``, but + logic here means ``_infer_prefix()`` outputs ``osx_framework_library``. But + since ``prefix`` is not available for ``sysconfig.get_default_scheme()``, + which is the stdlib replacement for ``_infer_prefix()``, presumably Apple + wouldn't be able to magically switch between ``osx_framework_library`` and + ``posix_prefix``. ``_infer_prefix()`` returning ``osx_framework_library`` + means its behavior is consistent whether we use the stdlib implementation + or our own, and we deal with this special case in ``get_scheme()`` instead. + """ + return ( + "osx_framework_library" in _AVAILABLE_SCHEMES + and not running_under_virtualenv() + and is_osx_framework() + ) + + +def _infer_prefix() -> str: """Try to find a prefix scheme for the current platform. This tries: + * A special ``osx_framework_library`` for Python distributed by Apple's + Command Line Tools, when not running in a virtual environment. * Implementation + OS, used by PyPy on Windows (``pypy_nt``). * Implementation without OS, used by PyPy on POSIX (``pypy``). * OS + "prefix", used by CPython on POSIX (``posix_prefix``). @@ -38,6 +66,10 @@ def _infer_prefix(): If none of the above works, fall back to ``posix_prefix``. """ + if _PREFERRED_SCHEME_API: + return _PREFERRED_SCHEME_API("prefix") + if _should_use_osx_framework_prefix(): + return "osx_framework_library" implementation_suffixed = f"{sys.implementation.name}_{os.name}" if implementation_suffixed in _AVAILABLE_SCHEMES: return implementation_suffixed @@ -51,10 +83,14 @@ def _infer_prefix(): return "posix_prefix" -def _infer_user(): - # type: () -> str +def _infer_user() -> str: """Try to find a user scheme for the current platform.""" - suffixed = f"{os.name}_user" + if _PREFERRED_SCHEME_API: + return _PREFERRED_SCHEME_API("user") + if is_osx_framework() and not running_under_virtualenv(): + suffixed = "osx_framework_user" + else: + suffixed = f"{os.name}_user" if suffixed in _AVAILABLE_SCHEMES: return suffixed if "posix_user" not in _AVAILABLE_SCHEMES: # User scheme unavailable. @@ -62,9 +98,10 @@ def _infer_user(): return "posix_user" -def _infer_home(): - # type: () -> str +def _infer_home() -> str: """Try to find a home for the current platform.""" + if _PREFERRED_SCHEME_API: + return _PREFERRED_SCHEME_API("home") suffixed = f"{os.name}_home" if suffixed in _AVAILABLE_SCHEMES: return suffixed @@ -85,14 +122,13 @@ if sysconfig.get_config_var("userbase") is not None: def get_scheme( - dist_name, # type: str - user=False, # type: bool - home=None, # type: typing.Optional[str] - root=None, # type: typing.Optional[str] - isolated=False, # type: bool - prefix=None, # type: typing.Optional[str] -): - # type: (...) -> Scheme + dist_name: str, + user: bool = False, + home: typing.Optional[str] = None, + root: typing.Optional[str] = None, + isolated: bool = False, + prefix: typing.Optional[str] = None, +) -> Scheme: """ Get the "scheme" corresponding to the input parameters. @@ -118,6 +154,12 @@ def get_scheme( else: scheme_name = _infer_prefix() + # Special case: When installing into a custom prefix, use posix_prefix + # instead of osx_framework_library. See _should_use_osx_framework_prefix() + # docstring for details. + if prefix is not None and scheme_name == "osx_framework_library": + scheme_name = "posix_prefix" + if home is not None: variables = {k: home for k in _HOME_KEYS} elif prefix is not None: @@ -151,30 +193,21 @@ def get_scheme( ) if root is not None: for key in SCHEME_KEYS: - value = distutils.util.change_root(root, getattr(scheme, key)) + value = change_root(root, getattr(scheme, key)) setattr(scheme, key, value) return scheme -def get_bin_prefix(): - # type: () -> str +def get_bin_prefix() -> str: # Forcing to use /usr/local/bin for standard macOS framework installs. if sys.platform[:6] == "darwin" and sys.prefix[:16] == "/System/Library/": return "/usr/local/bin" return sysconfig.get_paths()["scripts"] -def get_purelib(): - # type: () -> str +def get_purelib() -> str: return sysconfig.get_paths()["purelib"] -def get_platlib(): - # type: () -> str +def get_platlib() -> str: return sysconfig.get_paths()["platlib"] - - -def get_prefixed_libs(prefix): - # type: (str) -> typing.Tuple[str, str] - paths = sysconfig.get_paths(vars={"base": prefix, "platbase": prefix}) - return (paths["purelib"], paths["platlib"]) diff --git a/env/Lib/site-packages/pip/_internal/locations/base.py b/env/Lib/site-packages/pip/_internal/locations/base.py index 98557abb..3f9f896e 100644 --- a/env/Lib/site-packages/pip/_internal/locations/base.py +++ b/env/Lib/site-packages/pip/_internal/locations/base.py @@ -1,9 +1,11 @@ +import functools import os import site import sys import sysconfig import typing +from pip._internal.exceptions import InstallationError from pip._internal.utils import appdirs from pip._internal.utils.virtualenv import running_under_virtualenv @@ -11,11 +13,10 @@ from pip._internal.utils.virtualenv import running_under_virtualenv USER_CACHE_DIR = appdirs.user_cache_dir("pip") # FIXME doesn't account for venv linked to global site-packages -site_packages = sysconfig.get_path("purelib") # type: typing.Optional[str] +site_packages: str = sysconfig.get_path("purelib") -def get_major_minor_version(): - # type: () -> str +def get_major_minor_version() -> str: """ Return the major-minor version of the current Python as a string, e.g. "3.7" or "3.10". @@ -23,8 +24,35 @@ def get_major_minor_version(): return "{}.{}".format(*sys.version_info) -def get_src_prefix(): - # type: () -> str +def change_root(new_root: str, pathname: str) -> str: + """Return 'pathname' with 'new_root' prepended. + + If 'pathname' is relative, this is equivalent to os.path.join(new_root, pathname). + Otherwise, it requires making 'pathname' relative and then joining the + two, which is tricky on DOS/Windows and Mac OS. + + This is borrowed from Python's standard library's distutils module. + """ + if os.name == "posix": + if not os.path.isabs(pathname): + return os.path.join(new_root, pathname) + else: + return os.path.join(new_root, pathname[1:]) + + elif os.name == "nt": + (drive, path) = os.path.splitdrive(pathname) + if path[0] == "\\": + path = path[1:] + return os.path.join(new_root, path) + + else: + raise InstallationError( + f"Unknown platform: {os.name}\n" + "Can not change root path prefix on unknown platform." + ) + + +def get_src_prefix() -> str: if running_under_virtualenv(): src_prefix = os.path.join(sys.prefix, "src") else: @@ -43,6 +71,11 @@ def get_src_prefix(): try: # Use getusersitepackages if this is present, as it ensures that the # value is initialised properly. - user_site = site.getusersitepackages() # type: typing.Optional[str] + user_site: typing.Optional[str] = site.getusersitepackages() except AttributeError: user_site = site.USER_SITE + + +@functools.lru_cache(maxsize=None) +def is_osx_framework() -> bool: + return bool(sysconfig.get_config_var("PYTHONFRAMEWORK")) diff --git a/env/Lib/site-packages/pip/_internal/main.py b/env/Lib/site-packages/pip/_internal/main.py index 51eee158..33c6d24c 100644 --- a/env/Lib/site-packages/pip/_internal/main.py +++ b/env/Lib/site-packages/pip/_internal/main.py @@ -1,8 +1,7 @@ from typing import List, Optional -def main(args=None): - # type: (Optional[List[str]]) -> int +def main(args: Optional[List[str]] = None) -> int: """This is preserved for old console scripts that may still be referencing it. diff --git a/env/Lib/site-packages/pip/_internal/metadata/__init__.py b/env/Lib/site-packages/pip/_internal/metadata/__init__.py index 63335a19..9f73ca71 100644 --- a/env/Lib/site-packages/pip/_internal/metadata/__init__.py +++ b/env/Lib/site-packages/pip/_internal/metadata/__init__.py @@ -1,36 +1,100 @@ -from typing import List, Optional +import contextlib +import functools +import os +import sys +from typing import TYPE_CHECKING, List, Optional, Type, cast -from .base import BaseDistribution, BaseEnvironment +from pip._internal.utils.misc import strtobool +from .base import BaseDistribution, BaseEnvironment, FilesystemWheel, MemoryWheel, Wheel -def get_default_environment(): - # type: () -> BaseEnvironment +if TYPE_CHECKING: + from typing import Protocol +else: + Protocol = object + +__all__ = [ + "BaseDistribution", + "BaseEnvironment", + "FilesystemWheel", + "MemoryWheel", + "Wheel", + "get_default_environment", + "get_environment", + "get_wheel_distribution", + "select_backend", +] + + +def _should_use_importlib_metadata() -> bool: + """Whether to use the ``importlib.metadata`` or ``pkg_resources`` backend. + + By default, pip uses ``importlib.metadata`` on Python 3.11+, and + ``pkg_resourcess`` otherwise. This can be overridden by a couple of ways: + + * If environment variable ``_PIP_USE_IMPORTLIB_METADATA`` is set, it + dictates whether ``importlib.metadata`` is used, regardless of Python + version. + * On Python 3.11+, Python distributors can patch ``importlib.metadata`` + to add a global constant ``_PIP_USE_IMPORTLIB_METADATA = False``. This + makes pip use ``pkg_resources`` (unless the user set the aforementioned + environment variable to *True*). + """ + with contextlib.suppress(KeyError, ValueError): + return bool(strtobool(os.environ["_PIP_USE_IMPORTLIB_METADATA"])) + if sys.version_info < (3, 11): + return False + import importlib.metadata + + return bool(getattr(importlib.metadata, "_PIP_USE_IMPORTLIB_METADATA", True)) + + +class Backend(Protocol): + Distribution: Type[BaseDistribution] + Environment: Type[BaseEnvironment] + + +@functools.lru_cache(maxsize=None) +def select_backend() -> Backend: + if _should_use_importlib_metadata(): + from . import importlib + + return cast(Backend, importlib) + from . import pkg_resources + + return cast(Backend, pkg_resources) + + +def get_default_environment() -> BaseEnvironment: """Get the default representation for the current environment. This returns an Environment instance from the chosen backend. The default Environment instance should be built from ``sys.path`` and may use caching to share instance state accorss calls. """ - from .pkg_resources import Environment + return select_backend().Environment.default() - return Environment.default() - -def get_environment(paths): - # type: (Optional[List[str]]) -> BaseEnvironment +def get_environment(paths: Optional[List[str]]) -> BaseEnvironment: """Get a representation of the environment specified by ``paths``. This returns an Environment instance from the chosen backend based on the given import paths. The backend must build a fresh instance representing the state of installed distributions when this function is called. """ - from .pkg_resources import Environment + return select_backend().Environment.from_paths(paths) + + +def get_directory_distribution(directory: str) -> BaseDistribution: + """Get the distribution metadata representation in the specified directory. - return Environment.from_paths(paths) + This returns a Distribution instance from the chosen backend based on + the given on-disk ``.dist-info`` directory. + """ + return select_backend().Distribution.from_directory(directory) -def get_wheel_distribution(wheel_path, canonical_name): - # type: (str, str) -> BaseDistribution +def get_wheel_distribution(wheel: Wheel, canonical_name: str) -> BaseDistribution: """Get the representation of the specified wheel's distribution metadata. This returns a Distribution instance from the chosen backend based on @@ -38,6 +102,26 @@ def get_wheel_distribution(wheel_path, canonical_name): :param canonical_name: Normalized project name of the given wheel. """ - from .pkg_resources import Distribution + return select_backend().Distribution.from_wheel(wheel, canonical_name) + - return Distribution.from_wheel(wheel_path, canonical_name) +def get_metadata_distribution( + metadata_contents: bytes, + filename: str, + canonical_name: str, +) -> BaseDistribution: + """Get the dist representation of the specified METADATA file contents. + + This returns a Distribution instance from the chosen backend sourced from the data + in `metadata_contents`. + + :param metadata_contents: Contents of a METADATA file within a dist, or one served + via PEP 658. + :param filename: Filename for the dist this metadata represents. + :param canonical_name: Normalized project name of the given dist. + """ + return select_backend().Distribution.from_metadata_file_contents( + metadata_contents, + filename, + canonical_name, + ) diff --git a/env/Lib/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index bea5930d53a0c4717b2f4cfcd5dc5ca87ed994c8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1753 zcmYe~<>g{vU|^UdaWHj1D+9x05C<7EF)%PVFfcF_+b}RNq%fo~<}l<kMlt3xMKLil zq%fs0=P>88M6u+uMzJz7q_Cv0wlGAorLd*2w=hJpr*NcjwlG9-q;Lf@XmY;<nXAck zi^V6ixa1axe?duReqLhEOGX9;22G}00#1p=sV<qtB}JJ@r68$W{2&q6yt2%q{Jh-M zypm*)0Wb{G1#+A-$Z;Yd$1$cbfgD%Mz{pU;uz+bHLokCTb0Q}r1A}{Ni9$(6szOR? zT4HHVi9%6oK~ZXPYF<eq$R35X{35V)a%oXfYF>##D#A)VE-nQH1%;4|%wmP2)RNMo zykdpKJOw02DP-mqmn7yTrz)fs<>x}o$;dBG%~ME9OwLZtOVLvZL0Ano4Xf_rjQrA^ z6osTzg{0EVoDzs>2?@oO#d-yaB^e0`3W<3s3b~1u3Z=!V3dxDd8JT(MVB<>i6^b(w zi&7CTDK1GYNmWQpPR=hXE>=iR%*iR%11l|JVPIfb$#{z!$qAaww|EP()8mU$i}Op1 zl2eO|I2afhZm~lHtB4(>g`tR>fq~&yv$Iu9XmM&$aZGAXN@h`ve_pCfQD#}Hg04cS zpJ$kBP_So+W3Ym!pNqerYp|zdOt7o3YjB8bkb+rEK!8t7qKR%!etKqcNoICTYF=54 zPi9g~ab`)XZb4#lc4B&JaZEvGfqr~uUP)?EUSf`ZZfZ$lN@7W(etdjpUS>&ryk0@& zE%Ef!l6a`=;*sKt4U`f<9%SI)VJhNfU|>iFB@$SI0VNh@1_lOjf)PVbFpP{0HH-_G zY8VzWf|HCoG|42QCzSj&aQq_KsZd;ynw*)InVO=IRH=}V0E(*Ogaj%i8-=9A;?xv{ z{5+7A;K)nQEKAK($jmLsFDg+0TLej3&~&DdTUuNKPCO|Ji3({&sl^$H6ai21@I;f5 zssKqQ`DqYkIXS5*3MokWuUMfxBNb$QX0bwAX<jlouVg~fQ)&uQf&wQIP39s_1_lO5 z;^6}2g?O+VHJNU)f*D{La591rJfKv@4~k2q@DxUgLjh16g5nJphoJZa#V|MyC6MEg ziIJg(2^5Dlj0>5-vB(FFMNr0vdmobFq49`_yYh_G)ExC<6z?m*5+BycR6s7NAOVP{ z41h-_I3htVf<z|F-h>1_P{`|M=B4E)Bq*e07NsVa<QG*!t+pyiEK1B(NKVYl&&y0s z%!$uS%uTgY@XIgCP0Y!xN=;EHD9X=DO)gOYNhm<Qhhzm(WN9+q;z4#hEZzh`(E*7! zu&XqgZ*hSc;Ap(XhiZ8dNI4`PK?Oq*I5NdRkqOZQ@(rvUSAfSUCl6DRC<6n7pC;!m zwvx(%%)Im>Q1ljo;`J5_D8(1Cf)WuZD}!@z5hw|O^&nY>u#v+iH$SB`C)Ey=(ThRl NmH?9gGY2mRF8~lL`J(^; diff --git a/env/Lib/site-packages/pip/_internal/metadata/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/metadata/__pycache__/base.cpython-39.pyc deleted file mode 100644 index 15d4d9cd43929bb8621359d7e234a9b49100ce51..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5327 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 E0M5M}kN^Mx diff --git a/env/Lib/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-39.pyc deleted file mode 100644 index cd3d97162b0966eb1f7c5aad8187877a7c799777..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4281 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 diff --git a/env/Lib/site-packages/pip/_internal/metadata/base.py b/env/Lib/site-packages/pip/_internal/metadata/base.py index 37f9a823..cafb79fb 100644 --- a/env/Lib/site-packages/pip/_internal/metadata/base.py +++ b/env/Lib/site-packages/pip/_internal/metadata/base.py @@ -1,85 +1,604 @@ +import csv +import email.message +import functools +import json import logging +import pathlib import re -from typing import Container, Iterator, List, Optional, Union +import zipfile +from typing import ( + IO, + TYPE_CHECKING, + Any, + Collection, + Container, + Dict, + Iterable, + Iterator, + List, + NamedTuple, + Optional, + Tuple, + Union, +) +from pip._vendor.packaging.requirements import Requirement +from pip._vendor.packaging.specifiers import InvalidSpecifier, SpecifierSet +from pip._vendor.packaging.utils import NormalizedName from pip._vendor.packaging.version import LegacyVersion, Version -from pip._internal.utils.misc import stdlib_pkgs # TODO: Move definition here. +from pip._internal.exceptions import NoneMetadataError +from pip._internal.locations import site_packages, user_site +from pip._internal.models.direct_url import ( + DIRECT_URL_METADATA_NAME, + DirectUrl, + DirectUrlValidationError, +) +from pip._internal.utils.compat import stdlib_pkgs # TODO: Move definition here. +from pip._internal.utils.egg_link import egg_link_path_from_sys_path +from pip._internal.utils.misc import is_local, normalize_path +from pip._internal.utils.packaging import safe_extra +from pip._internal.utils.urls import url_to_path + +from ._json import msg_to_json + +if TYPE_CHECKING: + from typing import Protocol +else: + Protocol = object DistributionVersion = Union[LegacyVersion, Version] +InfoPath = Union[str, pathlib.PurePath] + logger = logging.getLogger(__name__) -class BaseDistribution: +class BaseEntryPoint(Protocol): + @property + def name(self) -> str: + raise NotImplementedError() + + @property + def value(self) -> str: + raise NotImplementedError() + + @property + def group(self) -> str: + raise NotImplementedError() + + +def _convert_installed_files_path( + entry: Tuple[str, ...], + info: Tuple[str, ...], +) -> str: + """Convert a legacy installed-files.txt path into modern RECORD path. + + The legacy format stores paths relative to the info directory, while the + modern format stores paths relative to the package root, e.g. the + site-packages directory. + + :param entry: Path parts of the installed-files.txt entry. + :param info: Path parts of the egg-info directory relative to package root. + :returns: The converted entry. + + For best compatibility with symlinks, this does not use ``abspath()`` or + ``Path.resolve()``, but tries to work with path parts: + + 1. While ``entry`` starts with ``..``, remove the equal amounts of parts + from ``info``; if ``info`` is empty, start appending ``..`` instead. + 2. Join the two directly. + """ + while entry and entry[0] == "..": + if not info or info[-1] == "..": + info += ("..",) + else: + info = info[:-1] + entry = entry[1:] + return str(pathlib.Path(*info, *entry)) + + +class RequiresEntry(NamedTuple): + requirement: str + extra: str + marker: str + + +class BaseDistribution(Protocol): + @classmethod + def from_directory(cls, directory: str) -> "BaseDistribution": + """Load the distribution from a metadata directory. + + :param directory: Path to a metadata directory, e.g. ``.dist-info``. + """ + raise NotImplementedError() + + @classmethod + def from_metadata_file_contents( + cls, + metadata_contents: bytes, + filename: str, + project_name: str, + ) -> "BaseDistribution": + """Load the distribution from the contents of a METADATA file. + + This is used to implement PEP 658 by generating a "shallow" dist object that can + be used for resolution without downloading or building the actual dist yet. + + :param metadata_contents: The contents of a METADATA file. + :param filename: File name for the dist with this metadata. + :param project_name: Name of the project this dist represents. + """ + raise NotImplementedError() + + @classmethod + def from_wheel(cls, wheel: "Wheel", name: str) -> "BaseDistribution": + """Load the distribution from a given wheel. + + :param wheel: A concrete wheel definition. + :param name: File name of the wheel. + + :raises InvalidWheel: Whenever loading of the wheel causes a + :py:exc:`zipfile.BadZipFile` exception to be thrown. + :raises UnsupportedWheel: If the wheel is a valid zip, but malformed + internally. + """ + raise NotImplementedError() + + def __repr__(self) -> str: + return f"{self.raw_name} {self.version} ({self.location})" + + def __str__(self) -> str: + return f"{self.raw_name} {self.version}" + @property - def location(self): - # type: () -> Optional[str] + def location(self) -> Optional[str]: """Where the distribution is loaded from. A string value is not necessarily a filesystem path, since distributions can be loaded from other sources, e.g. arbitrary zip archives. ``None`` means the distribution is created in-memory. + + Do not canonicalize this value with e.g. ``pathlib.Path.resolve()``. If + this is a symbolic link, we want to preserve the relative path between + it and files in the distribution. """ raise NotImplementedError() @property - def metadata_version(self): - # type: () -> Optional[str] - """Value of "Metadata-Version:" in the distribution, if available.""" - raise NotImplementedError() + def editable_project_location(self) -> Optional[str]: + """The project location for editable distributions. + + This is the directory where pyproject.toml or setup.py is located. + None if the distribution is not installed in editable mode. + """ + # TODO: this property is relatively costly to compute, memoize it ? + direct_url = self.direct_url + if direct_url: + if direct_url.is_local_editable(): + return url_to_path(direct_url.url) + else: + # Search for an .egg-link file by walking sys.path, as it was + # done before by dist_is_editable(). + egg_link_path = egg_link_path_from_sys_path(self.raw_name) + if egg_link_path: + # TODO: get project location from second line of egg_link file + # (https://github.com/pypa/pip/issues/10243) + return self.location + return None @property - def canonical_name(self): - # type: () -> str + def installed_location(self) -> Optional[str]: + """The distribution's "installed" location. + + This should generally be a ``site-packages`` directory. This is + usually ``dist.location``, except for legacy develop-installed packages, + where ``dist.location`` is the source code location, and this is where + the ``.egg-link`` file is. + + The returned location is normalized (in particular, with symlinks removed). + """ raise NotImplementedError() @property - def version(self): - # type: () -> DistributionVersion + def info_location(self) -> Optional[str]: + """Location of the .[egg|dist]-info directory or file. + + Similarly to ``location``, a string value is not necessarily a + filesystem path. ``None`` means the distribution is created in-memory. + + For a modern .dist-info installation on disk, this should be something + like ``{location}/{raw_name}-{version}.dist-info``. + + Do not canonicalize this value with e.g. ``pathlib.Path.resolve()``. If + this is a symbolic link, we want to preserve the relative path between + it and other files in the distribution. + """ raise NotImplementedError() @property - def installer(self): - # type: () -> str + def installed_by_distutils(self) -> bool: + """Whether this distribution is installed with legacy distutils format. + + A distribution installed with "raw" distutils not patched by setuptools + uses one single file at ``info_location`` to store metadata. We need to + treat this specially on uninstallation. + """ + info_location = self.info_location + if not info_location: + return False + return pathlib.Path(info_location).is_file() + + @property + def installed_as_egg(self) -> bool: + """Whether this distribution is installed as an egg. + + This usually indicates the distribution was installed by (older versions + of) easy_install. + """ + location = self.location + if not location: + return False + return location.endswith(".egg") + + @property + def installed_with_setuptools_egg_info(self) -> bool: + """Whether this distribution is installed with the ``.egg-info`` format. + + This usually indicates the distribution was installed with setuptools + with an old pip version or with ``single-version-externally-managed``. + + Note that this ensure the metadata store is a directory. distutils can + also installs an ``.egg-info``, but as a file, not a directory. This + property is *False* for that case. Also see ``installed_by_distutils``. + """ + info_location = self.info_location + if not info_location: + return False + if not info_location.endswith(".egg-info"): + return False + return pathlib.Path(info_location).is_dir() + + @property + def installed_with_dist_info(self) -> bool: + """Whether this distribution is installed with the "modern format". + + This indicates a "modern" installation, e.g. storing metadata in the + ``.dist-info`` directory. This applies to installations made by + setuptools (but through pip, not directly), or anything using the + standardized build backend interface (PEP 517). + """ + info_location = self.info_location + if not info_location: + return False + if not info_location.endswith(".dist-info"): + return False + return pathlib.Path(info_location).is_dir() + + @property + def canonical_name(self) -> NormalizedName: raise NotImplementedError() @property - def editable(self): - # type: () -> bool + def version(self) -> DistributionVersion: raise NotImplementedError() @property - def local(self): - # type: () -> bool + def setuptools_filename(self) -> str: + """Convert a project name to its setuptools-compatible filename. + + This is a copy of ``pkg_resources.to_filename()`` for compatibility. + """ + return self.raw_name.replace("-", "_") + + @property + def direct_url(self) -> Optional[DirectUrl]: + """Obtain a DirectUrl from this distribution. + + Returns None if the distribution has no `direct_url.json` metadata, + or if `direct_url.json` is invalid. + """ + try: + content = self.read_text(DIRECT_URL_METADATA_NAME) + except FileNotFoundError: + return None + try: + return DirectUrl.from_json(content) + except ( + UnicodeDecodeError, + json.JSONDecodeError, + DirectUrlValidationError, + ) as e: + logger.warning( + "Error parsing %s for %s: %s", + DIRECT_URL_METADATA_NAME, + self.canonical_name, + e, + ) + return None + + @property + def installer(self) -> str: + try: + installer_text = self.read_text("INSTALLER") + except (OSError, ValueError, NoneMetadataError): + return "" # Fail silently if the installer file cannot be read. + for line in installer_text.splitlines(): + cleaned_line = line.strip() + if cleaned_line: + return cleaned_line + return "" + + @property + def requested(self) -> bool: + return self.is_file("REQUESTED") + + @property + def editable(self) -> bool: + return bool(self.editable_project_location) + + @property + def local(self) -> bool: + """If distribution is installed in the current virtual environment. + + Always True if we're not in a virtualenv. + """ + if self.installed_location is None: + return False + return is_local(self.installed_location) + + @property + def in_usersite(self) -> bool: + if self.installed_location is None or user_site is None: + return False + return self.installed_location.startswith(normalize_path(user_site)) + + @property + def in_site_packages(self) -> bool: + if self.installed_location is None or site_packages is None: + return False + return self.installed_location.startswith(normalize_path(site_packages)) + + def is_file(self, path: InfoPath) -> bool: + """Check whether an entry in the info directory is a file.""" + raise NotImplementedError() + + def iter_distutils_script_names(self) -> Iterator[str]: + """Find distutils 'scripts' entries metadata. + + If 'scripts' is supplied in ``setup.py``, distutils records those in the + installed distribution's ``scripts`` directory, a file for each script. + """ + raise NotImplementedError() + + def read_text(self, path: InfoPath) -> str: + """Read a file in the info directory. + + :raise FileNotFoundError: If ``path`` does not exist in the directory. + :raise NoneMetadataError: If ``path`` exists in the info directory, but + cannot be read. + """ + raise NotImplementedError() + + def iter_entry_points(self) -> Iterable[BaseEntryPoint]: + raise NotImplementedError() + + def _metadata_impl(self) -> email.message.Message: raise NotImplementedError() + @functools.lru_cache(maxsize=1) + def _metadata_cached(self) -> email.message.Message: + # When we drop python 3.7 support, move this to the metadata property and use + # functools.cached_property instead of lru_cache. + metadata = self._metadata_impl() + self._add_egg_info_requires(metadata) + return metadata + + @property + def metadata(self) -> email.message.Message: + """Metadata of distribution parsed from e.g. METADATA or PKG-INFO. + + This should return an empty message if the metadata file is unavailable. + + :raises NoneMetadataError: If the metadata file is available, but does + not contain valid metadata. + """ + return self._metadata_cached() + + @property + def metadata_dict(self) -> Dict[str, Any]: + """PEP 566 compliant JSON-serializable representation of METADATA or PKG-INFO. + + This should return an empty dict if the metadata file is unavailable. + + :raises NoneMetadataError: If the metadata file is available, but does + not contain valid metadata. + """ + return msg_to_json(self.metadata) + + @property + def metadata_version(self) -> Optional[str]: + """Value of "Metadata-Version:" in distribution metadata, if available.""" + return self.metadata.get("Metadata-Version") + + @property + def raw_name(self) -> str: + """Value of "Name:" in distribution metadata.""" + # The metadata should NEVER be missing the Name: key, but if it somehow + # does, fall back to the known canonical name. + return self.metadata.get("Name", self.canonical_name) + @property - def in_usersite(self): - # type: () -> bool + def requires_python(self) -> SpecifierSet: + """Value of "Requires-Python:" in distribution metadata. + + If the key does not exist or contains an invalid value, an empty + SpecifierSet should be returned. + """ + value = self.metadata.get("Requires-Python") + if value is None: + return SpecifierSet() + try: + # Convert to str to satisfy the type checker; this can be a Header object. + spec = SpecifierSet(str(value)) + except InvalidSpecifier as e: + message = "Package %r has an invalid Requires-Python: %s" + logger.warning(message, self.raw_name, e) + return SpecifierSet() + return spec + + def iter_dependencies(self, extras: Collection[str] = ()) -> Iterable[Requirement]: + """Dependencies of this distribution. + + For modern .dist-info distributions, this is the collection of + "Requires-Dist:" entries in distribution metadata. + """ + raise NotImplementedError() + + def iter_provided_extras(self) -> Iterable[str]: + """Extras provided by this distribution. + + For modern .dist-info distributions, this is the collection of + "Provides-Extra:" entries in distribution metadata. + """ raise NotImplementedError() + def _iter_declared_entries_from_record(self) -> Optional[Iterator[str]]: + try: + text = self.read_text("RECORD") + except FileNotFoundError: + return None + # This extra Path-str cast normalizes entries. + return (str(pathlib.Path(row[0])) for row in csv.reader(text.splitlines())) + + def _iter_declared_entries_from_legacy(self) -> Optional[Iterator[str]]: + try: + text = self.read_text("installed-files.txt") + except FileNotFoundError: + return None + paths = (p for p in text.splitlines(keepends=False) if p) + root = self.location + info = self.info_location + if root is None or info is None: + return paths + try: + info_rel = pathlib.Path(info).relative_to(root) + except ValueError: # info is not relative to root. + return paths + if not info_rel.parts: # info *is* root. + return paths + return ( + _convert_installed_files_path(pathlib.Path(p).parts, info_rel.parts) + for p in paths + ) + + def iter_declared_entries(self) -> Optional[Iterator[str]]: + """Iterate through file entries declared in this distribution. + + For modern .dist-info distributions, this is the files listed in the + ``RECORD`` metadata file. For legacy setuptools distributions, this + comes from ``installed-files.txt``, with entries normalized to be + compatible with the format used by ``RECORD``. + + :return: An iterator for listed entries, or None if the distribution + contains neither ``RECORD`` nor ``installed-files.txt``. + """ + return ( + self._iter_declared_entries_from_record() + or self._iter_declared_entries_from_legacy() + ) + + def _iter_requires_txt_entries(self) -> Iterator[RequiresEntry]: + """Parse a ``requires.txt`` in an egg-info directory. + + This is an INI-ish format where an egg-info stores dependencies. A + section name describes extra other environment markers, while each entry + is an arbitrary string (not a key-value pair) representing a dependency + as a requirement string (no markers). + + There is a construct in ``importlib.metadata`` called ``Sectioned`` that + does mostly the same, but the format is currently considered private. + """ + try: + content = self.read_text("requires.txt") + except FileNotFoundError: + return + extra = marker = "" # Section-less entries don't have markers. + for line in content.splitlines(): + line = line.strip() + if not line or line.startswith("#"): # Comment; ignored. + continue + if line.startswith("[") and line.endswith("]"): # A section header. + extra, _, marker = line.strip("[]").partition(":") + continue + yield RequiresEntry(requirement=line, extra=extra, marker=marker) + + def _iter_egg_info_extras(self) -> Iterable[str]: + """Get extras from the egg-info directory.""" + known_extras = {""} + for entry in self._iter_requires_txt_entries(): + if entry.extra in known_extras: + continue + known_extras.add(entry.extra) + yield entry.extra + + def _iter_egg_info_dependencies(self) -> Iterable[str]: + """Get distribution dependencies from the egg-info directory. + + To ease parsing, this converts a legacy dependency entry into a PEP 508 + requirement string. Like ``_iter_requires_txt_entries()``, there is code + in ``importlib.metadata`` that does mostly the same, but not do exactly + what we need. + + Namely, ``importlib.metadata`` does not normalize the extra name before + putting it into the requirement string, which causes marker comparison + to fail because the dist-info format do normalize. This is consistent in + all currently available PEP 517 backends, although not standardized. + """ + for entry in self._iter_requires_txt_entries(): + if entry.extra and entry.marker: + marker = f'({entry.marker}) and extra == "{safe_extra(entry.extra)}"' + elif entry.extra: + marker = f'extra == "{safe_extra(entry.extra)}"' + elif entry.marker: + marker = entry.marker + else: + marker = "" + if marker: + yield f"{entry.requirement} ; {marker}" + else: + yield entry.requirement + + def _add_egg_info_requires(self, metadata: email.message.Message) -> None: + """Add egg-info requires.txt information to the metadata.""" + if not metadata.get_all("Requires-Dist"): + for dep in self._iter_egg_info_dependencies(): + metadata["Requires-Dist"] = dep + if not metadata.get_all("Provides-Extra"): + for extra in self._iter_egg_info_extras(): + metadata["Provides-Extra"] = extra + class BaseEnvironment: """An environment containing distributions to introspect.""" @classmethod - def default(cls): - # type: () -> BaseEnvironment + def default(cls) -> "BaseEnvironment": raise NotImplementedError() @classmethod - def from_paths(cls, paths): - # type: (Optional[List[str]]) -> BaseEnvironment + def from_paths(cls, paths: Optional[List[str]]) -> "BaseEnvironment": raise NotImplementedError() - def get_distribution(self, name): - # type: (str) -> Optional[BaseDistribution] - """Given a requirement name, return the installed distributions.""" + def get_distribution(self, name: str) -> Optional["BaseDistribution"]: + """Given a requirement name, return the installed distributions. + + The name may not be normalized. The implementation must canonicalize + it for lookup. + """ raise NotImplementedError() - def _iter_distributions(self): - # type: () -> Iterator[BaseDistribution] + def _iter_distributions(self) -> Iterator["BaseDistribution"]: """Iterate through installed distributions. This function should be implemented by subclass, but never called @@ -88,9 +607,8 @@ class BaseEnvironment: """ raise NotImplementedError() - def iter_distributions(self): - # type: () -> Iterator[BaseDistribution] - """Iterate through installed distributions.""" + def iter_all_distributions(self) -> Iterator[BaseDistribution]: + """Iterate through all installed distributions without any filtering.""" for dist in self._iter_distributions(): # Make sure the distribution actually comes from a valid Python # packaging distribution. Pip's AdjacentTempDirectory leaves folders @@ -112,15 +630,19 @@ class BaseEnvironment: def iter_installed_distributions( self, - local_only=True, # type: bool - skip=stdlib_pkgs, # type: Container[str] - include_editables=True, # type: bool - editables_only=False, # type: bool - user_only=False, # type: bool - ): - # type: (...) -> Iterator[BaseDistribution] + local_only: bool = True, + skip: Container[str] = stdlib_pkgs, + include_editables: bool = True, + editables_only: bool = False, + user_only: bool = False, + ) -> Iterator[BaseDistribution]: """Return a list of installed distributions. + This is based on ``iter_all_distributions()`` with additional filtering + options. Note that ``iter_installed_distributions()`` without arguments + is *not* equal to ``iter_all_distributions()``, since some of the + configurations exclude packages by default. + :param local_only: If True (default), only return installations local to the current virtualenv, if in a virtualenv. :param skip: An iterable of canonicalized project names to ignore; @@ -130,7 +652,7 @@ class BaseEnvironment: :param user_only: If True, only report installations in the user site directory. """ - it = self.iter_distributions() + it = self.iter_all_distributions() if local_only: it = (d for d in it if d.local) if not include_editables: @@ -140,3 +662,27 @@ class BaseEnvironment: if user_only: it = (d for d in it if d.in_usersite) return (d for d in it if d.canonical_name not in skip) + + +class Wheel(Protocol): + location: str + + def as_zipfile(self) -> zipfile.ZipFile: + raise NotImplementedError() + + +class FilesystemWheel(Wheel): + def __init__(self, location: str) -> None: + self.location = location + + def as_zipfile(self) -> zipfile.ZipFile: + return zipfile.ZipFile(self.location, allowZip64=True) + + +class MemoryWheel(Wheel): + def __init__(self, location: str, stream: IO[bytes]) -> None: + self.location = location + self.stream = stream + + def as_zipfile(self) -> zipfile.ZipFile: + return zipfile.ZipFile(self.stream, allowZip64=True) diff --git a/env/Lib/site-packages/pip/_internal/metadata/pkg_resources.py b/env/Lib/site-packages/pip/_internal/metadata/pkg_resources.py index f39a39eb..f330ef12 100644 --- a/env/Lib/site-packages/pip/_internal/metadata/pkg_resources.py +++ b/env/Lib/site-packages/pip/_internal/metadata/pkg_resources.py @@ -1,104 +1,253 @@ +import email.message +import email.parser +import logging +import os import zipfile -from typing import Iterator, List, Optional +from typing import Collection, Iterable, Iterator, List, Mapping, NamedTuple, Optional from pip._vendor import pkg_resources -from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.packaging.requirements import Requirement +from pip._vendor.packaging.utils import NormalizedName, canonicalize_name from pip._vendor.packaging.version import parse as parse_version -from pip._internal.utils import misc # TODO: Move definition here. -from pip._internal.utils.packaging import get_installer -from pip._internal.utils.wheel import pkg_resources_distribution_for_wheel +from pip._internal.exceptions import InvalidWheel, NoneMetadataError, UnsupportedWheel +from pip._internal.utils.egg_link import egg_link_path_from_location +from pip._internal.utils.misc import display_path, normalize_path +from pip._internal.utils.wheel import parse_wheel, read_wheel_metadata_file -from .base import BaseDistribution, BaseEnvironment, DistributionVersion +from .base import ( + BaseDistribution, + BaseEntryPoint, + BaseEnvironment, + DistributionVersion, + InfoPath, + Wheel, +) + +logger = logging.getLogger(__name__) + + +class EntryPoint(NamedTuple): + name: str + value: str + group: str + + +class InMemoryMetadata: + """IMetadataProvider that reads metadata files from a dictionary. + + This also maps metadata decoding exceptions to our internal exception type. + """ + + def __init__(self, metadata: Mapping[str, bytes], wheel_name: str) -> None: + self._metadata = metadata + self._wheel_name = wheel_name + + def has_metadata(self, name: str) -> bool: + return name in self._metadata + + def get_metadata(self, name: str) -> str: + try: + return self._metadata[name].decode() + except UnicodeDecodeError as e: + # Augment the default error with the origin of the file. + raise UnsupportedWheel( + f"Error decoding metadata for {self._wheel_name}: {e} in {name} file" + ) + + def get_metadata_lines(self, name: str) -> Iterable[str]: + return pkg_resources.yield_lines(self.get_metadata(name)) + + def metadata_isdir(self, name: str) -> bool: + return False + + def metadata_listdir(self, name: str) -> List[str]: + return [] + + def run_script(self, script_name: str, namespace: str) -> None: + pass class Distribution(BaseDistribution): - def __init__(self, dist): - # type: (pkg_resources.Distribution) -> None + def __init__(self, dist: pkg_resources.Distribution) -> None: self._dist = dist @classmethod - def from_wheel(cls, path, name): - # type: (str, str) -> Distribution - with zipfile.ZipFile(path, allowZip64=True) as zf: - dist = pkg_resources_distribution_for_wheel(zf, name, path) + def from_directory(cls, directory: str) -> BaseDistribution: + dist_dir = directory.rstrip(os.sep) + + # Build a PathMetadata object, from path to metadata. :wink: + base_dir, dist_dir_name = os.path.split(dist_dir) + metadata = pkg_resources.PathMetadata(base_dir, dist_dir) + + # Determine the correct Distribution object type. + if dist_dir.endswith(".egg-info"): + dist_cls = pkg_resources.Distribution + dist_name = os.path.splitext(dist_dir_name)[0] + else: + assert dist_dir.endswith(".dist-info") + dist_cls = pkg_resources.DistInfoDistribution + dist_name = os.path.splitext(dist_dir_name)[0].split("-")[0] + + dist = dist_cls(base_dir, project_name=dist_name, metadata=metadata) + return cls(dist) + + @classmethod + def from_metadata_file_contents( + cls, + metadata_contents: bytes, + filename: str, + project_name: str, + ) -> BaseDistribution: + metadata_dict = { + "METADATA": metadata_contents, + } + dist = pkg_resources.DistInfoDistribution( + location=filename, + metadata=InMemoryMetadata(metadata_dict, filename), + project_name=project_name, + ) + return cls(dist) + + @classmethod + def from_wheel(cls, wheel: Wheel, name: str) -> BaseDistribution: + try: + with wheel.as_zipfile() as zf: + info_dir, _ = parse_wheel(zf, name) + metadata_dict = { + path.split("/", 1)[-1]: read_wheel_metadata_file(zf, path) + for path in zf.namelist() + if path.startswith(f"{info_dir}/") + } + except zipfile.BadZipFile as e: + raise InvalidWheel(wheel.location, name) from e + except UnsupportedWheel as e: + raise UnsupportedWheel(f"{name} has an invalid wheel, {e}") + dist = pkg_resources.DistInfoDistribution( + location=wheel.location, + metadata=InMemoryMetadata(metadata_dict, wheel.location), + project_name=name, + ) return cls(dist) @property - def location(self): - # type: () -> Optional[str] + def location(self) -> Optional[str]: return self._dist.location @property - def metadata_version(self): - # type: () -> Optional[str] - for line in self._dist.get_metadata_lines(self._dist.PKG_INFO): - if line.lower().startswith("metadata-version:"): - return line.split(":", 1)[-1].strip() - return None + def installed_location(self) -> Optional[str]: + egg_link = egg_link_path_from_location(self.raw_name) + if egg_link: + location = egg_link + elif self.location: + location = self.location + else: + return None + return normalize_path(location) @property - def canonical_name(self): - # type: () -> str - return canonicalize_name(self._dist.project_name) + def info_location(self) -> Optional[str]: + return self._dist.egg_info @property - def version(self): - # type: () -> DistributionVersion - return parse_version(self._dist.version) + def installed_by_distutils(self) -> bool: + # A distutils-installed distribution is provided by FileMetadata. This + # provider has a "path" attribute not present anywhere else. Not the + # best introspection logic, but pip has been doing this for a long time. + try: + return bool(self._dist._provider.path) + except AttributeError: + return False @property - def installer(self): - # type: () -> str - return get_installer(self._dist) + def canonical_name(self) -> NormalizedName: + return canonicalize_name(self._dist.project_name) @property - def editable(self): - # type: () -> bool - return misc.dist_is_editable(self._dist) + def version(self) -> DistributionVersion: + return parse_version(self._dist.version) - @property - def local(self): - # type: () -> bool - return misc.dist_is_local(self._dist) + def is_file(self, path: InfoPath) -> bool: + return self._dist.has_metadata(str(path)) - @property - def in_usersite(self): - # type: () -> bool - return misc.dist_in_usersite(self._dist) + def iter_distutils_script_names(self) -> Iterator[str]: + yield from self._dist.metadata_listdir("scripts") + + def read_text(self, path: InfoPath) -> str: + name = str(path) + if not self._dist.has_metadata(name): + raise FileNotFoundError(name) + content = self._dist.get_metadata(name) + if content is None: + raise NoneMetadataError(self, name) + return content + + def iter_entry_points(self) -> Iterable[BaseEntryPoint]: + for group, entries in self._dist.get_entry_map().items(): + for name, entry_point in entries.items(): + name, _, value = str(entry_point).partition("=") + yield EntryPoint(name=name.strip(), value=value.strip(), group=group) + + def _metadata_impl(self) -> email.message.Message: + """ + :raises NoneMetadataError: if the distribution reports `has_metadata()` + True but `get_metadata()` returns None. + """ + if isinstance(self._dist, pkg_resources.DistInfoDistribution): + metadata_name = "METADATA" + else: + metadata_name = "PKG-INFO" + try: + metadata = self.read_text(metadata_name) + except FileNotFoundError: + if self.location: + displaying_path = display_path(self.location) + else: + displaying_path = repr(self.location) + logger.warning("No metadata found in %s", displaying_path) + metadata = "" + feed_parser = email.parser.FeedParser() + feed_parser.feed(metadata) + return feed_parser.close() + + def iter_dependencies(self, extras: Collection[str] = ()) -> Iterable[Requirement]: + if extras: # pkg_resources raises on invalid extras, so we sanitize. + extras = frozenset(extras).intersection(self._dist.extras) + return self._dist.requires(extras) + + def iter_provided_extras(self) -> Iterable[str]: + return self._dist.extras class Environment(BaseEnvironment): - def __init__(self, ws): - # type: (pkg_resources.WorkingSet) -> None + def __init__(self, ws: pkg_resources.WorkingSet) -> None: self._ws = ws @classmethod - def default(cls): - # type: () -> BaseEnvironment + def default(cls) -> BaseEnvironment: return cls(pkg_resources.working_set) @classmethod - def from_paths(cls, paths): - # type: (Optional[List[str]]) -> BaseEnvironment + def from_paths(cls, paths: Optional[List[str]]) -> BaseEnvironment: return cls(pkg_resources.WorkingSet(paths)) - def _search_distribution(self, name): - # type: (str) -> Optional[BaseDistribution] + def _iter_distributions(self) -> Iterator[BaseDistribution]: + for dist in self._ws: + yield Distribution(dist) + + def _search_distribution(self, name: str) -> Optional[BaseDistribution]: """Find a distribution matching the ``name`` in the environment. This searches from *all* distributions available in the environment, to match the behavior of ``pkg_resources.get_distribution()``. """ canonical_name = canonicalize_name(name) - for dist in self.iter_distributions(): + for dist in self.iter_all_distributions(): if dist.canonical_name == canonical_name: return dist return None - def get_distribution(self, name): - # type: (str) -> Optional[BaseDistribution] - + def get_distribution(self, name: str) -> Optional[BaseDistribution]: # Search the distribution by looking through the working set. dist = self._search_distribution(name) if dist: @@ -119,8 +268,3 @@ class Environment(BaseEnvironment): except pkg_resources.DistributionNotFound: return None return self._search_distribution(name) - - def _iter_distributions(self): - # type: () -> Iterator[BaseDistribution] - for dist in self._ws: - yield Distribution(dist) diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index dcf6e70dd4b33c0f8fc88f364e6993e5bd8bd334..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 288 zcmYe~<>g{vU|^UdaWK`Mfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}U_92E)@ zld}`kQx!@w5=#`4^Ycm)GxLfSa`RJCbBZB?MX3cvsl};zB?_r|C7C6esl|F+ewvK8 z*yH0<@{{A^S27eaF)%=gUyaUIF`>n&Ma40xIVqV%G5&d}E=8GTsS3IZp?;oWu0g?` zA&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylB zsk%^i7RMB17U;)k=9Q!t<t66mLma9fAD@|*SrQ+wS5SG2!zMRBr8Fni4&>|4pkM$1 DLO@ik diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-39.pyc deleted file mode 100644 index cfafa5c29d3746c7b5bcc5e4e07212cdcae43d18..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1401 zcmYe~<>g{vU|^UdaWM5IGXuk85C<8vFfcGUFfcF_TQD#%q%fo~<}l<kMlmsh*i1Rh zxhzpEU^a6OYc5+98zX}|Lkdd@YYRgPYbskaa};|DTQGwr`%93SnvAzt3lfWpQ#BcH zvG`=>Wot6t67f#0bV@8vO>xf8El4a%_06ov%u5ETM#jug4%ii`3{i|J3{gxej8V+# z3@J>D7^7I)8PXV2m{V9<IHFinSX0<q7^2ux*i$%K7^2wQ8CV#iID#28Id6%2<`tJD z=Hw)nWaj5NC+4MOrX-f6R#^t678Ioxr{<LuD<mou<d>x8m1HL7C@3Yvlqe~r<rgVr zBI(xSQczG(&}6>Fl9!m9dW*d*wWv5VKkpVxPG(+qGAP)fZe{?nK^WwTVlxH?h8o5i zhIob&#u}z(5R0jXxrQO0xrC*eA&a$!A&a4gA&aSoA&WVUxr8l+u@@ZJ!3>&Aews|T zn6pzWZ}Fw1re)@3=B39c=Oh*vYqA%yF)%RP;spn8Jk%vc><kPHMI0ar*5cBF)S_D) z@$s2?nI-Y@MXU@A44N#rSc+3~(!hEVidQn;;*5uw8y~-t;a8KhRZM7cYEf}aYEDXK zQH+0Hs!LI3S*n7rLa3i-m}^k5XNY64f~TL0zn^Qcr(;a8tFLQth-;97Sxi8HPfVhT zZccuBW^qYoc1&tsS&UC+QcQ7XNvdu^Vsdt3dTMb@L1uw|d}dxrYEfQdj(%=_N@`BA zK0M_03Mz|u85kHqxR?(Vrc7*%T#Rf?Y>a%2O#iCnutupK%&W<aAT3Y~VuQTy3`)=< zpajjh02JDcun=F!3=ZciO&hGHYE&y0)#@l9NKLzyEVtOw@{4j4OEAK*2;|x#K~OA! z2_aBaaKy(Kr4|&$$4h|R0E#vSCKg7X|G51DQBIye6hTf^fQO}m1~hFbRM#pbmMB!$ zY8DBD+$Rbmz>WkHV3)GT#}}6r#mCE`IaC&F(C9%`YjT2;87ND{$KT?LkI&6dDa}cZ zkH5teA75CSm;;qzkB?8uPmYfVrM2Rm{F37McyKHiiGf@q4hkt=Xevxj&B=+6M+!%N zkP?s+!O0ku%8Nl|7zZN@GY1n7HwPP7+)tAuO12=gKrg;5H7_N<NDq?UGV{{)pn*`t z1Tu&lWS1mZAuJ8*LDHZeC?^+za_ucCRQb}9%$#DVsv=O<2HS|_L_{cZ*g!(S4wUwa NLGjJQ#KXwL3;=^kWbyz2 diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-39.pyc deleted file mode 100644 index b9a0186dc4d74627482e3280c892f7ab28f87fa7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6314 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 diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/format_control.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/format_control.cpython-39.pyc deleted file mode 100644 index 042aa0e879b593edd2b294db2605eabf3e41cd6d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2558 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 Z13By#hYiI4cA$)13<^aNCLSgpW&pv|aSs3h diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-39.pyc deleted file mode 100644 index 4c259d1af5dadcee851e9537a750d766df23152f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1211 zcmYe~<>g{vU|^UdaWK_|g@NHQh=Yt-7#J8F7#J9ejTjghQW#Pga~Pr+-5FAtQkYv9 zQka{WqL@;dQdm-0Q`mZ$qL@>eQrJ^Cz-*Qj#$X0b&X*w5{E|T=GG>NyiVYYT7*ZLc z7*iOcm{J&{n9~_jm=-Zcv9vR!F{Uu5u(WVQv4Tu*VTfXDXJBE7Vh?7}WWU7|keHmE zn4apHmy%jh<sOt;P?TDnnpaY+kf;EaQUJ>-B<7_k6cpu`Wu~MSE2JhCXQmb@Bqk@P z78fg&<SV4+r4;06=9Lt4DJUo?XtLg7E-lKr#g>;^l9Qi&i>o*@w;(4q9wf$5P+5=( zW(lWd=A_0Km*f{Erl-cI<mV=4<|V^C1o9V%4a3Dw3=9k<49yG+7#A`yGSo2EFvK&J zFlVtWV69<X$e6`e!w}C_!?1uog>fNBjswhQ0<$@5m}(f}xl$N{88n&wZm~gJbBhJ! z5>4(~ti`1TsYSOq;^Q;(GE3s)i$HeXVk<4m$;nK*#afV9RGfN?qqHcexF9F9qzDw1 zw|GH5h)>HeiZ4hk$tYrFU|=X>0}<>D3=Epgw^)i(bJD;D6@f%nGT!2hk5A4?EG~|Z zU&-*R&e<v^v^ce>I3_hGC9^2TKQGm#D6=e8L02Kv&oj(5DA+T^F<8OV&&A)*HQ3WJ zCfL>2H8{jINWm;7AiyUk(L^^VKRvU!Br`iEHLonjCo?IgII|>Gw*V5I#W4k$1^V%s zc_pbud5Jmtx%nxnImP;!pjg%`s4U`UU|;~@VjfU9GjTDpF$ys9F!Hcgi9%x?9O-(n zAW3Edse@t=8x#o6p!6&Nj+QLO1xz&zS<E$z3z>o$G#ULgS&BeL7x6MMFx+A<Ey~Ht z&&&gdhbB`INY5=6aKH(J!VFA^fLQzt3=9$=V?lN>FjYyRx~8-!2Oj2{9H1D>OUzA; zkH5tgAD^3_Qknx|^Tfv&mL}#vW!U56Q}UDJ<3ZtHoReQt93Kz%eG$m2TfERnNlwkl ziH|P=I|NJ!f?NZ3638VW-xhN)Ffed1vM_Tn^Y9jdM5_cdN=gcft@QOl2}v)%C|$ow z43wse^$IFWGV=2>@{3DSQ$P}$jNoKYB?i+`l3HA%htMVs;_Kqj%X*6kk{0#ANf8pT zAP3xH38)P4yu}fcT3iBRA-Nyy36T45ao9jY#*Psbu6!U*F!M<=F|zz;V+N4`*6uyV diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/link.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/link.cpython-39.pyc deleted file mode 100644 index 05cb7364d3452159544d3bf6f73ba5f3edb1c51a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7215 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 Tk%v))l?OZm!ow_3&yWNF;FOZq diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-39.pyc deleted file mode 100644 index 8b62e151b755803d9720ca204d857e1b6aac09c2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 966 zcmYe~<>g{vU|^UdaWIvMnStRkh=Yuo85kHG7#J9e<ro+kQW&Bb(iu`17coXLx-+CO zr7*WJq%b!#MKPtY1T$!|R_)?)%P&$WsVqn>R!A%^&QH!vEJ;mKD9<d(P{_<HE=kPE zNi50C&r>K)&PdHoE!N`#Ye-Z`Pt8j$O3YEnFH0>d%S<g-$WK#9EKAJHNleN~g{f9Z z%u7)y$w<vCQb^9vD@m;=(NQQ)P36icDJdwn($`PPPcGIgs4U6I&(q5<O4m2mhuW#1 znU|7Up_fsTo1>hVQ<7Sgmspaj3zY;rNRMkJ>n-+zoWzox%%ofF1*Ju)U`9r2VoGXJ z@h$e^<f6=ilHyw|DTyVC$;crDVl%-)Nrr)eA(bJDF@+(DDTOhLIh7@f6%tNSY>+Uz z#TE?qdsT^}0)(ZIk)M-NtWc0xl2NQso{^cHp^#XVs!&>-nxc?c4Dzr-QettcLP};) zYH~?_QD$nfLRx+imx6+VLSj)#W?Eu$31)C7Dg=N-LZKirIXf{uRS&E_nGNJzC<d`X zE_VjSuMz_TLk(jMLp(zbQw>8rV-0f+Lp)OrOASLja}8?^Lp)0gLokCTqhApt0|SF5 z+bx#j)SR>;kp3c2A}L~FU|=X>1rZ=~S27fFGB7aws&}@E2`x@7Dvn9bNy#jV@y|<j zDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-24N@?R2?+3sNi@;T$xqKL zF3HS}NzE&Z@ySezDb6fO)rESiIHn-8KtDb+4;-sG`nmZjsX4{^ko2WjP<e|ZK0Y%q zvm`!V801TEV&`CEgup6(NDSz~)c9$#gEZtN=BCES-{Ojo&&^LM%>l7_;^PZT6LX+4 z?D6p_`N{F|x446yJzRZV<Go!YgKu%h#~0`1mlVgx7jc8affJPg*<HlWz`(!*atSDq uI2c)2SeU?Kewxfh{2=uLAOfTc9DYayNc$}g8;FbSK#@=k3UU?>4rTz^N(K-B diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-39.pyc deleted file mode 100644 index 980cbaa7b8aded7542d6bd21504ca764aa9dd1d7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3367 zcmYe~<>g{vU|^UdaWIuth=JiTh=Yuo85kHG7#J9eTNoG^QW#Pga~Pr^G-DJan9mf& z1g4pzn87ql6l)4Y3R4bSE_)O^BS<ZC4o5C$6epO?lEanD9mNf1v*z&R@<#E3*=#v{ zx%^T5xdKrFj0~xa3j|Yz7BWT&yECM)r*O0|q;NDdMTw*^1~X`Kz680?Pm}Q$i%({8 zi6-MM!Q{le{JhNM#GK5k)cCx_+*FWcKxKfZCgUykjKt#jlAK~qrdxb@`9--9MFoi^ z8Mj1=Qd1I>OX3qtOETiqit=;gON(-nL8c>PcnH`qFfgPtfP5Xrl)@OroWhjCoX!-* zlFFLGlET`;(99Ucmco|8-og;Yp2CsB*}@RTk;0Y2-NF#XnZgsypvilSJ2*A5C^;iI zIlmya%8g4wK|#SaFFCQGxHKoRB(+$fBqLQJCqFr{Br`t`#7ituD99{O$ShV!&d*EB zOfM};O;ISxS11M>qX#zN7FSwkUP^pUW?pvjEw0SGl++54KZ=t<4u^S!oq>UYg@J*= z85EUG3=9nE47JQPj4lkZ2DL0TEDIP?7#A`Y>6I|nurxE)vX(GqF)v`LVFiiRu-3BF zFfU-OVOhw?$WX{p!q&`CTvo!qfTM<~hIt{A3q!0%ElUY!7S{r9keXVy8n!H+6sByZ zBA*i81$-&YAbpGsg=K|4H4HV(HB2ciy-dLjnygiUU=M&o!MP|ku_RR?Q2{A{6!Md@ zQj<#*64OdjixgmSmzkFi4yFWzuM;2v0W#+oW8E#*jFOUq;;Kx{kSotD$v_X^qSV6D z%%W6<5T9WE;9wseg^c|2)UwnfuqDOCISRS?DWy573YmEd0hJ{g`FWt&$jdKLNGwat z%t=hjN!44)RK&@^z)%FrNt*n(xQa^>i%N<?mKCuvFfiO=$}hgf0#0#ksTG;UCB?Vc z5(^4a^HPdfLDHO=C8<Rv`T04;w^)-i5;OB|v6U9(<YXq@Vl7B4Do(w{QCgG(VX+k_ zXQbw)-eSwiPft%Ry2W0eSd^EUm#)cvi#a)`7~zat0!gKrIVJIkK)S^ON+Gv6@>0ve zY2_9h*vOQX3`GhI3=F?oovmU*i&Kk=V^VWcGK*sT^HN=kGRsmGbQMDVJi}arf;~eV zgB3jeT>Sl9gFPK%f?a)GgF{?{6wG1*0(@c;O>}ee(=&@pGP7e+^U7j;GLvG8GfPr+ z3lfvF6Vp?RV+t}0^y4%0N>YpR5_9x(^HWlDiuEBWIleeKzaUkwpz;=5GB_njg3_rP zDE0EQFmf<*F>)~SFtRZ6u&^--F!C^RF|sf+{byliV`5@tVr2SPC4`i2^dLr{q<>Ie zV1lK80R{$!8paxic!nCL8ishr6oz1im5hExybKHsn#{LYic@pa5J3qJ9tfcbiY|`$ z_{_Y_lK6NhkQ+gnih+%du}TEl1u!Maj36&SF(@r?z}&D5k_Q>n8ETno7_u0ON<d@@ zV-{07V>UB{=fV(cRm)t$T*KVVSj$qvlEu1!4V=SRYgn_`i-T%dvp9-_N;nsAr7+g8 zEM#J2s9}QSK}Lo`r5eTs+$l^8cv6@b@YXObWCTG*h8l(}zM?r`ITnaq3Tp~m3s~HR zp&6_SlwVWW7x30FE(8_09DY?+AsL_?kdj)VP+F9uprl%?q)?oinp>=pnOByWlbNEU zP>_?FSe&X*P?TSmnF7kmkff?tCFYZ#pAE{jnRyD}(kZprN};;8ib+SIN(4y`lsv&Q zD1iowG*ILfg92L&6mbl(e6@@v3^k0+jA0Cn424Xf=qpkN#T{c2sGM8Lbc;#P;1+Xf zQ4S>9K<T>(9Cw^H>8W|C6$M3h86fjOhO;nMnIT7AdTL308mOKqDM?L<hZn|rHXvqB zv7H{=h+B+Yn*88QUj#}8x44Qka|?1(L4_~a9Yvy`LILDva1Jgm$jK}zk^m(kw!GAm zoc!b>P%1By0;v)L3q$O^#gdhunFmgQnruZXAQ{%2%)Hd%Tf&eED>Wq^9FQQJii<Qr z3WP9aZm|?#2?22&{__TfhYl#EGO;kSFp4m8F>x^Su!AxkD1))E@Gx;Oa{OmwW@BVw z<YQ#{&+(syrAnEIkV^)IGRR;M2C+fW3Btvocxh)$V@zR8VQS&%WN2qdV@zRAVQJw2 z<poe`1lJOqf>KLLi@^0Ea_yLwUz(SqP?njf0Lrg=h!EjI)G8UN$=Su=lDxDi2i!7H z$j<}wa}zW36g1K@i;7D?MLW3S1+^w1NmL;*F9mK&X>qDTNk(QdDCtAYD9Hz<^OVx$ zRE5Nx97K%**MgCRLFrN$6vTQA3=Aa<3m9t{Aa!gBYX>CPG1W5GFfL#N)x*VFHH;~Y z;tU{>U<OSlzh8{{n(VhY3-XIID?s%~kv=HRAd(krVQGFzY7r<<Z*ipNrGV=mO(sav zV9v=;)?~cJQ&5x-s!qW^faD8smf*|H28B&QWkDt=J(YqS$p?-q7DgsUzJDwnpu)Gx z20f+`;f*bmpc;x19H9IH4h|7;F<8S8%TvqP0nXDCnF?8gA$1bOm7rQcld;Ge<YiEb zf#hT^o1DzzlH~l{0=s4g28Pcd7gt%3=17DQnvCFltjPq<ZbeowyEK^~_JRe#!6gC8 zKiK@93ko=pzZf`p_^MQhafzQM*Da2CaD>Fi-{Ojo&jmL%;^S}e#K#wwCgy;evhne^ z*yH0<@{{A^Z*j)Q7w6=c6vxNk;!e&<EH2JXEy>7FDN+KtR~1B<fCxJf0S+nz0djm1 zsP+*Axf2w@984@M9864%TpApl97<q0P0=DytlVM;H7_#r(u?>(CYgZ>7#>KIL=W6( z0GDjH*h(r3K#D+l`j&J-W`SOOS!!NNevuxe%FoP8*DEc_%qfN>OewGmSpBaDssAC_ z7E*qqDFAEL1I2J+38bMUfocLoL2hPoGPs!qE^}{jrl*$pfE!0e_8`ZDi&&7qA&Ch! iKyGo^K!V&3R8JR!ifRr<802B%Vd7!rVH9BEVg>*-@rv;P diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-39.pyc deleted file mode 100644 index c6bc3292e8a33c9ecd1ff1f32ce95f22c0d04374..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1601 zcmYe~<>g{vU|^UdaWHi@I|IXG5C<7EGcYhXFfcF_YcVh|q%fo~<}l<kMlmvi*i1Q0 zxy(__j12A!Da<J>Eet6v%}h}&DXhT^nrtsYrf4$W;_xph$;{77%+X}L#p{+|l$%)M zoS#=xl%JCfQh|(FV0I}nFfgPtL@}l?L@}i>Mlq)|q%bXFjABV)Phm}AYhjFHO<@UU z(B!x!5}cZonhY{OpeQvhwJ0?&IkmVdg-by}LBTaIIkBL)G$*knwOFAfBUK?eF)t-E zC9xz`p%|u1p#Y&xAuYd1Atk>&FDE}SB{MG_Y)E2Wib7^yaY<rMPG(-ZLRw}{YOx+z zW+m$_p2VD-{POt9#Jud(lv|<@USdv8d_hraQEE<VVsUEmExt6cpW~Aup1#Eku`)g> zGcU2I@|IX;dR~4}YJ5>@VQFSjYH@r)Wl2VUo||7X8&c4K*h~xz49=jK&|_d=s9{ZE zEM+L-NnxsGtzoQTh-au_s$qy{tYNNUh-a!{sbPp`u3@cVh-XP*3}(<|PAq3)U~n!< z1^GTv0b8gk<R@jNCYR`Ofqe%GK&yhpqQqPUh_@h~v{DGqNG-`oErNuELT+MFc4~@3 zVzB~5UO^)>4;<FTsd>ezaFal$<)<kGxCSVgS{i98Bo?JA6r>jAW|owsrYMx;D<mPs zPBAzlpn(nvYmk1ZYfwYeO2JV9B~3wnp^#ss;Fq75s;3ZI46y+k{3uQWB??4R$WK!! z&Mz%WPE{yKOwLYBPc2r^SAfJ4LZmz+HBTWqKd-nnrv#QpK&}H}ka3xLDXA3-pj4BS znU@VsDj-Ry^HCxn5t=3W(3Gf<n5U4RlcJ-LR9d1?mY9<XVuDi&ipx_ni%S&p%TkLJ z5*6}N%V7=&31fs9_5_AvH$;g-W?piBZb4#6W>OAn+$jY?Q>ShKICUz4oK~7ztdN<f z0P&}SOKMtTX--KoC^p>^bBa?D?(lOfVr5`p&}6&CQk<HTRs>4SMeGa=3`HCuf)hl5 z3Zaz@MLY})48J;@tztrpQ;UjYQgc!=i(>rqQeBEN%Tg6|6+-<y!(4-cJwqIW6+Hc1 z{QX>mJso3$U431HLtKLt%whrpd}0z!baV34GmA?yvtv^8%3^#nlVXZ9OHy@V@fuT* zS)d=EnOBlpl$V&JpPQeOnp3O~PYIyxn^vq>P<e|ZK0Y%qvm`!V7?kh$Kp9e$gOP=a zjS&K?WU=KWJ(w;{7B@dPKTS4}IeCe>sqyi*xZ>k;^HWN5Ky04)_`=e}9H<O?e0)lN za(w(P&iMG^ocxmF`1m4_jo>grB6vZ;1u7{)!B`AZ!NJJF%E86J2!_9kKyrSXthd-o zDho36(u+Xl#x3Q7%mO{Qm-QfC)<exqMWC`CtR2ZZP>d9T?7YQc197<>BPcLHw(v0V GFarQ}2G1P; diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-39.pyc deleted file mode 100644 index 4f07b5657e4314610b53751575176d986ceb0970..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3298 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 diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/wheel.cpython-39.pyc deleted file mode 100644 index 269f3b7fa5ee1adc13f1fb969e28ed26d3f3f0d7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4213 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 V)Iu!=jWMt=b1;f9@i6f)0{|8gf;|8L diff --git a/env/Lib/site-packages/pip/_internal/models/candidate.py b/env/Lib/site-packages/pip/_internal/models/candidate.py index 3b91704a..a4963aec 100644 --- a/env/Lib/site-packages/pip/_internal/models/candidate.py +++ b/env/Lib/site-packages/pip/_internal/models/candidate.py @@ -5,30 +5,30 @@ from pip._internal.utils.models import KeyBasedCompareMixin class InstallationCandidate(KeyBasedCompareMixin): - """Represents a potential "candidate" for installation. - """ + """Represents a potential "candidate" for installation.""" __slots__ = ["name", "version", "link"] - def __init__(self, name, version, link): - # type: (str, str, Link) -> None + def __init__(self, name: str, version: str, link: Link) -> None: self.name = name self.version = parse_version(version) self.link = link super().__init__( key=(self.name, self.version, self.link), - defining_class=InstallationCandidate + defining_class=InstallationCandidate, ) - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return "<InstallationCandidate({!r}, {!r}, {!r})>".format( - self.name, self.version, self.link, + self.name, + self.version, + self.link, ) - def __str__(self): - # type: () -> str - return '{!r} candidate (version {} at {})'.format( - self.name, self.version, self.link, + def __str__(self) -> str: + return "{!r} candidate (version {} at {})".format( + self.name, + self.version, + self.link, ) diff --git a/env/Lib/site-packages/pip/_internal/models/direct_url.py b/env/Lib/site-packages/pip/_internal/models/direct_url.py index 345dbaf1..e219d738 100644 --- a/env/Lib/site-packages/pip/_internal/models/direct_url.py +++ b/env/Lib/site-packages/pip/_internal/models/direct_url.py @@ -22,8 +22,9 @@ class DirectUrlValidationError(Exception): pass -def _get(d, expected_type, key, default=None): - # type: (Dict[str, Any], Type[T], str, Optional[T]) -> Optional[T] +def _get( + d: Dict[str, Any], expected_type: Type[T], key: str, default: Optional[T] = None +) -> Optional[T]: """Get value from dictionary and verify expected type.""" if key not in d: return default @@ -37,16 +38,16 @@ def _get(d, expected_type, key, default=None): return value -def _get_required(d, expected_type, key, default=None): - # type: (Dict[str, Any], Type[T], str, Optional[T]) -> T +def _get_required( + d: Dict[str, Any], expected_type: Type[T], key: str, default: Optional[T] = None +) -> T: value = _get(d, expected_type, key, default) if value is None: raise DirectUrlValidationError(f"{key} must have a value") return value -def _exactly_one_of(infos): - # type: (Iterable[Optional[InfoType]]) -> InfoType +def _exactly_one_of(infos: Iterable[Optional["InfoType"]]) -> "InfoType": infos = [info for info in infos if info is not None] if not infos: raise DirectUrlValidationError( @@ -60,8 +61,7 @@ def _exactly_one_of(infos): return infos[0] -def _filter_none(**kwargs): - # type: (Any) -> Dict[str, Any] +def _filter_none(**kwargs: Any) -> Dict[str, Any]: """Make dict excluding None values.""" return {k: v for k, v in kwargs.items() if v is not None} @@ -71,39 +71,29 @@ class VcsInfo: def __init__( self, - vcs, # type: str - commit_id, # type: str - requested_revision=None, # type: Optional[str] - resolved_revision=None, # type: Optional[str] - resolved_revision_type=None, # type: Optional[str] - ): + vcs: str, + commit_id: str, + requested_revision: Optional[str] = None, + ) -> None: self.vcs = vcs self.requested_revision = requested_revision self.commit_id = commit_id - self.resolved_revision = resolved_revision - self.resolved_revision_type = resolved_revision_type @classmethod - def _from_dict(cls, d): - # type: (Optional[Dict[str, Any]]) -> Optional[VcsInfo] + def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["VcsInfo"]: if d is None: return None return cls( vcs=_get_required(d, str, "vcs"), commit_id=_get_required(d, str, "commit_id"), requested_revision=_get(d, str, "requested_revision"), - resolved_revision=_get(d, str, "resolved_revision"), - resolved_revision_type=_get(d, str, "resolved_revision_type"), ) - def _to_dict(self): - # type: () -> Dict[str, Any] + def _to_dict(self) -> Dict[str, Any]: return _filter_none( vcs=self.vcs, requested_revision=self.requested_revision, commit_id=self.commit_id, - resolved_revision=self.resolved_revision, - resolved_revision_type=self.resolved_revision_type, ) @@ -112,20 +102,43 @@ class ArchiveInfo: def __init__( self, - hash=None, # type: Optional[str] - ): + hash: Optional[str] = None, + hashes: Optional[Dict[str, str]] = None, + ) -> None: + # set hashes before hash, since the hash setter will further populate hashes + self.hashes = hashes self.hash = hash + @property + def hash(self) -> Optional[str]: + return self._hash + + @hash.setter + def hash(self, value: Optional[str]) -> None: + if value is not None: + # Auto-populate the hashes key to upgrade to the new format automatically. + # We don't back-populate the legacy hash key from hashes. + try: + hash_name, hash_value = value.split("=", 1) + except ValueError: + raise DirectUrlValidationError( + f"invalid archive_info.hash format: {value!r}" + ) + if self.hashes is None: + self.hashes = {hash_name: hash_value} + elif hash_name not in self.hashes: + self.hashes = self.hashes.copy() + self.hashes[hash_name] = hash_value + self._hash = value + @classmethod - def _from_dict(cls, d): - # type: (Optional[Dict[str, Any]]) -> Optional[ArchiveInfo] + def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["ArchiveInfo"]: if d is None: return None - return cls(hash=_get(d, str, "hash")) + return cls(hash=_get(d, str, "hash"), hashes=_get(d, dict, "hashes")) - def _to_dict(self): - # type: () -> Dict[str, Any] - return _filter_none(hash=self.hash) + def _to_dict(self) -> Dict[str, Any]: + return _filter_none(hash=self.hash, hashes=self.hashes) class DirInfo: @@ -133,21 +146,17 @@ class DirInfo: def __init__( self, - editable=False, # type: bool - ): + editable: bool = False, + ) -> None: self.editable = editable @classmethod - def _from_dict(cls, d): - # type: (Optional[Dict[str, Any]]) -> Optional[DirInfo] + def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["DirInfo"]: if d is None: return None - return cls( - editable=_get_required(d, bool, "editable", default=False) - ) + return cls(editable=_get_required(d, bool, "editable", default=False)) - def _to_dict(self): - # type: () -> Dict[str, Any] + def _to_dict(self) -> Dict[str, Any]: return _filter_none(editable=self.editable or None) @@ -155,26 +164,24 @@ InfoType = Union[ArchiveInfo, DirInfo, VcsInfo] class DirectUrl: - def __init__( self, - url, # type: str - info, # type: InfoType - subdirectory=None, # type: Optional[str] - ): + url: str, + info: InfoType, + subdirectory: Optional[str] = None, + ) -> None: self.url = url self.info = info self.subdirectory = subdirectory - def _remove_auth_from_netloc(self, netloc): - # type: (str) -> str + def _remove_auth_from_netloc(self, netloc: str) -> str: if "@" not in netloc: return netloc user_pass, netloc_no_user_pass = netloc.split("@", 1) if ( - isinstance(self.info, VcsInfo) and - self.info.vcs == "git" and - user_pass == "git" + isinstance(self.info, VcsInfo) + and self.info.vcs == "git" + and user_pass == "git" ): return netloc if ENV_VAR_RE.match(user_pass): @@ -182,8 +189,7 @@ class DirectUrl: return netloc_no_user_pass @property - def redacted_url(self): - # type: () -> str + def redacted_url(self) -> str: """url with user:password part removed unless it is formed with environment variables as specified in PEP 610, or it is ``git`` in the case of a git URL. @@ -195,13 +201,11 @@ class DirectUrl: ) return surl - def validate(self): - # type: () -> None + def validate(self) -> None: self.from_dict(self.to_dict()) @classmethod - def from_dict(cls, d): - # type: (Dict[str, Any]) -> DirectUrl + def from_dict(cls, d: Dict[str, Any]) -> "DirectUrl": return DirectUrl( url=_get_required(d, str, "url"), subdirectory=_get(d, str, "subdirectory"), @@ -214,8 +218,7 @@ class DirectUrl: ), ) - def to_dict(self): - # type: () -> Dict[str, Any] + def to_dict(self) -> Dict[str, Any]: res = _filter_none( url=self.redacted_url, subdirectory=self.subdirectory, @@ -224,10 +227,11 @@ class DirectUrl: return res @classmethod - def from_json(cls, s): - # type: (str) -> DirectUrl + def from_json(cls, s: str) -> "DirectUrl": return cls.from_dict(json.loads(s)) - def to_json(self): - # type: () -> str + def to_json(self) -> str: return json.dumps(self.to_dict(), sort_keys=True) + + def is_local_editable(self) -> bool: + return isinstance(self.info, DirInfo) and self.info.editable diff --git a/env/Lib/site-packages/pip/_internal/models/format_control.py b/env/Lib/site-packages/pip/_internal/models/format_control.py index cf262af2..db3995ea 100644 --- a/env/Lib/site-packages/pip/_internal/models/format_control.py +++ b/env/Lib/site-packages/pip/_internal/models/format_control.py @@ -6,13 +6,15 @@ from pip._internal.exceptions import CommandError class FormatControl: - """Helper for managing formats from which a package can be installed. - """ + """Helper for managing formats from which a package can be installed.""" __slots__ = ["no_binary", "only_binary"] - def __init__(self, no_binary=None, only_binary=None): - # type: (Optional[Set[str]], Optional[Set[str]]) -> None + def __init__( + self, + no_binary: Optional[Set[str]] = None, + only_binary: Optional[Set[str]] = None, + ) -> None: if no_binary is None: no_binary = set() if only_binary is None: @@ -21,66 +23,58 @@ class FormatControl: self.no_binary = no_binary self.only_binary = only_binary - def __eq__(self, other): - # type: (object) -> bool + def __eq__(self, other: object) -> bool: if not isinstance(other, self.__class__): return NotImplemented if self.__slots__ != other.__slots__: return False - return all( - getattr(self, k) == getattr(other, k) - for k in self.__slots__ - ) + return all(getattr(self, k) == getattr(other, k) for k in self.__slots__) - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return "{}({}, {})".format( - self.__class__.__name__, - self.no_binary, - self.only_binary + self.__class__.__name__, self.no_binary, self.only_binary ) @staticmethod - def handle_mutual_excludes(value, target, other): - # type: (str, Set[str], Set[str]) -> None - if value.startswith('-'): + def handle_mutual_excludes(value: str, target: Set[str], other: Set[str]) -> None: + if value.startswith("-"): raise CommandError( "--no-binary / --only-binary option requires 1 argument." ) - new = value.split(',') - while ':all:' in new: + new = value.split(",") + while ":all:" in new: other.clear() target.clear() - target.add(':all:') - del new[:new.index(':all:') + 1] + target.add(":all:") + del new[: new.index(":all:") + 1] # Without a none, we want to discard everything as :all: covers it - if ':none:' not in new: + if ":none:" not in new: return for name in new: - if name == ':none:': + if name == ":none:": target.clear() continue name = canonicalize_name(name) other.discard(name) target.add(name) - def get_allowed_formats(self, canonical_name): - # type: (str) -> FrozenSet[str] + def get_allowed_formats(self, canonical_name: str) -> FrozenSet[str]: result = {"binary", "source"} if canonical_name in self.only_binary: - result.discard('source') + result.discard("source") elif canonical_name in self.no_binary: - result.discard('binary') - elif ':all:' in self.only_binary: - result.discard('source') - elif ':all:' in self.no_binary: - result.discard('binary') + result.discard("binary") + elif ":all:" in self.only_binary: + result.discard("source") + elif ":all:" in self.no_binary: + result.discard("binary") return frozenset(result) - def disallow_binaries(self): - # type: () -> None + def disallow_binaries(self) -> None: self.handle_mutual_excludes( - ':all:', self.no_binary, self.only_binary, + ":all:", + self.no_binary, + self.only_binary, ) diff --git a/env/Lib/site-packages/pip/_internal/models/index.py b/env/Lib/site-packages/pip/_internal/models/index.py index b148abb4..b94c3251 100644 --- a/env/Lib/site-packages/pip/_internal/models/index.py +++ b/env/Lib/site-packages/pip/_internal/models/index.py @@ -2,33 +2,27 @@ import urllib.parse class PackageIndex: - """Represents a Package Index and provides easier access to endpoints - """ + """Represents a Package Index and provides easier access to endpoints""" - __slots__ = ['url', 'netloc', 'simple_url', 'pypi_url', - 'file_storage_domain'] + __slots__ = ["url", "netloc", "simple_url", "pypi_url", "file_storage_domain"] - def __init__(self, url, file_storage_domain): - # type: (str, str) -> None + def __init__(self, url: str, file_storage_domain: str) -> None: super().__init__() self.url = url self.netloc = urllib.parse.urlsplit(url).netloc - self.simple_url = self._url_for_path('simple') - self.pypi_url = self._url_for_path('pypi') + self.simple_url = self._url_for_path("simple") + self.pypi_url = self._url_for_path("pypi") # This is part of a temporary hack used to block installs of PyPI # packages which depend on external urls only necessary until PyPI can # block such packages themselves self.file_storage_domain = file_storage_domain - def _url_for_path(self, path): - # type: (str) -> str + def _url_for_path(self, path: str) -> str: return urllib.parse.urljoin(self.url, path) -PyPI = PackageIndex( - 'https://pypi.org/', file_storage_domain='files.pythonhosted.org' -) +PyPI = PackageIndex("https://pypi.org/", file_storage_domain="files.pythonhosted.org") TestPyPI = PackageIndex( - 'https://test.pypi.org/', file_storage_domain='test-files.pythonhosted.org' + "https://test.pypi.org/", file_storage_domain="test-files.pythonhosted.org" ) diff --git a/env/Lib/site-packages/pip/_internal/models/link.py b/env/Lib/site-packages/pip/_internal/models/link.py index 86d0be40..4453519a 100644 --- a/env/Lib/site-packages/pip/_internal/models/link.py +++ b/env/Lib/site-packages/pip/_internal/models/link.py @@ -1,12 +1,28 @@ +import functools +import itertools +import logging import os import posixpath import re import urllib.parse -from typing import TYPE_CHECKING, Optional, Tuple, Union +from dataclasses import dataclass +from typing import ( + TYPE_CHECKING, + Any, + Dict, + List, + Mapping, + NamedTuple, + Optional, + Tuple, + Union, +) +from pip._internal.utils.deprecation import deprecated from pip._internal.utils.filetypes import WHEEL_EXTENSION from pip._internal.utils.hashes import Hashes from pip._internal.utils.misc import ( + pairwise, redact_auth_from_url, split_auth_from_netloc, splitext, @@ -15,34 +31,182 @@ from pip._internal.utils.models import KeyBasedCompareMixin from pip._internal.utils.urls import path_to_url, url_to_path if TYPE_CHECKING: - from pip._internal.index.collector import HTMLPage + from pip._internal.index.collector import IndexContent +logger = logging.getLogger(__name__) -class Link(KeyBasedCompareMixin): - """Represents a parsed link from a Package Index's simple URL + +# Order matters, earlier hashes have a precedence over later hashes for what +# we will pick to use. +_SUPPORTED_HASHES = ("sha512", "sha384", "sha256", "sha224", "sha1", "md5") + + +@dataclass(frozen=True) +class LinkHash: + """Links to content may have embedded hash values. This class parses those. + + `name` must be any member of `_SUPPORTED_HASHES`. + + This class can be converted to and from `ArchiveInfo`. While ArchiveInfo intends to + be JSON-serializable to conform to PEP 610, this class contains the logic for + parsing a hash name and value for correctness, and then checking whether that hash + conforms to a schema with `.is_hash_allowed()`.""" + + name: str + value: str + + _hash_url_fragment_re = re.compile( + # NB: we do not validate that the second group (.*) is a valid hex + # digest. Instead, we simply keep that string in this class, and then check it + # against Hashes when hash-checking is needed. This is easier to debug than + # proactively discarding an invalid hex digest, as we handle incorrect hashes + # and malformed hashes in the same place. + r"[#&]({choices})=([^&]*)".format( + choices="|".join(re.escape(hash_name) for hash_name in _SUPPORTED_HASHES) + ), + ) + + def __post_init__(self) -> None: + assert self.name in _SUPPORTED_HASHES + + @classmethod + @functools.lru_cache(maxsize=None) + def find_hash_url_fragment(cls, url: str) -> Optional["LinkHash"]: + """Search a string for a checksum algorithm name and encoded output value.""" + match = cls._hash_url_fragment_re.search(url) + if match is None: + return None + name, value = match.groups() + return cls(name=name, value=value) + + def as_dict(self) -> Dict[str, str]: + return {self.name: self.value} + + def as_hashes(self) -> Hashes: + """Return a Hashes instance which checks only for the current hash.""" + return Hashes({self.name: [self.value]}) + + def is_hash_allowed(self, hashes: Optional[Hashes]) -> bool: + """ + Return True if the current hash is allowed by `hashes`. + """ + if hashes is None: + return False + return hashes.is_hash_allowed(self.name, hex_digest=self.value) + + +@dataclass(frozen=True) +class MetadataFile: + """Information about a core metadata file associated with a distribution.""" + + hashes: Optional[Dict[str, str]] + + def __post_init__(self) -> None: + if self.hashes is not None: + assert all(name in _SUPPORTED_HASHES for name in self.hashes) + + +def supported_hashes(hashes: Optional[Dict[str, str]]) -> Optional[Dict[str, str]]: + # Remove any unsupported hash types from the mapping. If this leaves no + # supported hashes, return None + if hashes is None: + return None + hashes = {n: v for n, v in hashes.items() if n in _SUPPORTED_HASHES} + if not hashes: + return None + return hashes + + +def _clean_url_path_part(part: str) -> str: """ + Clean a "part" of a URL path (i.e. after splitting on "@" characters). + """ + # We unquote prior to quoting to make sure nothing is double quoted. + return urllib.parse.quote(urllib.parse.unquote(part)) + + +def _clean_file_url_path(part: str) -> str: + """ + Clean the first part of a URL path that corresponds to a local + filesystem path (i.e. the first part after splitting on "@" characters). + """ + # We unquote prior to quoting to make sure nothing is double quoted. + # Also, on Windows the path part might contain a drive letter which + # should not be quoted. On Linux where drive letters do not + # exist, the colon should be quoted. We rely on urllib.request + # to do the right thing here. + return urllib.request.pathname2url(urllib.request.url2pathname(part)) + + +# percent-encoded: / +_reserved_chars_re = re.compile("(@|%2F)", re.IGNORECASE) + + +def _clean_url_path(path: str, is_local_path: bool) -> str: + """ + Clean the path portion of a URL. + """ + if is_local_path: + clean_func = _clean_file_url_path + else: + clean_func = _clean_url_path_part + + # Split on the reserved characters prior to cleaning so that + # revision strings in VCS URLs are properly preserved. + parts = _reserved_chars_re.split(path) + + cleaned_parts = [] + for to_clean, reserved in pairwise(itertools.chain(parts, [""])): + cleaned_parts.append(clean_func(to_clean)) + # Normalize %xx escapes (e.g. %2f -> %2F) + cleaned_parts.append(reserved.upper()) + + return "".join(cleaned_parts) + + +def _ensure_quoted_url(url: str) -> str: + """ + Make sure a link is fully quoted. + For example, if ' ' occurs in the URL, it will be replaced with "%20", + and without double-quoting other characters. + """ + # Split the URL into parts according to the general structure + # `scheme://netloc/path;parameters?query#fragment`. + result = urllib.parse.urlparse(url) + # If the netloc is empty, then the URL refers to a local filesystem path. + is_local_path = not result.netloc + path = _clean_url_path(result.path, is_local_path=is_local_path) + return urllib.parse.urlunparse(result._replace(path=path)) + + +class Link(KeyBasedCompareMixin): + """Represents a parsed link from a Package Index's simple URL""" __slots__ = [ "_parsed_url", "_url", + "_hashes", "comes_from", "requires_python", "yanked_reason", + "metadata_file_data", "cache_link_parsing", + "egg_fragment", ] def __init__( self, - url, # type: str - comes_from=None, # type: Optional[Union[str, HTMLPage]] - requires_python=None, # type: Optional[str] - yanked_reason=None, # type: Optional[str] - cache_link_parsing=True, # type: bool - ): - # type: (...) -> None + url: str, + comes_from: Optional[Union[str, "IndexContent"]] = None, + requires_python: Optional[str] = None, + yanked_reason: Optional[str] = None, + metadata_file_data: Optional[MetadataFile] = None, + cache_link_parsing: bool = True, + hashes: Optional[Mapping[str, str]] = None, + ) -> None: """ :param url: url of the resource pointed to (href of the link) - :param comes_from: instance of HTMLPage where the link was found, + :param comes_from: instance of IndexContent where the link was found, or string. :param requires_python: String containing the `Requires-Python` metadata field, specified in PEP 345. This may be specified by @@ -54,15 +218,23 @@ class Link(KeyBasedCompareMixin): a simple repository HTML link. If the file has been yanked but no reason was provided, this should be the empty string. See PEP 592 for more information and the specification. + :param metadata_file_data: the metadata attached to the file, or None if + no such metadata is provided. This argument, if not None, indicates + that a separate metadata file exists, and also optionally supplies + hashes for that file. :param cache_link_parsing: A flag that is used elsewhere to determine - whether resources retrieved from this link - should be cached. PyPI index urls should - generally have this set to False, for - example. + whether resources retrieved from this link should be cached. PyPI + URLs should generally have this set to False, for example. + :param hashes: A mapping of hash names to digests to allow us to + determine the validity of a download. """ + # The comes_from, requires_python, and metadata_file_data arguments are + # only used by classmethods of this class, and are not used in client + # code directly. + # url can be a UNC windows share - if url.startswith('\\\\'): + if url.startswith("\\\\"): url = path_to_url(url) self._parsed_url = urllib.parse.urlsplit(url) @@ -70,39 +242,148 @@ class Link(KeyBasedCompareMixin): # trying to set a new value. self._url = url + link_hash = LinkHash.find_hash_url_fragment(url) + hashes_from_link = {} if link_hash is None else link_hash.as_dict() + if hashes is None: + self._hashes = hashes_from_link + else: + self._hashes = {**hashes, **hashes_from_link} + self.comes_from = comes_from self.requires_python = requires_python if requires_python else None self.yanked_reason = yanked_reason + self.metadata_file_data = metadata_file_data super().__init__(key=url, defining_class=Link) self.cache_link_parsing = cache_link_parsing + self.egg_fragment = self._egg_fragment() + + @classmethod + def from_json( + cls, + file_data: Dict[str, Any], + page_url: str, + ) -> Optional["Link"]: + """ + Convert an pypi json document from a simple repository page into a Link. + """ + file_url = file_data.get("url") + if file_url is None: + return None - def __str__(self): - # type: () -> str + url = _ensure_quoted_url(urllib.parse.urljoin(page_url, file_url)) + pyrequire = file_data.get("requires-python") + yanked_reason = file_data.get("yanked") + hashes = file_data.get("hashes", {}) + + # PEP 714: Indexes must use the name core-metadata, but + # clients should support the old name as a fallback for compatibility. + metadata_info = file_data.get("core-metadata") + if metadata_info is None: + metadata_info = file_data.get("dist-info-metadata") + + # The metadata info value may be a boolean, or a dict of hashes. + if isinstance(metadata_info, dict): + # The file exists, and hashes have been supplied + metadata_file_data = MetadataFile(supported_hashes(metadata_info)) + elif metadata_info: + # The file exists, but there are no hashes + metadata_file_data = MetadataFile(None) + else: + # False or not present: the file does not exist + metadata_file_data = None + + # The Link.yanked_reason expects an empty string instead of a boolean. + if yanked_reason and not isinstance(yanked_reason, str): + yanked_reason = "" + # The Link.yanked_reason expects None instead of False. + elif not yanked_reason: + yanked_reason = None + + return cls( + url, + comes_from=page_url, + requires_python=pyrequire, + yanked_reason=yanked_reason, + hashes=hashes, + metadata_file_data=metadata_file_data, + ) + + @classmethod + def from_element( + cls, + anchor_attribs: Dict[str, Optional[str]], + page_url: str, + base_url: str, + ) -> Optional["Link"]: + """ + Convert an anchor element's attributes in a simple repository page to a Link. + """ + href = anchor_attribs.get("href") + if not href: + return None + + url = _ensure_quoted_url(urllib.parse.urljoin(base_url, href)) + pyrequire = anchor_attribs.get("data-requires-python") + yanked_reason = anchor_attribs.get("data-yanked") + + # PEP 714: Indexes must use the name data-core-metadata, but + # clients should support the old name as a fallback for compatibility. + metadata_info = anchor_attribs.get("data-core-metadata") + if metadata_info is None: + metadata_info = anchor_attribs.get("data-dist-info-metadata") + # The metadata info value may be the string "true", or a string of + # the form "hashname=hashval" + if metadata_info == "true": + # The file exists, but there are no hashes + metadata_file_data = MetadataFile(None) + elif metadata_info is None: + # The file does not exist + metadata_file_data = None + else: + # The file exists, and hashes have been supplied + hashname, sep, hashval = metadata_info.partition("=") + if sep == "=": + metadata_file_data = MetadataFile(supported_hashes({hashname: hashval})) + else: + # Error - data is wrong. Treat as no hashes supplied. + logger.debug( + "Index returned invalid data-dist-info-metadata value: %s", + metadata_info, + ) + metadata_file_data = MetadataFile(None) + + return cls( + url, + comes_from=page_url, + requires_python=pyrequire, + yanked_reason=yanked_reason, + metadata_file_data=metadata_file_data, + ) + + def __str__(self) -> str: if self.requires_python: - rp = f' (requires-python:{self.requires_python})' + rp = f" (requires-python:{self.requires_python})" else: - rp = '' + rp = "" if self.comes_from: - return '{} (from {}){}'.format( - redact_auth_from_url(self._url), self.comes_from, rp) + return "{} (from {}){}".format( + redact_auth_from_url(self._url), self.comes_from, rp + ) else: return redact_auth_from_url(str(self._url)) - def __repr__(self): - # type: () -> str - return f'<Link {self}>' + def __repr__(self) -> str: + return f"<Link {self}>" @property - def url(self): - # type: () -> str + def url(self) -> str: return self._url @property - def filename(self): - # type: () -> str - path = self.path.rstrip('/') + def filename(self) -> str: + path = self.path.rstrip("/") name = posixpath.basename(path) if not name: # Make sure we don't leak auth information if the netloc @@ -111,138 +392,190 @@ class Link(KeyBasedCompareMixin): return netloc name = urllib.parse.unquote(name) - assert name, f'URL {self._url!r} produced no filename' + assert name, f"URL {self._url!r} produced no filename" return name @property - def file_path(self): - # type: () -> str + def file_path(self) -> str: return url_to_path(self.url) @property - def scheme(self): - # type: () -> str + def scheme(self) -> str: return self._parsed_url.scheme @property - def netloc(self): - # type: () -> str + def netloc(self) -> str: """ This can contain auth information. """ return self._parsed_url.netloc @property - def path(self): - # type: () -> str + def path(self) -> str: return urllib.parse.unquote(self._parsed_url.path) - def splitext(self): - # type: () -> Tuple[str, str] - return splitext(posixpath.basename(self.path.rstrip('/'))) + def splitext(self) -> Tuple[str, str]: + return splitext(posixpath.basename(self.path.rstrip("/"))) @property - def ext(self): - # type: () -> str + def ext(self) -> str: return self.splitext()[1] @property - def url_without_fragment(self): - # type: () -> str + def url_without_fragment(self) -> str: scheme, netloc, path, query, fragment = self._parsed_url - return urllib.parse.urlunsplit((scheme, netloc, path, query, None)) + return urllib.parse.urlunsplit((scheme, netloc, path, query, "")) - _egg_fragment_re = re.compile(r'[#&]egg=([^&]*)') + _egg_fragment_re = re.compile(r"[#&]egg=([^&]*)") - @property - def egg_fragment(self): - # type: () -> Optional[str] + # Per PEP 508. + _project_name_re = re.compile( + r"^([A-Z0-9]|[A-Z0-9][A-Z0-9._-]*[A-Z0-9])$", re.IGNORECASE + ) + + def _egg_fragment(self) -> Optional[str]: match = self._egg_fragment_re.search(self._url) if not match: return None - return match.group(1) - _subdirectory_fragment_re = re.compile(r'[#&]subdirectory=([^&]*)') + # An egg fragment looks like a PEP 508 project name, along with + # an optional extras specifier. Anything else is invalid. + project_name = match.group(1) + if not self._project_name_re.match(project_name): + deprecated( + reason=f"{self} contains an egg fragment with a non-PEP 508 name", + replacement="to use the req @ url syntax, and remove the egg fragment", + gone_in="25.0", + issue=11617, + ) + + return project_name + + _subdirectory_fragment_re = re.compile(r"[#&]subdirectory=([^&]*)") @property - def subdirectory_fragment(self): - # type: () -> Optional[str] + def subdirectory_fragment(self) -> Optional[str]: match = self._subdirectory_fragment_re.search(self._url) if not match: return None return match.group(1) - _hash_re = re.compile( - r'(sha1|sha224|sha384|sha256|sha512|md5)=([a-f0-9]+)' - ) + def metadata_link(self) -> Optional["Link"]: + """Return a link to the associated core metadata file (if any).""" + if self.metadata_file_data is None: + return None + metadata_url = f"{self.url_without_fragment}.metadata" + if self.metadata_file_data.hashes is None: + return Link(metadata_url) + return Link(metadata_url, hashes=self.metadata_file_data.hashes) + + def as_hashes(self) -> Hashes: + return Hashes({k: [v] for k, v in self._hashes.items()}) @property - def hash(self): - # type: () -> Optional[str] - match = self._hash_re.search(self._url) - if match: - return match.group(2) - return None + def hash(self) -> Optional[str]: + return next(iter(self._hashes.values()), None) @property - def hash_name(self): - # type: () -> Optional[str] - match = self._hash_re.search(self._url) - if match: - return match.group(1) - return None + def hash_name(self) -> Optional[str]: + return next(iter(self._hashes), None) @property - def show_url(self): - # type: () -> str - return posixpath.basename(self._url.split('#', 1)[0].split('?', 1)[0]) + def show_url(self) -> str: + return posixpath.basename(self._url.split("#", 1)[0].split("?", 1)[0]) @property - def is_file(self): - # type: () -> bool - return self.scheme == 'file' + def is_file(self) -> bool: + return self.scheme == "file" - def is_existing_dir(self): - # type: () -> bool + def is_existing_dir(self) -> bool: return self.is_file and os.path.isdir(self.file_path) @property - def is_wheel(self): - # type: () -> bool + def is_wheel(self) -> bool: return self.ext == WHEEL_EXTENSION @property - def is_vcs(self): - # type: () -> bool + def is_vcs(self) -> bool: from pip._internal.vcs import vcs return self.scheme in vcs.all_schemes @property - def is_yanked(self): - # type: () -> bool + def is_yanked(self) -> bool: return self.yanked_reason is not None @property - def has_hash(self): - # type: () -> bool - return self.hash_name is not None + def has_hash(self) -> bool: + return bool(self._hashes) - def is_hash_allowed(self, hashes): - # type: (Optional[Hashes]) -> bool + def is_hash_allowed(self, hashes: Optional[Hashes]) -> bool: """ - Return True if the link has a hash and it is allowed. + Return True if the link has a hash and it is allowed by `hashes`. """ - if hashes is None or not self.has_hash: + if hashes is None: return False - # Assert non-None so mypy knows self.hash_name and self.hash are str. - assert self.hash_name is not None - assert self.hash is not None + return any(hashes.is_hash_allowed(k, v) for k, v in self._hashes.items()) + + +class _CleanResult(NamedTuple): + """Convert link for equivalency check. + + This is used in the resolver to check whether two URL-specified requirements + likely point to the same distribution and can be considered equivalent. This + equivalency logic avoids comparing URLs literally, which can be too strict + (e.g. "a=1&b=2" vs "b=2&a=1") and produce conflicts unexpecting to users. + + Currently this does three things: + + 1. Drop the basic auth part. This is technically wrong since a server can + serve different content based on auth, but if it does that, it is even + impossible to guarantee two URLs without auth are equivalent, since + the user can input different auth information when prompted. So the + practical solution is to assume the auth doesn't affect the response. + 2. Parse the query to avoid the ordering issue. Note that ordering under the + same key in the query are NOT cleaned; i.e. "a=1&a=2" and "a=2&a=1" are + still considered different. + 3. Explicitly drop most of the fragment part, except ``subdirectory=`` and + hash values, since it should have no impact the downloaded content. Note + that this drops the "egg=" part historically used to denote the requested + project (and extras), which is wrong in the strictest sense, but too many + people are supplying it inconsistently to cause superfluous resolution + conflicts, so we choose to also ignore them. + """ - return hashes.is_hash_allowed(self.hash_name, hex_digest=self.hash) + parsed: urllib.parse.SplitResult + query: Dict[str, List[str]] + subdirectory: str + hashes: Dict[str, str] + + +def _clean_link(link: Link) -> _CleanResult: + parsed = link._parsed_url + netloc = parsed.netloc.rsplit("@", 1)[-1] + # According to RFC 8089, an empty host in file: means localhost. + if parsed.scheme == "file" and not netloc: + netloc = "localhost" + fragment = urllib.parse.parse_qs(parsed.fragment) + if "egg" in fragment: + logger.debug("Ignoring egg= fragment in %s", link) + try: + # If there are multiple subdirectory values, use the first one. + # This matches the behavior of Link.subdirectory_fragment. + subdirectory = fragment["subdirectory"][0] + except (IndexError, KeyError): + subdirectory = "" + # If there are multiple hash values under the same algorithm, use the + # first one. This matches the behavior of Link.hash_value. + hashes = {k: fragment[k][0] for k in _SUPPORTED_HASHES if k in fragment} + return _CleanResult( + parsed=parsed._replace(netloc=netloc, query="", fragment=""), + query=urllib.parse.parse_qs(parsed.query), + subdirectory=subdirectory, + hashes=hashes, + ) -# TODO: Relax this comparison logic to ignore, for example, fragments. -def links_equivalent(link1, link2): - # type: (Link, Link) -> bool - return link1 == link2 +@functools.lru_cache(maxsize=None) +def links_equivalent(link1: Link, link2: Link) -> bool: + return _clean_link(link1) == _clean_link(link2) diff --git a/env/Lib/site-packages/pip/_internal/models/scheme.py b/env/Lib/site-packages/pip/_internal/models/scheme.py index 697cd19b..f51190ac 100644 --- a/env/Lib/site-packages/pip/_internal/models/scheme.py +++ b/env/Lib/site-packages/pip/_internal/models/scheme.py @@ -6,7 +6,7 @@ https://docs.python.org/3/install/index.html#alternate-installation. """ -SCHEME_KEYS = ['platlib', 'purelib', 'headers', 'scripts', 'data'] +SCHEME_KEYS = ["platlib", "purelib", "headers", "scripts", "data"] class Scheme: @@ -18,12 +18,12 @@ class Scheme: def __init__( self, - platlib, # type: str - purelib, # type: str - headers, # type: str - scripts, # type: str - data, # type: str - ): + platlib: str, + purelib: str, + headers: str, + scripts: str, + data: str, + ) -> None: self.platlib = platlib self.purelib = purelib self.headers = headers diff --git a/env/Lib/site-packages/pip/_internal/models/search_scope.py b/env/Lib/site-packages/pip/_internal/models/search_scope.py index a3f0a5c0..fe61e811 100644 --- a/env/Lib/site-packages/pip/_internal/models/search_scope.py +++ b/env/Lib/site-packages/pip/_internal/models/search_scope.py @@ -20,15 +20,15 @@ class SearchScope: Encapsulates the locations that pip is configured to search. """ - __slots__ = ["find_links", "index_urls"] + __slots__ = ["find_links", "index_urls", "no_index"] @classmethod def create( cls, - find_links, # type: List[str] - index_urls, # type: List[str] - ): - # type: (...) -> SearchScope + find_links: List[str], + index_urls: List[str], + no_index: bool, + ) -> "SearchScope": """ Create a SearchScope object after normalizing the `find_links`. """ @@ -37,9 +37,9 @@ class SearchScope: # it and if it exists, use the normalized version. # This is deliberately conservative - it might be fine just to # blindly normalize anything starting with a ~... - built_find_links = [] # type: List[str] + built_find_links: List[str] = [] for link in find_links: - if link.startswith('~'): + if link.startswith("~"): new_link = normalize_path(link) if os.path.exists(new_link): link = new_link @@ -50,35 +50,35 @@ class SearchScope: if not has_tls(): for link in itertools.chain(index_urls, built_find_links): parsed = urllib.parse.urlparse(link) - if parsed.scheme == 'https': + if parsed.scheme == "https": logger.warning( - 'pip is configured with locations that require ' - 'TLS/SSL, however the ssl module in Python is not ' - 'available.' + "pip is configured with locations that require " + "TLS/SSL, however the ssl module in Python is not " + "available." ) break return cls( find_links=built_find_links, index_urls=index_urls, + no_index=no_index, ) def __init__( self, - find_links, # type: List[str] - index_urls, # type: List[str] - ): - # type: (...) -> None + find_links: List[str], + index_urls: List[str], + no_index: bool, + ) -> None: self.find_links = find_links self.index_urls = index_urls + self.no_index = no_index - def get_formatted_locations(self): - # type: () -> str + def get_formatted_locations(self) -> str: lines = [] redacted_index_urls = [] if self.index_urls and self.index_urls != [PyPI.simple_url]: for url in self.index_urls: - redacted_index_url = redact_auth_from_url(url) # Parse the URL @@ -91,41 +91,42 @@ class SearchScope: # exceptions for malformed URLs if not purl.scheme and not purl.netloc: logger.warning( - 'The index url "%s" seems invalid, ' - 'please provide a scheme.', redacted_index_url) + 'The index url "%s" seems invalid, please provide a scheme.', + redacted_index_url, + ) redacted_index_urls.append(redacted_index_url) - lines.append('Looking in indexes: {}'.format( - ', '.join(redacted_index_urls))) + lines.append( + "Looking in indexes: {}".format(", ".join(redacted_index_urls)) + ) if self.find_links: lines.append( - 'Looking in links: {}'.format(', '.join( - redact_auth_from_url(url) for url in self.find_links)) + "Looking in links: {}".format( + ", ".join(redact_auth_from_url(url) for url in self.find_links) + ) ) - return '\n'.join(lines) + return "\n".join(lines) - def get_index_urls_locations(self, project_name): - # type: (str) -> List[str] + def get_index_urls_locations(self, project_name: str) -> List[str]: """Returns the locations found via self.index_urls Checks the url_name on the main (first in the list) index and use this url_name to produce all locations """ - def mkurl_pypi_url(url): - # type: (str) -> str + def mkurl_pypi_url(url: str) -> str: loc = posixpath.join( - url, - urllib.parse.quote(canonicalize_name(project_name))) + url, urllib.parse.quote(canonicalize_name(project_name)) + ) # For maximum compatibility with easy_install, ensure the path # ends in a trailing slash. Although this isn't in the spec # (and PyPI can handle it without the slash) some other index # implementations might break if they relied on easy_install's # behavior. - if not loc.endswith('/'): - loc = loc + '/' + if not loc.endswith("/"): + loc = loc + "/" return loc return [mkurl_pypi_url(url) for url in self.index_urls] diff --git a/env/Lib/site-packages/pip/_internal/models/selection_prefs.py b/env/Lib/site-packages/pip/_internal/models/selection_prefs.py index edc1cf79..977bc4ca 100644 --- a/env/Lib/site-packages/pip/_internal/models/selection_prefs.py +++ b/env/Lib/site-packages/pip/_internal/models/selection_prefs.py @@ -9,8 +9,13 @@ class SelectionPreferences: and installing files. """ - __slots__ = ['allow_yanked', 'allow_all_prereleases', 'format_control', - 'prefer_binary', 'ignore_requires_python'] + __slots__ = [ + "allow_yanked", + "allow_all_prereleases", + "format_control", + "prefer_binary", + "ignore_requires_python", + ] # Don't include an allow_yanked default value to make sure each call # site considers whether yanked releases are allowed. This also causes @@ -18,13 +23,12 @@ class SelectionPreferences: # people when reading the code. def __init__( self, - allow_yanked, # type: bool - allow_all_prereleases=False, # type: bool - format_control=None, # type: Optional[FormatControl] - prefer_binary=False, # type: bool - ignore_requires_python=None, # type: Optional[bool] - ): - # type: (...) -> None + allow_yanked: bool, + allow_all_prereleases: bool = False, + format_control: Optional[FormatControl] = None, + prefer_binary: bool = False, + ignore_requires_python: Optional[bool] = None, + ) -> None: """Create a SelectionPreferences object. :param allow_yanked: Whether files marked as yanked (in the sense diff --git a/env/Lib/site-packages/pip/_internal/models/target_python.py b/env/Lib/site-packages/pip/_internal/models/target_python.py index b91e349f..744bd7ef 100644 --- a/env/Lib/site-packages/pip/_internal/models/target_python.py +++ b/env/Lib/site-packages/pip/_internal/models/target_python.py @@ -26,12 +26,11 @@ class TargetPython: def __init__( self, - platforms=None, # type: Optional[List[str]] - py_version_info=None, # type: Optional[Tuple[int, ...]] - abis=None, # type: Optional[List[str]] - implementation=None, # type: Optional[str] - ): - # type: (...) -> None + platforms: Optional[List[str]] = None, + py_version_info: Optional[Tuple[int, ...]] = None, + abis: Optional[List[str]] = None, + implementation: Optional[str] = None, + ) -> None: """ :param platforms: A list of strings or None. If None, searches for packages that are supported by the current system. Otherwise, will @@ -54,7 +53,7 @@ class TargetPython: else: py_version_info = normalize_version_info(py_version_info) - py_version = '.'.join(map(str, py_version_info[:2])) + py_version = ".".join(map(str, py_version_info[:2])) self.abis = abis self.implementation = implementation @@ -63,32 +62,29 @@ class TargetPython: self.py_version_info = py_version_info # This is used to cache the return value of get_tags(). - self._valid_tags = None # type: Optional[List[Tag]] + self._valid_tags: Optional[List[Tag]] = None - def format_given(self): - # type: () -> str + def format_given(self) -> str: """ Format the given, non-None attributes for display. """ display_version = None if self._given_py_version_info is not None: - display_version = '.'.join( + display_version = ".".join( str(part) for part in self._given_py_version_info ) key_values = [ - ('platforms', self.platforms), - ('version_info', display_version), - ('abis', self.abis), - ('implementation', self.implementation), + ("platforms", self.platforms), + ("version_info", display_version), + ("abis", self.abis), + ("implementation", self.implementation), ] - return ' '.join( - f'{key}={value!r}' for key, value in key_values - if value is not None + return " ".join( + f"{key}={value!r}" for key, value in key_values if value is not None ) - def get_tags(self): - # type: () -> List[Tag] + def get_tags(self) -> List[Tag]: """ Return the supported PEP 425 tags to check wheel candidates against. diff --git a/env/Lib/site-packages/pip/_internal/models/wheel.py b/env/Lib/site-packages/pip/_internal/models/wheel.py index 0a582b30..a5dc12bd 100644 --- a/env/Lib/site-packages/pip/_internal/models/wheel.py +++ b/env/Lib/site-packages/pip/_internal/models/wheel.py @@ -13,45 +13,39 @@ class Wheel: """A wheel file""" wheel_file_re = re.compile( - r"""^(?P<namever>(?P<name>.+?)-(?P<ver>.*?)) - ((-(?P<build>\d[^-]*?))?-(?P<pyver>.+?)-(?P<abi>.+?)-(?P<plat>.+?) + r"""^(?P<namever>(?P<name>[^\s-]+?)-(?P<ver>[^\s-]*?)) + ((-(?P<build>\d[^-]*?))?-(?P<pyver>[^\s-]+?)-(?P<abi>[^\s-]+?)-(?P<plat>[^\s-]+?) \.whl|\.dist-info)$""", - re.VERBOSE + re.VERBOSE, ) - def __init__(self, filename): - # type: (str) -> None + def __init__(self, filename: str) -> None: """ :raises InvalidWheelFilename: when the filename is invalid for a wheel """ wheel_info = self.wheel_file_re.match(filename) if not wheel_info: - raise InvalidWheelFilename( - f"{filename} is not a valid wheel filename." - ) + raise InvalidWheelFilename(f"{filename} is not a valid wheel filename.") self.filename = filename - self.name = wheel_info.group('name').replace('_', '-') + self.name = wheel_info.group("name").replace("_", "-") # we'll assume "_" means "-" due to wheel naming scheme # (https://github.com/pypa/pip/issues/1150) - self.version = wheel_info.group('ver').replace('_', '-') - self.build_tag = wheel_info.group('build') - self.pyversions = wheel_info.group('pyver').split('.') - self.abis = wheel_info.group('abi').split('.') - self.plats = wheel_info.group('plat').split('.') + self.version = wheel_info.group("ver").replace("_", "-") + self.build_tag = wheel_info.group("build") + self.pyversions = wheel_info.group("pyver").split(".") + self.abis = wheel_info.group("abi").split(".") + self.plats = wheel_info.group("plat").split(".") # All the tag combinations from this file self.file_tags = { - Tag(x, y, z) for x in self.pyversions - for y in self.abis for z in self.plats + Tag(x, y, z) for x in self.pyversions for y in self.abis for z in self.plats } - def get_formatted_file_tags(self): - # type: () -> List[str] + def get_formatted_file_tags(self) -> List[str]: """Return the wheel's tags as a sorted list of strings.""" return sorted(str(tag) for tag in self.file_tags) - def support_index_min(self, tags): - # type: (List[Tag]) -> int + def support_index_min(self, tags: List[Tag]) -> int: """Return the lowest index that one of the wheel's file_tag combinations achieves in the given list of supported tags. @@ -64,12 +58,16 @@ class Wheel: :raises ValueError: If none of the wheel's file tags match one of the supported tags. """ - return min(tags.index(tag) for tag in self.file_tags if tag in tags) - - def find_most_preferred_tag(self, tags, tag_to_priority): - # type: (List[Tag], Dict[Tag, int]) -> int + try: + return next(i for i, t in enumerate(tags) if t in self.file_tags) + except StopIteration: + raise ValueError() + + def find_most_preferred_tag( + self, tags: List[Tag], tag_to_priority: Dict[Tag, int] + ) -> int: """Return the priority of the most preferred tag that one of the wheel's file - tag combinations acheives in the given list of supported tags using the given + tag combinations achieves in the given list of supported tags using the given tag_to_priority mapping, where lower priorities are more-preferred. This is used in place of support_index_min in some cases in order to avoid @@ -86,8 +84,7 @@ class Wheel: tag_to_priority[tag] for tag in self.file_tags if tag in tag_to_priority ) - def supported(self, tags): - # type: (Iterable[Tag]) -> bool + def supported(self, tags: Iterable[Tag]) -> bool: """Return whether the wheel is compatible with one of the given tags. :param tags: the PEP 425 tags to check the wheel against. diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index f3ee8b34fc4cf8f48df3d0a0ba2be58f2a0dc881..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 276 zcmYe~<>g{vU|^UdaWK`0fq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}Wjo%8cb z5;OCP6$(m=QgbR5@={C6^NX@|i&AqEOHxx5N=q_xGD|X3i}kqtG#PKP$H%ASC&$OH zWGG@{V1N+6nw+g-LW@(2iepl9QZkET{PR*>iZaVm6?7Fs{XD~5gMvLn9D@}+{apP0 zT!TFwV}f0MU4uhhgA~kS0s?$u5>0e-^3yYmOER-#QuE4Ud@_?_iZe@6bqf-cvlG)( yi(?8h3-seN^GZ^S@)C3Op>EWVkI&4@EQycTE2zB1VUwGmQks)$2lDA>kk<iqDp1}4 diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-39.pyc deleted file mode 100644 index 82ccc78d38e85aa7e23215159a1ab3a616e04a29..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7073 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 diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/cache.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/cache.cpython-39.pyc deleted file mode 100644 index 26477c940f26ab4fbb0d679f7343d240d9a22075..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2755 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 PCILnsW)4;+MlNmu!SIE9 diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-39.pyc deleted file mode 100644 index 957193870cd2e7c0f55c2abd9650e129da0bf881..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5115 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 Xj3P{2%p4pXIvgAv{2US-9DIrZr@asT diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-39.pyc deleted file mode 100644 index e362245d91698f9c1799de1f3559ba70b9251bb5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7940 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 OU@XGO!z{qUAp`&l6vw>) diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/session.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/session.cpython-39.pyc deleted file mode 100644 index 4cc899614a1af82e99e45cee9f7293d508f21c37..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9523 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 E0KfPUw*UYD diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-39.pyc deleted file mode 100644 index bb437df66b90ddb6c559a84ca5c5ace45dc195d0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1342 zcmYe~<>g{vU|^UdaWM4-KLf*K5C<7EGcYhXFfcF_`!Fytq%fo~<}l<kMlt3xMKLjg z_)Iy>xhzpExvWvFU_NsWTP}MPJ0n91OA2cyV-!aUTMBy%LlkE!OB!PeM+#>PV-!~k zS1^Mn_e+pHnoPG?Tr!hOZgF^)q!uNX<QHi&-4b&4_X~0L3yF932=()h5B7|5y~Pof zT3nEySDdQJcuUMLwWK`1DBC$dFE2H@Br`wHwWuh+sEXe)IXShUMAtPhIX@*cFZ~ur zW=d*aNoGl9G9$<`C<gh7gMop;8RV}+Ab&B|GL|sZFk~^7Ff}t3IaLXO*bA6bm=-eD zGKDh~day8*uvFSHGJqgdju|8u$x!HFz>voV602oOVX0xrVr5}qX2@nNic4Y5W+<x3 zV_{^-lLCp)W=LVHVVcd5!d}CW#WtH^E^94go>2-bNDiuJQVK^lL(w|09tn{6Y=#t0 zbUihUMf*zFYZz-7Qn-4Vnix|UK%wb(i=m3Ov?NW}qKYfCIA7Po!qigNFmnPU14HH) zMh1o|eg)^8%+$OR1#nndDO7POq~#YWlosV!DP%@4fmH;j7L}zI!Bl86-r^{Ng*wMA zuFT@hyyB9?yyVndY(=Sw#rb)+Sd%JCQj2e~rKBe3r=;Ez3eC#|F<ii0utm4Hi%Swq zN{iz`;<uPfi*kzC7#J8dnQyUx%)Z5!QBqP6p9+e<_}t?3B5no-hLsFO!VC-yzv`W> zVnT~ki;81Xb5b&kV*K+`U5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e? zT!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$MGxJJP zi}Dh4^z$IeO24!uGpAUupz@YLQDSCsYJ6ILQ9Q&KvY;d*2TDgwEQ~y?OpF4IJd7et zY)n#2V*go~K_nA13uBQe0|P@c6G$Bt!_r(b$bcXQ28Jqy8ip)}EXEqf6vh;$UM3fY zSgu;88m2G?MutM6aE3e`7KRe0N*_>)V+5s5h6T(ujG#1E!&K~0=mAx!7s-&vWWbQZ z9L%7}Qf1+uS(ciokf>0UT3DJ|TvDt6%QZR*1x5K~nJK9XB^jv-DTyVC3dtFzdD+E! zTnY*b3T~Q=xA-8D7@wS<SCX1n;-|@Si@7MV{1#hrNl|KI?kzsYl9Hm#q|%a9NW`)f zr6#6mG8b_&FfiQW0-F|JoLQB6ixtcUM<Ij|0jb~zMK>q|$AhJdEkGe51_~Y)CMGsU zCUK@0Tv9xYJj^_dER0NyMWCSe)8xLzR#I7znU`J!3e6%=Fh)riWESYfm!;;V<QM6| ze5#k5pOTtWT*Sh_z)-{rvQPr73>LY1sTH8IAu~U(7@Poav3s~Wy0``fgX0Qp8^p1o jlm}sfoy}pBo1apelWGSlL5e|zr2vxv6OSkdGlw()nU!PF diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-39.pyc deleted file mode 100644 index d8acfbb5f179a9f877350bb380761b33f51769b6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1921 zcmYe~<>g{vU|^UdaWHi`8w0~*5C<8vFfcGUFfcF_w=pm<q%cG=q%fv1<uFDuf@!8G zW-!eX#hSvH!kojF%O1s^%Mr!F2vWzA!<ow!#RX=w=5XioMDc*xY&pESd{KOi45{oz zDJhI8>^UsC{89Y50#O2t45^F@1XG0;GDZozGo)~&aJDd{aHg_miDZd3Ge?P~Fa<Mc za#bl;<mMC=B<Ex%>4g*}<`oy@7nLYv<`(3n=BDPAB$j06=W)FRdBabW=@xHDWPoeD zvxlp*x2K=`E!L3If}B)M##>^3sU_w4McK~zd3mYHAU&={MfpXVjJLP~G7ExJi;FY! z^E4T62^1w}7N^Fi<rl>lmn4>y7Hcxy;*9smFD?nGEJ(e@8}FM~RGg8RlarW~lbQ^& z6&Zs95X3LmVPIfLWr$)-VTfW%VT@u<VQ*(hV@zRAVQJxvVoBjhVNGFcVT@vJXJBE7 zVhd)_<h&&mkXaA`_9@(#RY3to`DK|YsS1e-30OiQ0WBC5$}$r{N)bLv;8IXfP{>cp zN=+`&1GC+dVU7ejl$C*jff<U6wHO!}N*J0M7BJQ@FJxq7C}GNCUcgerxR9}yrG_Po zwT2;{t%j+FA)Y;jA(%mv(NB}(7He^7L2A)0j`;Y@yv&mL_*-nHML9W{Nw-)F5{rsc zZ*i0s<v>_$#mO0|xv96<<Dm?W_+n_Vv)*DUPR&WX#hICxl3Ed8T9k8(9V&N=r?faV zJ|(dvwInk)HHsUeq9C!Tq<AIcEzbD(<ebFf;`sQL48IzjtztrpQ;UjYQgc!=i(>rq zQeBEN%Tg6|6+-<y!(4-cJwqIW6+Hc1{QX>mJso3$U431HLtKLt%whrpd}0z!baV34 zGmA?yvtv^8%3^#nlVXZ9OHy?U5|gtN(^HFM3Nj1y<1_P0Qj78ubM*5dDM}v_F?t1+ zMcfPw3=*LH!vP9gCLTr}Mh?a*Y0QY#g9TSIC;~u=K^T-dLD(5Rp9)G(GXHZv9T zc`-CG)-Yr-)iBmDr7(bC8e1)E33C?90@fPVg^aaqRTiMknaNnoUc->Zmc?GfR>NGw z4oY#oEVUdZ95o!xjEoF5EHw=AoHYy!xN11ExEC^pGXyiRFqH6AE@Nb<<z!^2(yHOi z;w`QN*;m51fIo#5#Lp6_VOz+|$k4<P&Jf9v!cfau$C<|kp$!-e7{JMa&992bIX|x? zHLpY$lvk=aN>VFIK%o<&$$X0?C9x#&7JEi&VoGXJ@h!IElA_ea+$uSbkdOd{R8Uq_ zP%Ty{&&bS4RY*@QDap)BS5Ph16uiZiS)7?yT#}fVoO+A7xTL5^fPsObhzCUQGB7aQ z;wml5Da`{Xu_8f`082rBaY+#yh{;}-T9lMuoO+87EFWK#T3nEySDbo_xhS!`2$T<Q zalpmca`MyDK}k8eD6=FpIWgxJH>3oJPtH$C)#NG?0vXAYkzZVLi#;PTFC{0n=oU{= zYGG+=aY=kqeoAGLB1i=&;g=NOVlFMpDUt>`Qw1c-oLZ4w1WFqaLJ}m#4%I9Vif@oA z1|~j6Ax0iXCPofME=HFBY)l-CY>a%2d>|f3^dAdLl@ylb1T{#L(G7&yLD?}cF*h|n z{uWn!d~SY9X%2|Z6CYn#nwSHXVULeb$xn`t2dCO1J&=QVq1h=pH76%N9^z84o5eu> z0J*t{lYxOj802110CO<1u<)^i#Wcl>j6g=PgF-PgFZ~t|q#V!#hdemGZt+5MN^(wS zYF<ec8-#m{t)#LbGcUb}31kVVFuEmCkXfJy&uDt770Iaupdz~%5@)ig($IXU2Q4v* zKw0XRG<G$mC7C(J;KWhH4zdoEQEzdkr<VADBfm%=B&Z7V2phzew>aUYG1#9-fdUR0 kP@vr6uz`fJ9U~}YK!L@=%)tnP0^mY`hlzzzfQgG40Qk)vM*si- diff --git a/env/Lib/site-packages/pip/_internal/network/auth.py b/env/Lib/site-packages/pip/_internal/network/auth.py index bd54a5cb..94a82fa6 100644 --- a/env/Lib/site-packages/pip/_internal/network/auth.py +++ b/env/Lib/site-packages/pip/_internal/network/auth.py @@ -3,15 +3,24 @@ Contains interface (MultiDomainBasicAuth) and associated glue code for providing credentials in the context of network requests. """ - import logging +import os +import shutil +import subprocess +import sysconfig +import typing import urllib.parse -from typing import Any, Dict, List, Optional, Tuple +from abc import ABC, abstractmethod +from functools import lru_cache +from os.path import commonprefix +from pathlib import Path +from typing import Any, Dict, List, NamedTuple, Optional, Tuple from pip._vendor.requests.auth import AuthBase, HTTPBasicAuth from pip._vendor.requests.models import Request, Response from pip._vendor.requests.utils import get_netrc_auth +from pip._internal.utils.logging import getLogger from pip._internal.utils.misc import ( ask, ask_input, @@ -21,70 +30,256 @@ from pip._internal.utils.misc import ( ) from pip._internal.vcs.versioncontrol import AuthInfo -logger = logging.getLogger(__name__) +logger = getLogger(__name__) + +KEYRING_DISABLED = False + + +class Credentials(NamedTuple): + url: str + username: str + password: str + + +class KeyRingBaseProvider(ABC): + """Keyring base provider interface""" + + has_keyring: bool + + @abstractmethod + def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]: + ... + + @abstractmethod + def save_auth_info(self, url: str, username: str, password: str) -> None: + ... -Credentials = Tuple[str, str, str] -try: - import keyring -except ImportError: - keyring = None -except Exception as exc: - logger.warning( - "Keyring is skipped due to an exception: %s", str(exc), - ) - keyring = None +class KeyRingNullProvider(KeyRingBaseProvider): + """Keyring null provider""" + has_keyring = False -def get_keyring_auth(url, username): - # type: (Optional[str], Optional[str]) -> Optional[AuthInfo] - """Return the tuple auth for a given url from keyring.""" - global keyring - if not url or not keyring: + def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]: return None - try: - try: - get_credential = keyring.get_credential - except AttributeError: - pass - else: + def save_auth_info(self, url: str, username: str, password: str) -> None: + return None + + +class KeyRingPythonProvider(KeyRingBaseProvider): + """Keyring interface which uses locally imported `keyring`""" + + has_keyring = True + + def __init__(self) -> None: + import keyring + + self.keyring = keyring + + def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]: + # Support keyring's get_credential interface which supports getting + # credentials without a username. This is only available for + # keyring>=15.2.0. + if hasattr(self.keyring, "get_credential"): logger.debug("Getting credentials from keyring for %s", url) - cred = get_credential(url, username) + cred = self.keyring.get_credential(url, username) if cred is not None: return cred.username, cred.password return None - if username: + if username is not None: logger.debug("Getting password from keyring for %s", url) - password = keyring.get_password(url, username) + password = self.keyring.get_password(url, username) if password: return username, password + return None + + def save_auth_info(self, url: str, username: str, password: str) -> None: + self.keyring.set_password(url, username, password) + + +class KeyRingCliProvider(KeyRingBaseProvider): + """Provider which uses `keyring` cli + + Instead of calling the keyring package installed alongside pip + we call keyring on the command line which will enable pip to + use which ever installation of keyring is available first in + PATH. + """ + + has_keyring = True + + def __init__(self, cmd: str) -> None: + self.keyring = cmd + + def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]: + # This is the default implementation of keyring.get_credential + # https://github.com/jaraco/keyring/blob/97689324abcf01bd1793d49063e7ca01e03d7d07/keyring/backend.py#L134-L139 + if username is not None: + password = self._get_password(url, username) + if password is not None: + return username, password + return None + + def save_auth_info(self, url: str, username: str, password: str) -> None: + return self._set_password(url, username, password) - except Exception as exc: - logger.warning( - "Keyring is skipped due to an exception: %s", str(exc), + def _get_password(self, service_name: str, username: str) -> Optional[str]: + """Mirror the implementation of keyring.get_password using cli""" + if self.keyring is None: + return None + + cmd = [self.keyring, "get", service_name, username] + env = os.environ.copy() + env["PYTHONIOENCODING"] = "utf-8" + res = subprocess.run( + cmd, + stdin=subprocess.DEVNULL, + stdout=subprocess.PIPE, + env=env, ) - keyring = None - return None + if res.returncode: + return None + return res.stdout.decode("utf-8").strip(os.linesep) + def _set_password(self, service_name: str, username: str, password: str) -> None: + """Mirror the implementation of keyring.set_password using cli""" + if self.keyring is None: + return None + env = os.environ.copy() + env["PYTHONIOENCODING"] = "utf-8" + subprocess.run( + [self.keyring, "set", service_name, username], + input=f"{password}{os.linesep}".encode("utf-8"), + env=env, + check=True, + ) + return None + + +@lru_cache(maxsize=None) +def get_keyring_provider(provider: str) -> KeyRingBaseProvider: + logger.verbose("Keyring provider requested: %s", provider) + + # keyring has previously failed and been disabled + if KEYRING_DISABLED: + provider = "disabled" + if provider in ["import", "auto"]: + try: + impl = KeyRingPythonProvider() + logger.verbose("Keyring provider set: import") + return impl + except ImportError: + pass + except Exception as exc: + # In the event of an unexpected exception + # we should warn the user + msg = "Installed copy of keyring fails with exception %s" + if provider == "auto": + msg = msg + ", trying to find a keyring executable as a fallback" + logger.warning(msg, exc, exc_info=logger.isEnabledFor(logging.DEBUG)) + if provider in ["subprocess", "auto"]: + cli = shutil.which("keyring") + if cli and cli.startswith(sysconfig.get_path("scripts")): + # all code within this function is stolen from shutil.which implementation + @typing.no_type_check + def PATH_as_shutil_which_determines_it() -> str: + path = os.environ.get("PATH", None) + if path is None: + try: + path = os.confstr("CS_PATH") + except (AttributeError, ValueError): + # os.confstr() or CS_PATH is not available + path = os.defpath + # bpo-35755: Don't use os.defpath if the PATH environment variable is + # set to an empty string + + return path + + scripts = Path(sysconfig.get_path("scripts")) + + paths = [] + for path in PATH_as_shutil_which_determines_it().split(os.pathsep): + p = Path(path) + try: + if not p.samefile(scripts): + paths.append(path) + except FileNotFoundError: + pass + + path = os.pathsep.join(paths) + + cli = shutil.which("keyring", path=path) + + if cli: + logger.verbose("Keyring provider set: subprocess with executable %s", cli) + return KeyRingCliProvider(cli) + + logger.verbose("Keyring provider set: disabled") + return KeyRingNullProvider() -class MultiDomainBasicAuth(AuthBase): - def __init__(self, prompting=True, index_urls=None): - # type: (bool, Optional[List[str]]) -> None +class MultiDomainBasicAuth(AuthBase): + def __init__( + self, + prompting: bool = True, + index_urls: Optional[List[str]] = None, + keyring_provider: str = "auto", + ) -> None: self.prompting = prompting self.index_urls = index_urls - self.passwords = {} # type: Dict[str, AuthInfo] + self.keyring_provider = keyring_provider # type: ignore[assignment] + self.passwords: Dict[str, AuthInfo] = {} # When the user is prompted to enter credentials and keyring is # available, we will offer to save them. If the user accepts, # this value is set to the credentials they entered. After the # request authenticates, the caller should call # ``save_credentials`` to save these. - self._credentials_to_save = None # type: Optional[Credentials] + self._credentials_to_save: Optional[Credentials] = None + + @property + def keyring_provider(self) -> KeyRingBaseProvider: + return get_keyring_provider(self._keyring_provider) + + @keyring_provider.setter + def keyring_provider(self, provider: str) -> None: + # The free function get_keyring_provider has been decorated with + # functools.cache. If an exception occurs in get_keyring_auth that + # cache will be cleared and keyring disabled, take that into account + # if you want to remove this indirection. + self._keyring_provider = provider + + @property + def use_keyring(self) -> bool: + # We won't use keyring when --no-input is passed unless + # a specific provider is requested because it might require + # user interaction + return self.prompting or self._keyring_provider not in ["auto", "disabled"] + + def _get_keyring_auth( + self, + url: Optional[str], + username: Optional[str], + ) -> Optional[AuthInfo]: + """Return the tuple auth for a given url from keyring.""" + # Do nothing if no url was provided + if not url: + return None + + try: + return self.keyring_provider.get_auth_info(url, username) + except Exception as exc: + logger.warning( + "Keyring is skipped due to an exception: %s", + str(exc), + ) + global KEYRING_DISABLED + KEYRING_DISABLED = True + get_keyring_provider.cache_clear() + return None - def _get_index_url(self, url): - # type: (str) -> Optional[str] + def _get_index_url(self, url: str) -> Optional[str]: """Return the original index URL matching the requested URL. Cached or dynamically generated credentials may work against @@ -100,15 +295,45 @@ class MultiDomainBasicAuth(AuthBase): if not url or not self.index_urls: return None - for u in self.index_urls: - prefix = remove_auth_from_url(u).rstrip("/") + "/" - if url.startswith(prefix): - return u - return None + url = remove_auth_from_url(url).rstrip("/") + "/" + parsed_url = urllib.parse.urlsplit(url) - def _get_new_credentials(self, original_url, allow_netrc=True, - allow_keyring=False): - # type: (str, bool, bool) -> AuthInfo + candidates = [] + + for index in self.index_urls: + index = index.rstrip("/") + "/" + parsed_index = urllib.parse.urlsplit(remove_auth_from_url(index)) + if parsed_url == parsed_index: + return index + + if parsed_url.netloc != parsed_index.netloc: + continue + + candidate = urllib.parse.urlsplit(index) + candidates.append(candidate) + + if not candidates: + return None + + candidates.sort( + reverse=True, + key=lambda candidate: commonprefix( + [ + parsed_url.path, + candidate.path, + ] + ).rfind("/"), + ) + + return urllib.parse.urlunsplit(candidates[0]) + + def _get_new_credentials( + self, + original_url: str, + *, + allow_netrc: bool = True, + allow_keyring: bool = False, + ) -> AuthInfo: """Find and return credentials for the specified URL.""" # Split the credentials and netloc from the url. url, netloc, url_user_password = split_auth_netloc_from_url( @@ -147,18 +372,21 @@ class MultiDomainBasicAuth(AuthBase): # If we don't have a password and keyring is available, use it. if allow_keyring: # The index url is more specific than the netloc, so try it first + # fmt: off kr_auth = ( - get_keyring_auth(index_url, username) or - get_keyring_auth(netloc, username) + self._get_keyring_auth(index_url, username) or + self._get_keyring_auth(netloc, username) ) + # fmt: on if kr_auth: logger.debug("Found credentials in keyring for %s", netloc) return kr_auth return username, password - def _get_url_and_credentials(self, original_url): - # type: (str) -> Tuple[str, Optional[str], Optional[str]] + def _get_url_and_credentials( + self, original_url: str + ) -> Tuple[str, Optional[str], Optional[str]]: """Return the credentials to use for the provided URL. If allowed, netrc and keyring may be used to obtain the @@ -170,13 +398,19 @@ class MultiDomainBasicAuth(AuthBase): """ url, netloc, _ = split_auth_netloc_from_url(original_url) - # Use any stored credentials that we have for this netloc - username, password = self.passwords.get(netloc, (None, None)) + # Try to get credentials from original url + username, password = self._get_new_credentials(original_url) - if username is None and password is None: - # No stored credentials. Acquire new credentials without prompting - # the user. (e.g. from netrc, keyring, or the URL itself) - username, password = self._get_new_credentials(original_url) + # If credentials not found, use any stored credentials for this netloc. + # Do this if either the username or the password is missing. + # This accounts for the situation in which the user has specified + # the username in the index url, but the password comes from keyring. + if (username is None or password is None) and netloc in self.passwords: + un, pw = self.passwords[netloc] + # It is possible that the cached credentials are for a different username, + # in which case the cache should be ignored. + if username is None or username == un: + username, password = un, pw if username is not None or password is not None: # Convert the username and password if they're None, so that @@ -191,15 +425,14 @@ class MultiDomainBasicAuth(AuthBase): assert ( # Credentials were found - (username is not None and password is not None) or + (username is not None and password is not None) # Credentials were not found - (username is None and password is None) + or (username is None and password is None) ), f"Could not load credentials from url: {original_url}" return url, username, password - def __call__(self, req): - # type: (Request) -> Request + def __call__(self, req: Request) -> Request: # Get credentials for this request url, username, password = self._get_url_and_credentials(req.url) @@ -216,42 +449,51 @@ class MultiDomainBasicAuth(AuthBase): return req # Factored out to allow for easy patching in tests - def _prompt_for_password(self, netloc): - # type: (str) -> Tuple[Optional[str], Optional[str], bool] - username = ask_input(f"User for {netloc}: ") + def _prompt_for_password( + self, netloc: str + ) -> Tuple[Optional[str], Optional[str], bool]: + username = ask_input(f"User for {netloc}: ") if self.prompting else None if not username: return None, None, False - auth = get_keyring_auth(netloc, username) - if auth and auth[0] is not None and auth[1] is not None: - return auth[0], auth[1], False + if self.use_keyring: + auth = self._get_keyring_auth(netloc, username) + if auth and auth[0] is not None and auth[1] is not None: + return auth[0], auth[1], False password = ask_password("Password: ") return username, password, True # Factored out to allow for easy patching in tests - def _should_save_password_to_keyring(self): - # type: () -> bool - if not keyring: + def _should_save_password_to_keyring(self) -> bool: + if ( + not self.prompting + or not self.use_keyring + or not self.keyring_provider.has_keyring + ): return False return ask("Save credentials to keyring [y/N]: ", ["y", "n"]) == "y" - def handle_401(self, resp, **kwargs): - # type: (Response, **Any) -> Response + def handle_401(self, resp: Response, **kwargs: Any) -> Response: # We only care about 401 responses, anything else we want to just # pass through the actual response if resp.status_code != 401: return resp + username, password = None, None + + # Query the keyring for credentials: + if self.use_keyring: + username, password = self._get_new_credentials( + resp.url, + allow_netrc=False, + allow_keyring=True, + ) + # We are not able to prompt the user so simply return the response - if not self.prompting: + if not self.prompting and not username and not password: return resp parsed = urllib.parse.urlparse(resp.url) - # Query the keyring for credentials: - username, password = self._get_new_credentials(resp.url, - allow_netrc=False, - allow_keyring=True) - # Prompt the user for a new username and password save = False if not username and not password: @@ -264,11 +506,17 @@ class MultiDomainBasicAuth(AuthBase): # Prompt to save the password to keyring if save and self._should_save_password_to_keyring(): - self._credentials_to_save = (parsed.netloc, username, password) + self._credentials_to_save = Credentials( + url=parsed.netloc, + username=username, + password=password, + ) # Consume content and release the original connection to allow our new # request to reuse the same one. - resp.content + # The result of the assignment isn't used, it's just needed to consume + # the content. + _ = resp.content resp.raw.release_conn() # Add our new username and password to the request @@ -287,26 +535,27 @@ class MultiDomainBasicAuth(AuthBase): return new_resp - def warn_on_401(self, resp, **kwargs): - # type: (Response, **Any) -> None + def warn_on_401(self, resp: Response, **kwargs: Any) -> None: """Response callback to warn about incorrect credentials.""" if resp.status_code == 401: logger.warning( - '401 Error, Credentials not correct for %s', resp.request.url, + "401 Error, Credentials not correct for %s", + resp.request.url, ) - def save_credentials(self, resp, **kwargs): - # type: (Response, **Any) -> None + def save_credentials(self, resp: Response, **kwargs: Any) -> None: """Response callback to save credentials on success.""" - assert keyring is not None, "should never reach here without keyring" - if not keyring: - return + assert ( + self.keyring_provider.has_keyring + ), "should never reach here without keyring" creds = self._credentials_to_save self._credentials_to_save = None if creds and resp.status_code < 400: try: - logger.info('Saving credentials to keyring') - keyring.set_password(*creds) + logger.info("Saving credentials to keyring") + self.keyring_provider.save_auth_info( + creds.url, creds.username, creds.password + ) except Exception: - logger.exception('Failed to save credentials') + logger.exception("Failed to save credentials") diff --git a/env/Lib/site-packages/pip/_internal/network/cache.py b/env/Lib/site-packages/pip/_internal/network/cache.py index ce08932a..a81a2398 100644 --- a/env/Lib/site-packages/pip/_internal/network/cache.py +++ b/env/Lib/site-packages/pip/_internal/network/cache.py @@ -3,7 +3,7 @@ import os from contextlib import contextmanager -from typing import Iterator, Optional +from typing import Generator, Optional from pip._vendor.cachecontrol.cache import BaseCache from pip._vendor.cachecontrol.caches import FileCache @@ -13,14 +13,12 @@ from pip._internal.utils.filesystem import adjacent_tmp_file, replace from pip._internal.utils.misc import ensure_dir -def is_from_cache(response): - # type: (Response) -> bool +def is_from_cache(response: Response) -> bool: return getattr(response, "from_cache", False) @contextmanager -def suppressed_cache_errors(): - # type: () -> Iterator[None] +def suppressed_cache_errors() -> Generator[None, None, None]: """If we can't access the cache then we can just skip caching and process requests as if caching wasn't enabled. """ @@ -36,14 +34,12 @@ class SafeFileCache(BaseCache): not be accessible or writable. """ - def __init__(self, directory): - # type: (str) -> None + def __init__(self, directory: str) -> None: assert directory is not None, "Cache directory must not be None." super().__init__() self.directory = directory - def _get_cache_path(self, name): - # type: (str) -> str + def _get_cache_path(self, name: str) -> str: # From cachecontrol.caches.file_cache.FileCache._fn, brought into our # class for backwards-compatibility and to avoid using a non-public # method. @@ -51,15 +47,13 @@ class SafeFileCache(BaseCache): parts = list(hashed[:5]) + [hashed] return os.path.join(self.directory, *parts) - def get(self, key): - # type: (str) -> Optional[bytes] + def get(self, key: str) -> Optional[bytes]: path = self._get_cache_path(key) with suppressed_cache_errors(): - with open(path, 'rb') as f: + with open(path, "rb") as f: return f.read() - def set(self, key, value): - # type: (str, bytes) -> None + def set(self, key: str, value: bytes, expires: Optional[int] = None) -> None: path = self._get_cache_path(key) with suppressed_cache_errors(): ensure_dir(os.path.dirname(path)) @@ -69,8 +63,7 @@ class SafeFileCache(BaseCache): replace(f.name, path) - def delete(self, key): - # type: (str) -> None + def delete(self, key: str) -> None: path = self._get_cache_path(key) with suppressed_cache_errors(): os.remove(path) diff --git a/env/Lib/site-packages/pip/_internal/network/download.py b/env/Lib/site-packages/pip/_internal/network/download.py index 1897d99a..79b82a57 100644 --- a/env/Lib/site-packages/pip/_internal/network/download.py +++ b/env/Lib/site-packages/pip/_internal/network/download.py @@ -1,6 +1,6 @@ """Download files with progress indicators. """ -import cgi +import email.message import logging import mimetypes import os @@ -8,7 +8,7 @@ from typing import Iterable, Optional, Tuple from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response -from pip._internal.cli.progress_bars import DownloadProgressProvider +from pip._internal.cli.progress_bars import get_download_progress_renderer from pip._internal.exceptions import NetworkConnectionError from pip._internal.models.index import PyPI from pip._internal.models.link import Link @@ -20,20 +20,18 @@ from pip._internal.utils.misc import format_size, redact_auth_from_url, splitext logger = logging.getLogger(__name__) -def _get_http_response_size(resp): - # type: (Response) -> Optional[int] +def _get_http_response_size(resp: Response) -> Optional[int]: try: - return int(resp.headers['content-length']) + return int(resp.headers["content-length"]) except (ValueError, KeyError, TypeError): return None def _prepare_download( - resp, # type: Response - link, # type: Link - progress_bar # type: str -): - # type: (...) -> Iterable[bytes] + resp: Response, + link: Link, + progress_bar: str, +) -> Iterable[bytes]: total_length = _get_http_response_size(resp) if link.netloc == PyPI.file_storage_domain: @@ -44,7 +42,7 @@ def _prepare_download( logged_url = redact_auth_from_url(url) if total_length: - logged_url = '{} ({})'.format(logged_url, format_size(total_length)) + logged_url = "{} ({})".format(logged_url, format_size(total_length)) if is_from_cache(resp): logger.info("Using cached %s", logged_url) @@ -67,49 +65,44 @@ def _prepare_download( if not show_progress: return chunks - return DownloadProgressProvider( - progress_bar, max=total_length - )(chunks) + renderer = get_download_progress_renderer(bar_type=progress_bar, size=total_length) + return renderer(chunks) -def sanitize_content_filename(filename): - # type: (str) -> str +def sanitize_content_filename(filename: str) -> str: """ Sanitize the "filename" value from a Content-Disposition header. """ return os.path.basename(filename) -def parse_content_disposition(content_disposition, default_filename): - # type: (str, str) -> str +def parse_content_disposition(content_disposition: str, default_filename: str) -> str: """ Parse the "filename" value from a Content-Disposition header, and return the default filename if the result is empty. """ - _type, params = cgi.parse_header(content_disposition) - filename = params.get('filename') + m = email.message.Message() + m["content-type"] = content_disposition + filename = m.get_param("filename") if filename: # We need to sanitize the filename to prevent directory traversal # in case the filename contains ".." path parts. - filename = sanitize_content_filename(filename) + filename = sanitize_content_filename(str(filename)) return filename or default_filename -def _get_http_response_filename(resp, link): - # type: (Response, Link) -> str +def _get_http_response_filename(resp: Response, link: Link) -> str: """Get an ideal filename from the given HTTP response, falling back to the link filename if not provided. """ filename = link.filename # fallback # Have a look at the Content-Disposition header for a better guess - content_disposition = resp.headers.get('content-disposition') + content_disposition = resp.headers.get("content-disposition") if content_disposition: filename = parse_content_disposition(content_disposition, filename) - ext = splitext(filename)[1] # type: Optional[str] + ext: Optional[str] = splitext(filename)[1] if not ext: - ext = mimetypes.guess_extension( - resp.headers.get('content-type', '') - ) + ext = mimetypes.guess_extension(resp.headers.get("content-type", "")) if ext: filename += ext if not ext and link.url != resp.url: @@ -119,9 +112,8 @@ def _get_http_response_filename(resp, link): return filename -def _http_get_download(session, link): - # type: (PipSession, Link) -> Response - target_url = link.url.split('#', 1)[0] +def _http_get_download(session: PipSession, link: Link) -> Response: + target_url = link.url.split("#", 1)[0] resp = session.get(target_url, headers=HEADERS, stream=True) raise_for_status(resp) return resp @@ -130,15 +122,13 @@ def _http_get_download(session, link): class Downloader: def __init__( self, - session, # type: PipSession - progress_bar, # type: str - ): - # type: (...) -> None + session: PipSession, + progress_bar: str, + ) -> None: self._session = session self._progress_bar = progress_bar - def __call__(self, link, location): - # type: (Link, str) -> Tuple[str, str] + def __call__(self, link: Link, location: str) -> Tuple[str, str]: """Download the file given by link into location.""" try: resp = _http_get_download(self._session, link) @@ -153,26 +143,25 @@ class Downloader: filepath = os.path.join(location, filename) chunks = _prepare_download(resp, link, self._progress_bar) - with open(filepath, 'wb') as content_file: + with open(filepath, "wb") as content_file: for chunk in chunks: content_file.write(chunk) - content_type = resp.headers.get('Content-Type', '') + content_type = resp.headers.get("Content-Type", "") return filepath, content_type class BatchDownloader: - def __init__( self, - session, # type: PipSession - progress_bar, # type: str - ): - # type: (...) -> None + session: PipSession, + progress_bar: str, + ) -> None: self._session = session self._progress_bar = progress_bar - def __call__(self, links, location): - # type: (Iterable[Link], str) -> Iterable[Tuple[Link, Tuple[str, str]]] + def __call__( + self, links: Iterable[Link], location: str + ) -> Iterable[Tuple[Link, Tuple[str, str]]]: """Download the files given by links into location.""" for link in links: try: @@ -181,7 +170,8 @@ class BatchDownloader: assert e.response is not None logger.critical( "HTTP error %s while getting %s", - e.response.status_code, link, + e.response.status_code, + link, ) raise @@ -189,8 +179,8 @@ class BatchDownloader: filepath = os.path.join(location, filename) chunks = _prepare_download(resp, link, self._progress_bar) - with open(filepath, 'wb') as content_file: + with open(filepath, "wb") as content_file: for chunk in chunks: content_file.write(chunk) - content_type = resp.headers.get('Content-Type', '') + content_type = resp.headers.get("Content-Type", "") yield link, (filepath, content_type) diff --git a/env/Lib/site-packages/pip/_internal/network/lazy_wheel.py b/env/Lib/site-packages/pip/_internal/network/lazy_wheel.py index b877d3b7..82ec50d5 100644 --- a/env/Lib/site-packages/pip/_internal/network/lazy_wheel.py +++ b/env/Lib/site-packages/pip/_internal/network/lazy_wheel.py @@ -1,41 +1,40 @@ """Lazy ZIP over HTTP""" -__all__ = ['HTTPRangeRequestUnsupported', 'dist_from_wheel_url'] +__all__ = ["HTTPRangeRequestUnsupported", "dist_from_wheel_url"] from bisect import bisect_left, bisect_right from contextlib import contextmanager from tempfile import NamedTemporaryFile -from typing import Any, Dict, Iterator, List, Optional, Tuple -from zipfile import BadZipfile, ZipFile +from typing import Any, Dict, Generator, List, Optional, Tuple +from zipfile import BadZipFile, ZipFile -from pip._vendor.pkg_resources import Distribution +from pip._vendor.packaging.utils import canonicalize_name from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response +from pip._internal.metadata import BaseDistribution, MemoryWheel, get_wheel_distribution from pip._internal.network.session import PipSession from pip._internal.network.utils import HEADERS, raise_for_status, response_chunks -from pip._internal.utils.wheel import pkg_resources_distribution_for_wheel class HTTPRangeRequestUnsupported(Exception): pass -def dist_from_wheel_url(name, url, session): - # type: (str, str, PipSession) -> Distribution - """Return a pkg_resources.Distribution from the given wheel URL. +def dist_from_wheel_url(name: str, url: str, session: PipSession) -> BaseDistribution: + """Return a distribution object from the given wheel URL. - This uses HTTP range requests to only fetch the potion of the wheel + This uses HTTP range requests to only fetch the portion of the wheel containing metadata, just enough for the object to be constructed. If such requests are not supported, HTTPRangeRequestUnsupported is raised. """ - with LazyZipOverHTTP(url, session) as wheel: + with LazyZipOverHTTP(url, session) as zf: # For read-only ZIP files, ZipFile only needs methods read, # seek, seekable and tell, not the whole IO protocol. - zip_file = ZipFile(wheel) # type: ignore + wheel = MemoryWheel(zf.name, zf) # type: ignore # After context manager exit, wheel.name # is an invalid file by intention. - return pkg_resources_distribution_for_wheel(zip_file, name, wheel.name) + return get_wheel_distribution(wheel, canonicalize_name(name)) class LazyZipOverHTTP: @@ -47,51 +46,46 @@ class LazyZipOverHTTP: during initialization. """ - def __init__(self, url, session, chunk_size=CONTENT_CHUNK_SIZE): - # type: (str, PipSession, int) -> None + def __init__( + self, url: str, session: PipSession, chunk_size: int = CONTENT_CHUNK_SIZE + ) -> None: head = session.head(url, headers=HEADERS) raise_for_status(head) assert head.status_code == 200 self._session, self._url, self._chunk_size = session, url, chunk_size - self._length = int(head.headers['Content-Length']) + self._length = int(head.headers["Content-Length"]) self._file = NamedTemporaryFile() self.truncate(self._length) - self._left = [] # type: List[int] - self._right = [] # type: List[int] - if 'bytes' not in head.headers.get('Accept-Ranges', 'none'): - raise HTTPRangeRequestUnsupported('range request is not supported') + self._left: List[int] = [] + self._right: List[int] = [] + if "bytes" not in head.headers.get("Accept-Ranges", "none"): + raise HTTPRangeRequestUnsupported("range request is not supported") self._check_zip() @property - def mode(self): - # type: () -> str + def mode(self) -> str: """Opening mode, which is always rb.""" - return 'rb' + return "rb" @property - def name(self): - # type: () -> str + def name(self) -> str: """Path to the underlying file.""" return self._file.name - def seekable(self): - # type: () -> bool + def seekable(self) -> bool: """Return whether random access is supported, which is True.""" return True - def close(self): - # type: () -> None + def close(self) -> None: """Close the file.""" self._file.close() @property - def closed(self): - # type: () -> bool + def closed(self) -> bool: """Whether the file is closed.""" return self._file.closed - def read(self, size=-1): - # type: (int) -> bytes + def read(self, size: int = -1) -> bytes: """Read up to size bytes from the object and return them. As a convenience, if size is unspecified or -1, @@ -100,18 +94,16 @@ class LazyZipOverHTTP: """ download_size = max(size, self._chunk_size) start, length = self.tell(), self._length - stop = length if size < 0 else min(start+download_size, length) - start = max(0, stop-download_size) - self._download(start, stop-1) + stop = length if size < 0 else min(start + download_size, length) + start = max(0, stop - download_size) + self._download(start, stop - 1) return self._file.read(size) - def readable(self): - # type: () -> bool + def readable(self) -> bool: """Return whether the file is readable, which is True.""" return True - def seek(self, offset, whence=0): - # type: (int, int) -> int + def seek(self, offset: int, whence: int = 0) -> int: """Change stream position and return the new absolute position. Seek to offset relative position indicated by whence: @@ -121,13 +113,11 @@ class LazyZipOverHTTP: """ return self._file.seek(offset, whence) - def tell(self): - # type: () -> int - """Return the current possition.""" + def tell(self) -> int: + """Return the current position.""" return self._file.tell() - def truncate(self, size=None): - # type: (Optional[int]) -> int + def truncate(self, size: Optional[int] = None) -> int: """Resize the stream to the given size in bytes. If size is unspecified resize to the current position. @@ -137,23 +127,19 @@ class LazyZipOverHTTP: """ return self._file.truncate(size) - def writable(self): - # type: () -> bool + def writable(self) -> bool: """Return False.""" return False - def __enter__(self): - # type: () -> LazyZipOverHTTP + def __enter__(self) -> "LazyZipOverHTTP": self._file.__enter__() return self - def __exit__(self, *exc): - # type: (*Any) -> Optional[bool] - return self._file.__exit__(*exc) + def __exit__(self, *exc: Any) -> None: + self._file.__exit__(*exc) @contextmanager - def _stay(self): - # type: ()-> Iterator[None] + def _stay(self) -> Generator[None, None, None]: """Return a context manager keeping the position. At the end of the block, seek back to original position. @@ -164,8 +150,7 @@ class LazyZipOverHTTP: finally: self.seek(pos) - def _check_zip(self): - # type: () -> None + def _check_zip(self) -> None: """Check and download until the file is a valid ZIP.""" end = self._length - 1 for start in reversed(range(0, end, self._chunk_size)): @@ -175,23 +160,25 @@ class LazyZipOverHTTP: # For read-only ZIP files, ZipFile only needs # methods read, seek, seekable and tell. ZipFile(self) # type: ignore - except BadZipfile: + except BadZipFile: pass else: break - def _stream_response(self, start, end, base_headers=HEADERS): - # type: (int, int, Dict[str, str]) -> Response + def _stream_response( + self, start: int, end: int, base_headers: Dict[str, str] = HEADERS + ) -> Response: """Return HTTP response to a range request from start to end.""" headers = base_headers.copy() - headers['Range'] = f'bytes={start}-{end}' + headers["Range"] = f"bytes={start}-{end}" # TODO: Get range requests to be correctly cached - headers['Cache-Control'] = 'no-cache' + headers["Cache-Control"] = "no-cache" return self._session.get(self._url, headers=headers, stream=True) - def _merge(self, start, end, left, right): - # type: (int, int, int, int) -> Iterator[Tuple[int, int]] - """Return an iterator of intervals to be fetched. + def _merge( + self, start: int, end: int, left: int, right: int + ) -> Generator[Tuple[int, int], None, None]: + """Return a generator of intervals to be fetched. Args: start (int): Start of needed interval @@ -200,18 +187,17 @@ class LazyZipOverHTTP: right (int): Index after last overlapping downloaded data """ lslice, rslice = self._left[left:right], self._right[left:right] - i = start = min([start]+lslice[:1]) - end = max([end]+rslice[-1:]) + i = start = min([start] + lslice[:1]) + end = max([end] + rslice[-1:]) for j, k in zip(lslice, rslice): if j > i: - yield i, j-1 + yield i, j - 1 i = k + 1 if i <= end: yield i, end self._left[left:right], self._right[left:right] = [start], [end] - def _download(self, start, end): - # type: (int, int) -> None + def _download(self, start: int, end: int) -> None: """Download bytes from start to end inclusively.""" with self._stay(): left = bisect_left(self._right, start) diff --git a/env/Lib/site-packages/pip/_internal/network/session.py b/env/Lib/site-packages/pip/_internal/network/session.py index 4af800f1..887dc14e 100644 --- a/env/Lib/site-packages/pip/_internal/network/session.py +++ b/env/Lib/site-packages/pip/_internal/network/session.py @@ -2,31 +2,36 @@ network request configuration and behavior. """ -# When mypy runs on Windows the call to distro.linux_distribution() is skipped -# resulting in the failure: -# -# error: unused 'type: ignore' comment -# -# If the upstream module adds typing, this comment should be removed. See -# https://github.com/nir0s/distro/pull/269 -# -# mypy: warn-unused-ignores=False - import email.utils +import io import ipaddress import json import logging import mimetypes import os import platform +import shutil +import subprocess import sys import urllib.parse import warnings -from typing import Any, Dict, Iterator, List, Mapping, Optional, Sequence, Tuple, Union +from typing import ( + TYPE_CHECKING, + Any, + Dict, + Generator, + List, + Mapping, + Optional, + Sequence, + Tuple, + Union, +) from pip._vendor import requests, urllib3 -from pip._vendor.cachecontrol import CacheControlAdapter -from pip._vendor.requests.adapters import BaseAdapter, HTTPAdapter +from pip._vendor.cachecontrol import CacheControlAdapter as _BaseCacheControlAdapter +from pip._vendor.requests.adapters import DEFAULT_POOLBLOCK, BaseAdapter +from pip._vendor.requests.adapters import HTTPAdapter as _BaseHTTPAdapter from pip._vendor.requests.models import PreparedRequest, Response from pip._vendor.requests.structures import CaseInsensitiveDict from pip._vendor.urllib3.connectionpool import ConnectionPool @@ -44,6 +49,12 @@ from pip._internal.utils.glibc import libc_ver from pip._internal.utils.misc import build_url_from_netloc, parse_netloc from pip._internal.utils.urls import url_to_path +if TYPE_CHECKING: + from ssl import SSLContext + + from pip._vendor.urllib3.poolmanager import PoolManager + + logger = logging.getLogger(__name__) SecureOrigin = Tuple[str, str, Optional[Union[int, str]]] @@ -53,7 +64,7 @@ SecureOrigin = Tuple[str, str, Optional[Union[int, str]]] warnings.filterwarnings("ignore", category=InsecureRequestWarning) -SECURE_ORIGINS = [ +SECURE_ORIGINS: List[SecureOrigin] = [ # protocol, hostname, port # Taken from Chrome's list of secure origins (See: http://bit.ly/1qrySKC) ("https", "*", "*"), @@ -63,7 +74,7 @@ SECURE_ORIGINS = [ ("file", "*", None), # ssh is always secure. ("ssh", "*", "*"), -] # type: List[SecureOrigin] +] # These are environment variables present when running under various @@ -75,18 +86,17 @@ SECURE_ORIGINS = [ # For more background, see: https://github.com/pypa/pip/issues/5499 CI_ENVIRONMENT_VARIABLES = ( # Azure Pipelines - 'BUILD_BUILDID', + "BUILD_BUILDID", # Jenkins - 'BUILD_ID', + "BUILD_ID", # AppVeyor, CircleCI, Codeship, Gitlab CI, Shippable, Travis CI - 'CI', + "CI", # Explicit environment variable. - 'PIP_IS_CI', + "PIP_IS_CI", ) -def looks_like_ci(): - # type: () -> bool +def looks_like_ci() -> bool: """ Return whether it looks like pip is running under CI. """ @@ -96,48 +106,50 @@ def looks_like_ci(): return any(name in os.environ for name in CI_ENVIRONMENT_VARIABLES) -def user_agent(): - # type: () -> str +def user_agent() -> str: """ Return a string representing the user agent. """ - data = { + data: Dict[str, Any] = { "installer": {"name": "pip", "version": __version__}, "python": platform.python_version(), "implementation": { "name": platform.python_implementation(), }, - } # type: Dict[str, Any] + } - if data["implementation"]["name"] == 'CPython': + if data["implementation"]["name"] == "CPython": data["implementation"]["version"] = platform.python_version() - elif data["implementation"]["name"] == 'PyPy': + elif data["implementation"]["name"] == "PyPy": pypy_version_info = sys.pypy_version_info # type: ignore - if pypy_version_info.releaselevel == 'final': + if pypy_version_info.releaselevel == "final": pypy_version_info = pypy_version_info[:3] data["implementation"]["version"] = ".".join( [str(x) for x in pypy_version_info] ) - elif data["implementation"]["name"] == 'Jython': + elif data["implementation"]["name"] == "Jython": # Complete Guess data["implementation"]["version"] = platform.python_version() - elif data["implementation"]["name"] == 'IronPython': + elif data["implementation"]["name"] == "IronPython": # Complete Guess data["implementation"]["version"] = platform.python_version() if sys.platform.startswith("linux"): from pip._vendor import distro - # https://github.com/nir0s/distro/pull/269 - linux_distribution = distro.linux_distribution() # type: ignore - distro_infos = dict(filter( - lambda x: x[1], - zip(["name", "version", "id"], linux_distribution), - )) - libc = dict(filter( - lambda x: x[1], - zip(["lib", "version"], libc_ver()), - )) + linux_distribution = distro.name(), distro.version(), distro.codename() + distro_infos: Dict[str, Any] = dict( + filter( + lambda x: x[1], + zip(["name", "version", "id"], linux_distribution), + ) + ) + libc = dict( + filter( + lambda x: x[1], + zip(["lib", "version"], libc_ver()), + ) + ) if libc: distro_infos["libc"] = libc if distro_infos: @@ -157,12 +169,28 @@ def user_agent(): if has_tls(): import _ssl as ssl + data["openssl_version"] = ssl.OPENSSL_VERSION setuptools_dist = get_default_environment().get_distribution("setuptools") if setuptools_dist is not None: data["setuptools_version"] = str(setuptools_dist.version) + if shutil.which("rustc") is not None: + # If for any reason `rustc --version` fails, silently ignore it + try: + rustc_output = subprocess.check_output( + ["rustc", "--version"], stderr=subprocess.STDOUT, timeout=0.5 + ) + except Exception: + pass + else: + if rustc_output.startswith(b"rustc "): + # The format of `rustc --version` is: + # `b'rustc 1.52.1 (9bc8c42bb 2021-05-09)\n'` + # We extract just the middle (1.52.1) part + data["rustc_version"] = rustc_output.split(b" ")[1].decode() + # Use None rather than False so as not to give the impression that # pip knows it is not being run under CI. Rather, it is a null or # inconclusive result. Also, we include some value rather than no @@ -180,17 +208,15 @@ def user_agent(): class LocalFSAdapter(BaseAdapter): - def send( self, - request, # type: PreparedRequest - stream=False, # type: bool - timeout=None, # type: Optional[Union[float, Tuple[float, float]]] - verify=True, # type: Union[bool, str] - cert=None, # type: Optional[Union[str, Tuple[str, str]]] - proxies=None, # type:Optional[Mapping[str, str]] - ): - # type: (...) -> Response + request: PreparedRequest, + stream: bool = False, + timeout: Optional[Union[float, Tuple[float, float]]] = None, + verify: Union[bool, str] = True, + cert: Optional[Union[str, Tuple[str, str]]] = None, + proxies: Optional[Mapping[str, str]] = None, + ) -> Response: pathname = url_to_path(request.url) resp = Response() @@ -200,67 +226,108 @@ class LocalFSAdapter(BaseAdapter): try: stats = os.stat(pathname) except OSError as exc: + # format the exception raised as a io.BytesIO object, + # to return a better error message: resp.status_code = 404 - resp.raw = exc + resp.reason = type(exc).__name__ + resp.raw = io.BytesIO(f"{resp.reason}: {exc}".encode("utf8")) else: modified = email.utils.formatdate(stats.st_mtime, usegmt=True) content_type = mimetypes.guess_type(pathname)[0] or "text/plain" - resp.headers = CaseInsensitiveDict({ - "Content-Type": content_type, - "Content-Length": stats.st_size, - "Last-Modified": modified, - }) + resp.headers = CaseInsensitiveDict( + { + "Content-Type": content_type, + "Content-Length": stats.st_size, + "Last-Modified": modified, + } + ) resp.raw = open(pathname, "rb") resp.close = resp.raw.close return resp - def close(self): - # type: () -> None + def close(self) -> None: pass -class InsecureHTTPAdapter(HTTPAdapter): +class _SSLContextAdapterMixin: + """Mixin to add the ``ssl_context`` constructor argument to HTTP adapters. + + The additional argument is forwarded directly to the pool manager. This allows us + to dynamically decide what SSL store to use at runtime, which is used to implement + the optional ``truststore`` backend. + """ + + def __init__( + self, + *, + ssl_context: Optional["SSLContext"] = None, + **kwargs: Any, + ) -> None: + self._ssl_context = ssl_context + super().__init__(**kwargs) + + def init_poolmanager( + self, + connections: int, + maxsize: int, + block: bool = DEFAULT_POOLBLOCK, + **pool_kwargs: Any, + ) -> "PoolManager": + if self._ssl_context is not None: + pool_kwargs.setdefault("ssl_context", self._ssl_context) + return super().init_poolmanager( # type: ignore[misc] + connections=connections, + maxsize=maxsize, + block=block, + **pool_kwargs, + ) + + +class HTTPAdapter(_SSLContextAdapterMixin, _BaseHTTPAdapter): + pass + +class CacheControlAdapter(_SSLContextAdapterMixin, _BaseCacheControlAdapter): + pass + + +class InsecureHTTPAdapter(HTTPAdapter): def cert_verify( self, - conn, # type: ConnectionPool - url, # type: str - verify, # type: Union[bool, str] - cert, # type: Optional[Union[str, Tuple[str, str]]] - ): - # type: (...) -> None + conn: ConnectionPool, + url: str, + verify: Union[bool, str], + cert: Optional[Union[str, Tuple[str, str]]], + ) -> None: super().cert_verify(conn=conn, url=url, verify=False, cert=cert) class InsecureCacheControlAdapter(CacheControlAdapter): - def cert_verify( self, - conn, # type: ConnectionPool - url, # type: str - verify, # type: Union[bool, str] - cert, # type: Optional[Union[str, Tuple[str, str]]] - ): - # type: (...) -> None + conn: ConnectionPool, + url: str, + verify: Union[bool, str], + cert: Optional[Union[str, Tuple[str, str]]], + ) -> None: super().cert_verify(conn=conn, url=url, verify=False, cert=cert) class PipSession(requests.Session): - - timeout = None # type: Optional[int] + timeout: Optional[int] = None def __init__( self, - *args, # type: Any - retries=0, # type: int - cache=None, # type: Optional[str] - trusted_hosts=(), # type: Sequence[str] - index_urls=None, # type: Optional[List[str]] - **kwargs, # type: Any - ): - # type: (...) -> None + *args: Any, + retries: int = 0, + cache: Optional[str] = None, + trusted_hosts: Sequence[str] = (), + index_urls: Optional[List[str]] = None, + ssl_context: Optional["SSLContext"] = None, + **kwargs: Any, + ) -> None: """ :param trusted_hosts: Domains not to emit warnings for when not using HTTPS. @@ -269,7 +336,7 @@ class PipSession(requests.Session): # Namespace the attribute with "pip_" just in case to prevent # possible conflicts with the base class. - self.pip_trusted_origins = [] # type: List[Tuple[str, Optional[int]]] + self.pip_trusted_origins: List[Tuple[str, Optional[int]]] = [] # Attach our User Agent to the request self.headers["User-Agent"] = user_agent() @@ -283,7 +350,6 @@ class PipSession(requests.Session): # Set the total number of retries that a particular request can # have. total=retries, - # A 503 error from PyPI typically means that the Fastly -> Origin # connection got interrupted in some way. A 503 error in general # is typically considered a transient error so we'll go ahead and @@ -291,7 +357,6 @@ class PipSession(requests.Session): # A 500 may indicate transient error in Amazon S3 # A 520 or 527 - may indicate transient error in CloudFlare status_forcelist=[500, 503, 520, 527], - # Add a small amount of back off between failed requests in # order to prevent hammering the service. backoff_factor=0.25, @@ -313,13 +378,14 @@ class PipSession(requests.Session): secure_adapter = CacheControlAdapter( cache=SafeFileCache(cache), max_retries=retries, + ssl_context=ssl_context, ) self._trusted_host_adapter = InsecureCacheControlAdapter( cache=SafeFileCache(cache), max_retries=retries, ) else: - secure_adapter = HTTPAdapter(max_retries=retries) + secure_adapter = HTTPAdapter(max_retries=retries, ssl_context=ssl_context) self._trusted_host_adapter = insecure_adapter self.mount("https://", secure_adapter) @@ -331,16 +397,16 @@ class PipSession(requests.Session): for host in trusted_hosts: self.add_trusted_host(host, suppress_logging=True) - def update_index_urls(self, new_index_urls): - # type: (List[str]) -> None + def update_index_urls(self, new_index_urls: List[str]) -> None: """ :param new_index_urls: New index urls to update the authentication handler with. """ self.auth.index_urls = new_index_urls - def add_trusted_host(self, host, source=None, suppress_logging=False): - # type: (str, Optional[str], bool) -> None + def add_trusted_host( + self, host: str, source: Optional[str] = None, suppress_logging: bool = False + ) -> None: """ :param host: It is okay to provide a host that has previously been added. @@ -348,45 +414,48 @@ class PipSession(requests.Session): string came from. """ if not suppress_logging: - msg = f'adding trusted host: {host!r}' + msg = f"adding trusted host: {host!r}" if source is not None: - msg += f' (from {source})' + msg += f" (from {source})" logger.info(msg) - host_port = parse_netloc(host) - if host_port not in self.pip_trusted_origins: - self.pip_trusted_origins.append(host_port) + parsed_host, parsed_port = parse_netloc(host) + if parsed_host is None: + raise ValueError(f"Trusted host URL must include a host part: {host!r}") + if (parsed_host, parsed_port) not in self.pip_trusted_origins: + self.pip_trusted_origins.append((parsed_host, parsed_port)) self.mount( - build_url_from_netloc(host) + '/', - self._trusted_host_adapter + build_url_from_netloc(host, scheme="http") + "/", self._trusted_host_adapter ) - if not host_port[1]: - # Mount wildcard ports for the same host. + self.mount(build_url_from_netloc(host) + "/", self._trusted_host_adapter) + if not parsed_port: self.mount( - build_url_from_netloc(host) + ':', - self._trusted_host_adapter + build_url_from_netloc(host, scheme="http") + ":", + self._trusted_host_adapter, ) + # Mount wildcard ports for the same host. + self.mount(build_url_from_netloc(host) + ":", self._trusted_host_adapter) - def iter_secure_origins(self): - # type: () -> Iterator[SecureOrigin] + def iter_secure_origins(self) -> Generator[SecureOrigin, None, None]: yield from SECURE_ORIGINS for host, port in self.pip_trusted_origins: - yield ('*', host, '*' if port is None else port) + yield ("*", host, "*" if port is None else port) - def is_secure_origin(self, location): - # type: (Link) -> bool + def is_secure_origin(self, location: Link) -> bool: # Determine if this url used a secure transport mechanism parsed = urllib.parse.urlparse(str(location)) origin_protocol, origin_host, origin_port = ( - parsed.scheme, parsed.hostname, parsed.port, + parsed.scheme, + parsed.hostname, + parsed.port, ) # The protocol to use to see if the protocol matches. # Don't count the repository type as part of the protocol: in # cases such as "git+ssh", only use "ssh". (I.e., Only verify against # the last scheme.) - origin_protocol = origin_protocol.rsplit('+', 1)[-1] + origin_protocol = origin_protocol.rsplit("+", 1)[-1] # Determine if our origin is a secure origin by looking through our # hardcoded list of secure origins, as well as any additional ones @@ -397,15 +466,15 @@ class PipSession(requests.Session): continue try: - addr = ipaddress.ip_address(origin_host) + addr = ipaddress.ip_address(origin_host or "") network = ipaddress.ip_network(secure_host) except ValueError: # We don't have both a valid address or a valid network, so # we'll check this origin against hostnames. if ( - origin_host and - origin_host.lower() != secure_host.lower() and - secure_host != "*" + origin_host + and origin_host.lower() != secure_host.lower() + and secure_host != "*" ): continue else: @@ -416,9 +485,9 @@ class PipSession(requests.Session): # Check to see if the port matches. if ( - origin_port != secure_port and - secure_port != "*" and - secure_port is not None + origin_port != secure_port + and secure_port != "*" + and secure_port is not None ): continue @@ -440,10 +509,11 @@ class PipSession(requests.Session): return False - def request(self, method, url, *args, **kwargs): - # type: (str, str, *Any, **Any) -> Response + def request(self, method: str, url: str, *args: Any, **kwargs: Any) -> Response: # Allow setting a default timeout on a session kwargs.setdefault("timeout", self.timeout) + # Allow setting a default proxies on a session + kwargs.setdefault("proxies", self.proxies) # Dispatch the actual request return super().request(method, url, *args, **kwargs) diff --git a/env/Lib/site-packages/pip/_internal/network/utils.py b/env/Lib/site-packages/pip/_internal/network/utils.py index 6e5cf0d1..134848ae 100644 --- a/env/Lib/site-packages/pip/_internal/network/utils.py +++ b/env/Lib/site-packages/pip/_internal/network/utils.py @@ -1,4 +1,4 @@ -from typing import Dict, Iterator +from typing import Dict, Generator from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response @@ -23,40 +23,41 @@ from pip._internal.exceptions import NetworkConnectionError # you're not asking for a compressed file and will then decompress it # before sending because if that's the case I don't think it'll ever be # possible to make this work. -HEADERS = {'Accept-Encoding': 'identity'} # type: Dict[str, str] +HEADERS: Dict[str, str] = {"Accept-Encoding": "identity"} -def raise_for_status(resp): - # type: (Response) -> None - http_error_msg = '' +def raise_for_status(resp: Response) -> None: + http_error_msg = "" if isinstance(resp.reason, bytes): # We attempt to decode utf-8 first because some servers # choose to localize their reason strings. If the string # isn't utf-8, we fall back to iso-8859-1 for all other # encodings. try: - reason = resp.reason.decode('utf-8') + reason = resp.reason.decode("utf-8") except UnicodeDecodeError: - reason = resp.reason.decode('iso-8859-1') + reason = resp.reason.decode("iso-8859-1") else: reason = resp.reason if 400 <= resp.status_code < 500: http_error_msg = ( - f'{resp.status_code} Client Error: {reason} for url: {resp.url}') + f"{resp.status_code} Client Error: {reason} for url: {resp.url}" + ) elif 500 <= resp.status_code < 600: http_error_msg = ( - f'{resp.status_code} Server Error: {reason} for url: {resp.url}') + f"{resp.status_code} Server Error: {reason} for url: {resp.url}" + ) if http_error_msg: raise NetworkConnectionError(http_error_msg, response=resp) -def response_chunks(response, chunk_size=CONTENT_CHUNK_SIZE): - # type: (Response, int) -> Iterator[bytes] - """Given a requests Response, provide the data chunks. - """ +def response_chunks( + response: Response, chunk_size: int = CONTENT_CHUNK_SIZE +) -> Generator[bytes, None, None]: + """Given a requests Response, provide the data chunks.""" try: # Special case for urllib3. for chunk in response.raw.stream( diff --git a/env/Lib/site-packages/pip/_internal/network/xmlrpc.py b/env/Lib/site-packages/pip/_internal/network/xmlrpc.py index b92b8d9a..4a7d55d0 100644 --- a/env/Lib/site-packages/pip/_internal/network/xmlrpc.py +++ b/env/Lib/site-packages/pip/_internal/network/xmlrpc.py @@ -21,22 +21,32 @@ class PipXmlrpcTransport(xmlrpc.client.Transport): object. """ - def __init__(self, index_url, session, use_datetime=False): - # type: (str, PipSession, bool) -> None + def __init__( + self, index_url: str, session: PipSession, use_datetime: bool = False + ) -> None: super().__init__(use_datetime) index_parts = urllib.parse.urlparse(index_url) self._scheme = index_parts.scheme self._session = session - def request(self, host, handler, request_body, verbose=False): - # type: (_HostType, str, bytes, bool) -> Tuple[_Marshallable, ...] + def request( + self, + host: "_HostType", + handler: str, + request_body: bytes, + verbose: bool = False, + ) -> Tuple["_Marshallable", ...]: assert isinstance(host, str) parts = (self._scheme, host, handler, None, None, None) url = urllib.parse.urlunparse(parts) try: - headers = {'Content-Type': 'text/xml'} - response = self._session.post(url, data=request_body, - headers=headers, stream=True) + headers = {"Content-Type": "text/xml"} + response = self._session.post( + url, + data=request_body, + headers=headers, + stream=True, + ) raise_for_status(response) self.verbose = verbose return self.parse_response(response.raw) @@ -44,6 +54,7 @@ class PipXmlrpcTransport(xmlrpc.client.Transport): assert exc.response logger.critical( "HTTP error %s while getting %s", - exc.response.status_code, url, + exc.response.status_code, + url, ) raise diff --git a/env/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 9b3650d70ccb7cd60366b139be73e1c1fd16aa2c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 224 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<YIU}X z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP u%1g}A&o4+VN-W9D&nwoCkI&4@EQycTE2zB1VUwGmQks)$2XfwLkT(G3s65C3 diff --git a/env/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-39.pyc deleted file mode 100644 index c9bff16da90f9ed06485345cadb99f8bcf3e37ee..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3720 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 Ti~@`x89rtS5iT7LQ4TQxIzs1C diff --git a/env/Lib/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-39.pyc deleted file mode 100644 index a7c7c055be58a6aa126398cec987675c806e7270..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5673 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 diff --git a/env/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-39.pyc deleted file mode 100644 index 98a20e7d0c02fcf50ad8cf66ec00f1f39afe7dad..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14260 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 diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 35a76848c3e474c4d27d88a3291cfd8b52114671..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 230 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>UOq@ z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP z%1g}A&o4+VN-W9D&nwnXD$UGE(T|VM%*!l^kJl@xyv1RYo1apelWGTY<Y$m)0Bcx3 A4FCWD diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-39.pyc deleted file mode 100644 index 5e73fc27fc6968fb21520c744d820ce87a4dcd45..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1176 zcmYe~<>g{vU|^UdaWJ))g@NHQh=Yuo7#J8F7#J9eJs21mQW&BbQW#U1au}l+Qy5d2 zbC`0OqnH^%Vk|i<xvWvFU^Z(GTP}MPJDAOu!;#Aw#mUH!!k)s>!Vtxk!W7J)$ysIM zn_7~Xl30?cke-^CT9jClnV+YSlb@cMtdN#pq)?n+T9llskdj$kQk0og3X(0><9Z2l znV%-(ErEd40#ieCkNo^>=fs?x)FP0WQ)y;Sifdk3W>J1#ZfahMCgUyXqSCy))S~$E z%#w`w;(|;tCpWdYI59m{lkpaBNNR3@OJ-4Oa!GzsWirUGAR9oKje&uIlYxQ38RYi{ z1_p)_kT021n0uLOnQEA_7;Bkp82Wt}8A_N^SehAYS!x&;FxRjwWbBt>WT;_Wz*57! zkg=9EoFRpkg@J{knVFFxPr#6&*vo){5ey?47#T2RGmvFVShE-xu+=cvur36J8CzA3 zJ0z%56>?#LS6ZBzm#&bTnw*iCmsy-!tdNpgoLrQdl$xTDnWqro8lYfmXs*Y_rJ$go z5R_U{T9j9;P?C`f3-r_!gi$H5aL@y*uHw(lPf0Dx(}md;qRDiNB|9@O<(5EtPJU8i zPEKWfZem_ydTL6QL_kq$L1GceE#(=hsX1^{{WRH&SQ!`?Zm|?3mShyMfS7{CrAY-v z`N^rp#qp5%xusA5)}I;=vn)O>zbHNl6ru5818*_q7vEyZ%FoQxWV^))kx0!eyTzWA zn4F!OmvW0AuCpY!ASJWt77tti#AAb6!~;rEnR#jX@hO=_D;bJ}85kITbvs+dgche3 z700CJq+}Mw_~)g%6lIpBD(EVN`gw-A1_gVDI0h?t`nmY~xdwYW#ss_ix(0{11}T`u z1O)iRB%0`gQf_fcW_C<!URjJ!W>QRXW=X1UL1J=tVtQ(EOhIOWetc$LNorAEVvc@( z0W`rE>w|rw4|A$sLFFw$XnsJ11urNGih&a)6C=xiHWoG}HWm&>9!3^MrvDBsMWPH0 z44T}x*yH0<@{{A^i?|sW7^0*LG7I$L%Tn`F@{9Bez_~@QyeP4tAhoEt2$axoiGx+Z z9Hj?#NqlNvSrIcRlH^cjOG`3yiuDi?2Z>1;Y>G-!a|=MB3yycN<G`VeM2LVa;IPTf dPbtkwwPOT%kB5PQfrXiaiHC`Yk%y6o832h-S^WS2 diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-39.pyc deleted file mode 100644 index 55bb6d5b7d49abf688c5744d72ce164be203ece5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1950 zcmYe~<>g{vU|^UdaWJ)(oq^#oh=Yuo85kHG7#J9e^B5QyQW&BbQW#U1au}l+!8B78 zQwn1Wa}IMZOB4$uNRB0kHJ2@l4a{cEVbA4=;sCSRayWCjqPW0p_8jh9o+uthhE&D{ zys3N(8Kd}9I8r!U7@`DHxKg-V7@`DIn1UHJd8({^Q%e$45=#;l(o^$NixNvR^YavP z^3yYu71HvH6mnA26O$_yit|g0l2a8@GK))!GLuR{ii-8PUV^;gr^$Frz^ODdC&e|d zEVC#-FE=%>M3eEBpl4ojNn%b8*hJT&qWmIF##^$viP@>~#i=Ew1tt0UImPj*>FM#A zd1?9aiACwfnvA#jlM{1t;)_d@3X1ZRQ;R`DydkN%1umIIsmUezMU}~nAWNZ`iGhKE zm4Si585Dd$px|RnVQOJ0VOYRe!?2Lig`t_Tma&GhSgnL9g}H`dHp5(|X2vGQ66PAl zX2ukjY?dO25~dW^1uP)dU>Sxi)&*=e3^j}?Y?2HMK|#b`W$c!jm!goEr=XXbo~{dW ztwM2WQVPsP3YmEd32<J59+!fGf&x}&27{a_#lXOj&QQY;D+F@d0)`ZZg^WckHH;IP z3R!{~G#RTn;nrv}-r`8jODQhTEXmMhy2YetaEmc*B|{M?J^h;GY!wq)oLW>IlbVx~ zSrp@+m+DfKS(d7xs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2?CR?p9O4?JU=|Y);1iQ* zq6>=V;*!klnAE(o7@y3fnBvTmRNaEa<m|-s)Z&<e%mV%R%)FA+qP)Z${rm!G>L}Jv z0>!p|E;Ql9L(+&|LFFwjo1DzzlH~l{0y`0qUqSK1##p5kpO%@I0*`Awo1FaQ#GGO~ zJ%sWq1;2cx@P!AbLRx-lUJ59PUxFgOO4m2PC{>{(BQZ}QKQ9%(j_TSXkRDC;TTJ=I zx7a~WOUW!M0_C?`%sHufx7gD1i*gf7Zm|?3mSo&w$;!{n(`35E3Ag+fXIf@XYF=V) zYB4y>Ap|!A1H&yoR4)mDd@BP=l`L$G9RJx^SQwcYIsUV-@GvqlvM@6JXZp{=RwTy2 zz>o||uONjW%+A2TzyV9YDGUtYl$*j>!&t+zkeQL8geiq7g*k<#mnn<6mbHYXhOvgV zhB<|`m${a$hM`}Mk)edOhOLGvg)N1>mzj|voFRpSg@J{knVFFxPr#6&ILLs35ey?4 z7#T{~YFL{YgBdhAtMc3-c|BDD7KsX_#hH2O3gDcnS5T>&lvtdaqL7lBmY7_UuaKLX zoROH9S)5y}#|2K_L8&FBMR~;vB^jx(aw9bbVHi9FA(^4dD5x|q57~SL4N#C<sTON0 zz)ApcaRW_z3aZ6bJO!Bry08ovqRDiNB|9@O<(5EtPJU8iPEKWfZem_ydTNR$(=8sD z8SyEZMYs6!^5aX3Q;Xu0^YhX&)2k#3DoZl*^Wc7i+o;KOi#fSG<rYtJer|4JUP^pQ zYH_lkCi^Y6oc#3k)S_FgDXB@N=|yY|3=Bm=Ac6%%fFckam746gIKf#VJ~glG7B4vL z;tML{L0-GX1t~JYF5<{6&d*6KNlm%Mo|0OUn3+>tBne7HETBRUlBhsgx(J-I1fk_{ zYCJ4%)Io_$4U}GZK*@^b9}6oJBg=md7A8h8{L9A124OKW{Z(NvQe|LZ&=k7G9v`2Q zpBx{5iyh>h%)Im>K9Hs21(^kU@NBII_dpRSv)+<Gl})WkPAveJ_K<9&f+}5Fl9^Mi z2lhCmI0u_n1PZ2Ga#)qZ3-%&VFy4~Erl=$}w*VAw;DEoynVwqW1Bnlg_;^rejE^sp u1w{lXJAplm6oiOy<gm%jPbtkwwF8v_#h~Jdg_(nqgNcU`3YoZ=Im7{_CNPKq diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-39.pyc deleted file mode 100644 index 2fd533621cbb12b4c57302b3581c1e95a5beba31..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1155 zcmYe~<>g{vU|^UdaWFNAg@NHQh=Yuo85kHG7#J9ey%-o6QW#Pga~Pr^G-DKF3PTE0 z4pT036f+}8j5&uTmo<tN%x1}9%Vm#ZXJklaSiq6WxsWl6D}^<Mt%V_qJB2ZrL6iL@ z$QD0M##<cz1tppJd5JlijJE^=QVUEC%{}t-vz-%ja#D*l8E;7!mFDH87R8rmmSn^i z7i5Atxv9m)iRr1yEFe>$n2mvffrEj8!5QS-DGUq@HB2dtrHsWqUJOl)RS_i&3m8+F zYM2)?F*1}er7+hp%w|YonakYFSj$qwxPZBaWg%m~93w*wV-`yda}84pYcEqRYdAv+ zBMSoyLo+iYL!N*kLve%w10xtlGB7fPGvq0-FqE)Xwm`&67#6Ulu+=bt?1*FldDMWR zgguL60cQ<!4eLTCkjJZfok}xvQWWy@QWZS&ic1o6a)MF|OEZg7b5rw56iSOT^U@Vc zGEx-+TmuwL4b2sjz{(4X@{?1Gi}kp;6ciK`f>KLLi}H#U3KB~)6iV_H$}>_^a}+Yu z6pBleLCVrfb8;%dI!p8v{7W)Yi^?;LQ*{)Ip!)ps^HTM|CizuKx}+ADWacG;VnHD# zvnVyWB)_QAN<p=_N*L@^kb@u=q~#YWRB<V2K%J(k$#_dBH?<@&C9xzi9<H@Y#w{^3 zCp86Ze+sH@)nZMqTWmS`>FKFOw^&nBlS<QzK#_P$u(&h{>c@CUjNjr0`#c_O^({`< zisV#qO1Z_FT2z!@bc-p!_!bK&0B*5l<!9z;vfX0IOUzBZ#h#RyoSmANQpC!@z;KJT zBsI4n<rW*%OfIl#@gRjO8Hz+07#MzaI9tVp7N-^!$E4<@WEREv=cT$7WtOEX=qiNz zd4{<L1$%}#1}k{_x%m6J275Zj1iSjW28Xx?DVW6s1o*@xn&{@_r)L(IWM;>t=9R_x zWG2NFXO^Vu79=KTC#I(s#}s51=*MT~m82HsCFbbo7o-+}1G`us>_L67lk^HIZwZ0< z5D&)}fU^P*C^5@{QaCpcBNHPJ6B8rXe->sQMixdUMy7unEIf=nj2w(bVhjunnmo7I zK_Q!&mtF+YcZ;p0vH-+kVqjp1k}k+B(2Fli%}dEI(t{YTS6-A@P>@<wTm;JIx8%So zVD8i_Ey>I&)<Z-KB%V0aQ%igx(Z>-F4#)WTB2d-?I{_S`NQ5XT3OH<X^HWN5QtcQ) Ro&mXxgOP)ghY19^m;uAYNl5?z diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-39.pyc deleted file mode 100644 index 8cbc897aa17d9f341649b692ddbc97733a75da83..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2549 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 I4p9y{0OuvnxBvhE diff --git a/env/Lib/site-packages/pip/_internal/operations/build/metadata.py b/env/Lib/site-packages/pip/_internal/operations/build/metadata.py index 1c826835..c66ac354 100644 --- a/env/Lib/site-packages/pip/_internal/operations/build/metadata.py +++ b/env/Lib/site-packages/pip/_internal/operations/build/metadata.py @@ -3,33 +3,37 @@ import os -from pip._vendor.pep517.wrappers import Pep517HookCaller +from pip._vendor.pyproject_hooks import BuildBackendHookCaller from pip._internal.build_env import BuildEnvironment +from pip._internal.exceptions import ( + InstallationSubprocessError, + MetadataGenerationFailed, +) from pip._internal.utils.subprocess import runner_with_spinner_message from pip._internal.utils.temp_dir import TempDirectory -def generate_metadata(build_env, backend): - # type: (BuildEnvironment, Pep517HookCaller) -> str +def generate_metadata( + build_env: BuildEnvironment, backend: BuildBackendHookCaller, details: str +) -> str: """Generate metadata using mechanisms described in PEP 517. Returns the generated metadata directory. """ - metadata_tmpdir = TempDirectory( - kind="modern-metadata", globally_managed=True - ) + metadata_tmpdir = TempDirectory(kind="modern-metadata", globally_managed=True) metadata_dir = metadata_tmpdir.path with build_env: - # Note that Pep517HookCaller implements a fallback for + # Note that BuildBackendHookCaller implements a fallback for # prepare_metadata_for_build_wheel, so we don't have to # consider the possibility that this hook doesn't exist. - runner = runner_with_spinner_message("Preparing wheel metadata") + runner = runner_with_spinner_message("Preparing metadata (pyproject.toml)") with backend.subprocess_runner(runner): - distinfo_dir = backend.prepare_metadata_for_build_wheel( - metadata_dir - ) + try: + distinfo_dir = backend.prepare_metadata_for_build_wheel(metadata_dir) + except InstallationSubprocessError as error: + raise MetadataGenerationFailed(package_details=details) from error return os.path.join(metadata_dir, distinfo_dir) diff --git a/env/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py b/env/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py index f46538a0..e60988d6 100644 --- a/env/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py +++ b/env/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py @@ -5,7 +5,12 @@ import logging import os from pip._internal.build_env import BuildEnvironment -from pip._internal.exceptions import InstallationError +from pip._internal.cli.spinners import open_spinner +from pip._internal.exceptions import ( + InstallationError, + InstallationSubprocessError, + MetadataGenerationFailed, +) from pip._internal.utils.setuptools_build import make_setuptools_egg_info_args from pip._internal.utils.subprocess import call_subprocess from pip._internal.utils.temp_dir import TempDirectory @@ -13,49 +18,39 @@ from pip._internal.utils.temp_dir import TempDirectory logger = logging.getLogger(__name__) -def _find_egg_info(directory): - # type: (str) -> str - """Find an .egg-info subdirectory in `directory`. - """ - filenames = [ - f for f in os.listdir(directory) if f.endswith(".egg-info") - ] +def _find_egg_info(directory: str) -> str: + """Find an .egg-info subdirectory in `directory`.""" + filenames = [f for f in os.listdir(directory) if f.endswith(".egg-info")] if not filenames: - raise InstallationError( - f"No .egg-info directory found in {directory}" - ) + raise InstallationError(f"No .egg-info directory found in {directory}") if len(filenames) > 1: raise InstallationError( - "More than one .egg-info directory found in {}".format( - directory - ) + "More than one .egg-info directory found in {}".format(directory) ) return os.path.join(directory, filenames[0]) def generate_metadata( - build_env, # type: BuildEnvironment - setup_py_path, # type: str - source_dir, # type: str - isolated, # type: bool - details, # type: str -): - # type: (...) -> str + build_env: BuildEnvironment, + setup_py_path: str, + source_dir: str, + isolated: bool, + details: str, +) -> str: """Generate metadata using setup.py-based defacto mechanisms. Returns the generated metadata directory. """ logger.debug( - 'Running setup.py (path:%s) egg_info for package %s', - setup_py_path, details, + "Running setup.py (path:%s) egg_info for package %s", + setup_py_path, + details, ) - egg_info_dir = TempDirectory( - kind="pip-egg-info", globally_managed=True - ).path + egg_info_dir = TempDirectory(kind="pip-egg-info", globally_managed=True).path args = make_setuptools_egg_info_args( setup_py_path, @@ -64,11 +59,16 @@ def generate_metadata( ) with build_env: - call_subprocess( - args, - cwd=source_dir, - command_desc='python setup.py egg_info', - ) + with open_spinner("Preparing metadata (setup.py)") as spinner: + try: + call_subprocess( + args, + cwd=source_dir, + command_desc="python setup.py egg_info", + spinner=spinner, + ) + except InstallationSubprocessError as error: + raise MetadataGenerationFailed(package_details=details) from error # Return the .egg-info directory. return _find_egg_info(egg_info_dir) diff --git a/env/Lib/site-packages/pip/_internal/operations/build/wheel.py b/env/Lib/site-packages/pip/_internal/operations/build/wheel.py index 903bd7a0..064811ad 100644 --- a/env/Lib/site-packages/pip/_internal/operations/build/wheel.py +++ b/env/Lib/site-packages/pip/_internal/operations/build/wheel.py @@ -2,7 +2,7 @@ import logging import os from typing import Optional -from pip._vendor.pep517.wrappers import Pep517HookCaller +from pip._vendor.pyproject_hooks import BuildBackendHookCaller from pip._internal.utils.subprocess import runner_with_spinner_message @@ -10,22 +10,21 @@ logger = logging.getLogger(__name__) def build_wheel_pep517( - name, # type: str - backend, # type: Pep517HookCaller - metadata_directory, # type: str - tempd, # type: str -): - # type: (...) -> Optional[str] + name: str, + backend: BuildBackendHookCaller, + metadata_directory: str, + tempd: str, +) -> Optional[str]: """Build one InstallRequirement using the PEP 517 build process. Returns path to wheel if successfully built. Otherwise, returns None. """ assert metadata_directory is not None try: - logger.debug('Destination directory: %s', tempd) + logger.debug("Destination directory: %s", tempd) runner = runner_with_spinner_message( - f'Building wheel for {name} (PEP 517)' + f"Building wheel for {name} (pyproject.toml)" ) with backend.subprocess_runner(runner): wheel_name = backend.build_wheel( @@ -33,6 +32,6 @@ def build_wheel_pep517( metadata_directory=metadata_directory, ) except Exception: - logger.error('Failed building wheel for %s', name) + logger.error("Failed building wheel for %s", name) return None return os.path.join(tempd, wheel_name) diff --git a/env/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py b/env/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py index 755c3bc8..c5f0492c 100644 --- a/env/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py +++ b/env/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py @@ -4,59 +4,51 @@ from typing import List, Optional from pip._internal.cli.spinners import open_spinner from pip._internal.utils.setuptools_build import make_setuptools_bdist_wheel_args -from pip._internal.utils.subprocess import ( - LOG_DIVIDER, - call_subprocess, - format_command_args, -) +from pip._internal.utils.subprocess import call_subprocess, format_command_args logger = logging.getLogger(__name__) def format_command_result( - command_args, # type: List[str] - command_output, # type: str -): - # type: (...) -> str + command_args: List[str], + command_output: str, +) -> str: """Format command information for logging.""" command_desc = format_command_args(command_args) - text = f'Command arguments: {command_desc}\n' + text = f"Command arguments: {command_desc}\n" if not command_output: - text += 'Command output: None' + text += "Command output: None" elif logger.getEffectiveLevel() > logging.DEBUG: - text += 'Command output: [use --verbose to show]' + text += "Command output: [use --verbose to show]" else: - if not command_output.endswith('\n'): - command_output += '\n' - text += f'Command output:\n{command_output}{LOG_DIVIDER}' + if not command_output.endswith("\n"): + command_output += "\n" + text += f"Command output:\n{command_output}" return text def get_legacy_build_wheel_path( - names, # type: List[str] - temp_dir, # type: str - name, # type: str - command_args, # type: List[str] - command_output, # type: str -): - # type: (...) -> Optional[str] + names: List[str], + temp_dir: str, + name: str, + command_args: List[str], + command_output: str, +) -> Optional[str]: """Return the path to the wheel in the temporary build directory.""" # Sort for determinism. names = sorted(names) if not names: - msg = ( - 'Legacy build of wheel for {!r} created no files.\n' - ).format(name) + msg = ("Legacy build of wheel for {!r} created no files.\n").format(name) msg += format_command_result(command_args, command_output) logger.warning(msg) return None if len(names) > 1: msg = ( - 'Legacy build of wheel for {!r} created more than one file.\n' - 'Filenames (choosing first): {}\n' + "Legacy build of wheel for {!r} created more than one file.\n" + "Filenames (choosing first): {}\n" ).format(name, names) msg += format_command_result(command_args, command_output) logger.warning(msg) @@ -65,14 +57,13 @@ def get_legacy_build_wheel_path( def build_wheel_legacy( - name, # type: str - setup_py_path, # type: str - source_dir, # type: str - global_options, # type: List[str] - build_options, # type: List[str] - tempd, # type: str -): - # type: (...) -> Optional[str] + name: str, + setup_py_path: str, + source_dir: str, + global_options: List[str], + build_options: List[str], + tempd: str, +) -> Optional[str]: """Build one unpacked package using the "legacy" build process. Returns path to wheel if successfully built. Otherwise, returns None. @@ -84,19 +75,20 @@ def build_wheel_legacy( destination_dir=tempd, ) - spin_message = f'Building wheel for {name} (setup.py)' + spin_message = f"Building wheel for {name} (setup.py)" with open_spinner(spin_message) as spinner: - logger.debug('Destination directory: %s', tempd) + logger.debug("Destination directory: %s", tempd) try: output = call_subprocess( wheel_args, + command_desc="python setup.py bdist_wheel", cwd=source_dir, spinner=spinner, ) except Exception: spinner.finish("error") - logger.error('Failed building wheel for %s', name) + logger.error("Failed building wheel for %s", name) return None names = os.listdir(tempd) diff --git a/env/Lib/site-packages/pip/_internal/operations/check.py b/env/Lib/site-packages/pip/_internal/operations/check.py index 5699c0b9..26104592 100644 --- a/env/Lib/site-packages/pip/_internal/operations/check.py +++ b/env/Lib/site-packages/pip/_internal/operations/check.py @@ -2,87 +2,91 @@ """ import logging -from collections import namedtuple -from typing import TYPE_CHECKING, Any, Callable, Dict, List, Optional, Set, Tuple +from typing import Callable, Dict, List, NamedTuple, Optional, Set, Tuple -from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.pkg_resources import RequirementParseError +from pip._vendor.packaging.requirements import Requirement +from pip._vendor.packaging.specifiers import LegacySpecifier +from pip._vendor.packaging.utils import NormalizedName, canonicalize_name +from pip._vendor.packaging.version import LegacyVersion from pip._internal.distributions import make_distribution_for_install_requirement +from pip._internal.metadata import get_default_environment +from pip._internal.metadata.base import DistributionVersion from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils.misc import get_installed_distributions - -if TYPE_CHECKING: - from pip._vendor.packaging.utils import NormalizedName +from pip._internal.utils.deprecation import deprecated logger = logging.getLogger(__name__) + +class PackageDetails(NamedTuple): + version: DistributionVersion + dependencies: List[Requirement] + + # Shorthands -PackageSet = Dict['NormalizedName', 'PackageDetails'] -Missing = Tuple[str, Any] -Conflicting = Tuple[str, str, Any] +PackageSet = Dict[NormalizedName, PackageDetails] +Missing = Tuple[NormalizedName, Requirement] +Conflicting = Tuple[NormalizedName, DistributionVersion, Requirement] -MissingDict = Dict['NormalizedName', List[Missing]] -ConflictingDict = Dict['NormalizedName', List[Conflicting]] +MissingDict = Dict[NormalizedName, List[Missing]] +ConflictingDict = Dict[NormalizedName, List[Conflicting]] CheckResult = Tuple[MissingDict, ConflictingDict] ConflictDetails = Tuple[PackageSet, CheckResult] -PackageDetails = namedtuple('PackageDetails', ['version', 'requires']) - - -def create_package_set_from_installed(**kwargs: Any) -> Tuple["PackageSet", bool]: - """Converts a list of distributions into a PackageSet. - """ - # Default to using all packages installed on the system - if kwargs == {}: - kwargs = {"local_only": False, "skip": ()} +def create_package_set_from_installed() -> Tuple[PackageSet, bool]: + """Converts a list of distributions into a PackageSet.""" package_set = {} problems = False - for dist in get_installed_distributions(**kwargs): - name = canonicalize_name(dist.project_name) + env = get_default_environment() + for dist in env.iter_installed_distributions(local_only=False, skip=()): + name = dist.canonical_name try: - package_set[name] = PackageDetails(dist.version, dist.requires()) - except (OSError, RequirementParseError) as e: - # Don't crash on unreadable or broken metadata + dependencies = list(dist.iter_dependencies()) + package_set[name] = PackageDetails(dist.version, dependencies) + except (OSError, ValueError) as e: + # Don't crash on unreadable or broken metadata. logger.warning("Error parsing requirements for %s: %s", name, e) problems = True return package_set, problems -def check_package_set(package_set, should_ignore=None): - # type: (PackageSet, Optional[Callable[[str], bool]]) -> CheckResult +def check_package_set( + package_set: PackageSet, should_ignore: Optional[Callable[[str], bool]] = None +) -> CheckResult: """Check if a package set is consistent If should_ignore is passed, it should be a callable that takes a package name and returns a boolean. """ + warn_legacy_versions_and_specifiers(package_set) + missing = {} conflicting = {} for package_name, package_detail in package_set.items(): # Info about dependencies of package_name - missing_deps = set() # type: Set[Missing] - conflicting_deps = set() # type: Set[Conflicting] + missing_deps: Set[Missing] = set() + conflicting_deps: Set[Conflicting] = set() if should_ignore and should_ignore(package_name): continue - for req in package_detail.requires: - name = canonicalize_name(req.project_name) + for req in package_detail.dependencies: + name = canonicalize_name(req.name) # Check if it's missing if name not in package_set: missed = True if req.marker is not None: - missed = req.marker.evaluate() + missed = req.marker.evaluate({"extra": ""}) if missed: missing_deps.add((name, req)) continue # Check if there's a conflict - version = package_set[name].version # type: str + version = package_set[name].version if not req.specifier.contains(version, prereleases=True): conflicting_deps.add((name, version, req)) @@ -94,8 +98,7 @@ def check_package_set(package_set, should_ignore=None): return missing, conflicting -def check_install_conflicts(to_install): - # type: (List[InstallRequirement]) -> ConflictDetails +def check_install_conflicts(to_install: List[InstallRequirement]) -> ConflictDetails: """For checking if the dependency graph would be consistent after \ installing given requirements """ @@ -111,43 +114,74 @@ def check_install_conflicts(to_install): package_set, check_package_set( package_set, should_ignore=lambda name: name not in whitelist - ) + ), ) -def _simulate_installation_of(to_install, package_set): - # type: (List[InstallRequirement], PackageSet) -> Set[NormalizedName] - """Computes the version of packages after installing to_install. - """ - +def _simulate_installation_of( + to_install: List[InstallRequirement], package_set: PackageSet +) -> Set[NormalizedName]: + """Computes the version of packages after installing to_install.""" # Keep track of packages that were installed installed = set() # Modify it as installing requirement_set would (assuming no errors) for inst_req in to_install: abstract_dist = make_distribution_for_install_requirement(inst_req) - dist = abstract_dist.get_pkg_resources_distribution() - - assert dist is not None - name = canonicalize_name(dist.key) - package_set[name] = PackageDetails(dist.version, dist.requires()) + dist = abstract_dist.get_metadata_distribution() + name = dist.canonical_name + package_set[name] = PackageDetails(dist.version, list(dist.iter_dependencies())) installed.add(name) return installed -def _create_whitelist(would_be_installed, package_set): - # type: (Set[NormalizedName], PackageSet) -> Set[NormalizedName] +def _create_whitelist( + would_be_installed: Set[NormalizedName], package_set: PackageSet +) -> Set[NormalizedName]: packages_affected = set(would_be_installed) for package_name in package_set: if package_name in packages_affected: continue - for req in package_set[package_name].requires: + for req in package_set[package_name].dependencies: if canonicalize_name(req.name) in packages_affected: packages_affected.add(package_name) break return packages_affected + + +def warn_legacy_versions_and_specifiers(package_set: PackageSet) -> None: + for project_name, package_details in package_set.items(): + if isinstance(package_details.version, LegacyVersion): + deprecated( + reason=( + f"{project_name} {package_details.version} " + f"has a non-standard version number." + ), + replacement=( + f"to upgrade to a newer version of {project_name} " + f"or contact the author to suggest that they " + f"release a version with a conforming version number" + ), + issue=12063, + gone_in="23.3", + ) + for dep in package_details.dependencies: + if any(isinstance(spec, LegacySpecifier) for spec in dep.specifier): + deprecated( + reason=( + f"{project_name} {package_details.version} " + f"has a non-standard dependency specifier {dep}." + ), + replacement=( + f"to upgrade to a newer version of {project_name} " + f"or contact the author to suggest that they " + f"release a version with a conforming dependency specifiers" + ), + issue=12063, + gone_in="23.3", + ) diff --git a/env/Lib/site-packages/pip/_internal/operations/freeze.py b/env/Lib/site-packages/pip/_internal/operations/freeze.py index f34a9d4b..35445684 100644 --- a/env/Lib/site-packages/pip/_internal/operations/freeze.py +++ b/env/Lib/site-packages/pip/_internal/operations/freeze.py @@ -1,73 +1,46 @@ import collections import logging import os -from typing import ( - Container, - Dict, - Iterable, - Iterator, - List, - Optional, - Set, - Tuple, - Union, -) +from typing import Container, Dict, Generator, Iterable, List, NamedTuple, Optional, Set from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.pkg_resources import Distribution, Requirement, RequirementParseError +from pip._vendor.packaging.version import Version from pip._internal.exceptions import BadCommand, InstallationError +from pip._internal.metadata import BaseDistribution, get_environment from pip._internal.req.constructors import ( install_req_from_editable, install_req_from_line, ) from pip._internal.req.req_file import COMMENT_RE -from pip._internal.utils.direct_url_helpers import ( - direct_url_as_pep440_direct_reference, - dist_get_direct_url, -) -from pip._internal.utils.misc import dist_is_editable, get_installed_distributions +from pip._internal.utils.direct_url_helpers import direct_url_as_pep440_direct_reference logger = logging.getLogger(__name__) -RequirementInfo = Tuple[Optional[Union[str, Requirement]], bool, List[str]] - -def freeze( - requirement=None, # type: Optional[List[str]] - find_links=None, # type: Optional[List[str]] - local_only=False, # type: bool - user_only=False, # type: bool - paths=None, # type: Optional[List[str]] - isolated=False, # type: bool - exclude_editable=False, # type: bool - skip=() # type: Container[str] -): - # type: (...) -> Iterator[str] - find_links = find_links or [] +class _EditableInfo(NamedTuple): + requirement: str + comments: List[str] - for link in find_links: - yield f'-f {link}' - installations = {} # type: Dict[str, FrozenRequirement] - for dist in get_installed_distributions( - local_only=local_only, - skip=(), - user_only=user_only, - paths=paths - ): - try: - req = FrozenRequirement.from_dist(dist) - except RequirementParseError as exc: - # We include dist rather than dist.project_name because the - # dist string includes more information, like the version and - # location. We also include the exception message to aid - # troubleshooting. - logger.warning( - 'Could not generate requirement for distribution %r: %s', - dist, exc - ) - continue +def freeze( + requirement: Optional[List[str]] = None, + local_only: bool = False, + user_only: bool = False, + paths: Optional[List[str]] = None, + isolated: bool = False, + exclude_editable: bool = False, + skip: Container[str] = (), +) -> Generator[str, None, None]: + installations: Dict[str, FrozenRequirement] = {} + + dists = get_environment(paths).iter_installed_distributions( + local_only=local_only, + skip=(), + user_only=user_only, + ) + for dist in dists: + req = FrozenRequirement.from_dist(dist) if exclude_editable and req.editable: continue installations[req.canonical_name] = req @@ -77,42 +50,50 @@ def freeze( # should only be emitted once, even if the same option is in multiple # requirements files, so we need to keep track of what has been emitted # so that we don't emit it again if it's seen again - emitted_options = set() # type: Set[str] + emitted_options: Set[str] = set() # keep track of which files a requirement is in so that we can # give an accurate warning if a requirement appears multiple times. - req_files = collections.defaultdict(list) # type: Dict[str, List[str]] + req_files: Dict[str, List[str]] = collections.defaultdict(list) for req_file_path in requirement: with open(req_file_path) as req_file: for line in req_file: - if (not line.strip() or - line.strip().startswith('#') or - line.startswith(( - '-r', '--requirement', - '-f', '--find-links', - '-i', '--index-url', - '--pre', - '--trusted-host', - '--process-dependency-links', - '--extra-index-url', - '--use-feature'))): + if ( + not line.strip() + or line.strip().startswith("#") + or line.startswith( + ( + "-r", + "--requirement", + "-f", + "--find-links", + "-i", + "--index-url", + "--pre", + "--trusted-host", + "--process-dependency-links", + "--extra-index-url", + "--use-feature", + ) + ) + ): line = line.rstrip() if line not in emitted_options: emitted_options.add(line) yield line continue - if line.startswith('-e') or line.startswith('--editable'): - if line.startswith('-e'): + if line.startswith("-e") or line.startswith("--editable"): + if line.startswith("-e"): line = line[2:].strip() else: - line = line[len('--editable'):].strip().lstrip('=') + line = line[len("--editable") :].strip().lstrip("=") line_req = install_req_from_editable( line, isolated=isolated, ) else: line_req = install_req_from_line( - COMMENT_RE.sub('', line).strip(), + COMMENT_RE.sub("", line).strip(), isolated=isolated, ) @@ -120,15 +101,15 @@ def freeze( logger.info( "Skipping line in requirement file [%s] because " "it's not clear what it would install: %s", - req_file_path, line.strip(), + req_file_path, + line.strip(), ) logger.info( " (add #egg=PackageName to the URL to avoid" " this warning)" ) else: - line_req_canonical_name = canonicalize_name( - line_req.name) + line_req_canonical_name = canonicalize_name(line_req.name) if line_req_canonical_name not in installations: # either it's not installed, or it is installed # but has been processed already @@ -137,14 +118,13 @@ def freeze( "Requirement file [%s] contains %s, but " "package %r is not installed", req_file_path, - COMMENT_RE.sub('', line).strip(), - line_req.name + COMMENT_RE.sub("", line).strip(), + line_req.name, ) else: req_files[line_req.name].append(req_file_path) else: - yield str(installations[ - line_req_canonical_name]).rstrip() + yield str(installations[line_req_canonical_name]).rstrip() del installations[line_req_canonical_name] req_files[line_req.name].append(req_file_path) @@ -152,83 +132,99 @@ def freeze( # single requirements file or in different requirements files). for name, files in req_files.items(): if len(files) > 1: - logger.warning("Requirement %s included multiple times [%s]", - name, ', '.join(sorted(set(files)))) + logger.warning( + "Requirement %s included multiple times [%s]", + name, + ", ".join(sorted(set(files))), + ) - yield( - '## The following requirements were added by ' - 'pip freeze:' - ) - for installation in sorted( - installations.values(), key=lambda x: x.name.lower()): + yield ("## The following requirements were added by pip freeze:") + for installation in sorted(installations.values(), key=lambda x: x.name.lower()): if installation.canonical_name not in skip: yield str(installation).rstrip() -def get_requirement_info(dist): - # type: (Distribution) -> RequirementInfo +def _format_as_name_version(dist: BaseDistribution) -> str: + dist_version = dist.version + if isinstance(dist_version, Version): + return f"{dist.raw_name}=={dist_version}" + return f"{dist.raw_name}==={dist_version}" + + +def _get_editable_info(dist: BaseDistribution) -> _EditableInfo: """ - Compute and return values (req, editable, comments) for use in + Compute and return values (req, comments) for use in FrozenRequirement.from_dist(). """ - if not dist_is_editable(dist): - return (None, False, []) + editable_project_location = dist.editable_project_location + assert editable_project_location + location = os.path.normcase(os.path.abspath(editable_project_location)) - location = os.path.normcase(os.path.abspath(dist.location)) + from pip._internal.vcs import RemoteNotFoundError, RemoteNotValidError, vcs - from pip._internal.vcs import RemoteNotFoundError, vcs vcs_backend = vcs.get_backend_for_dir(location) if vcs_backend is None: - req = dist.as_requirement() + display = _format_as_name_version(dist) logger.debug( - 'No VCS found for editable requirement "%s" in: %r', req, + 'No VCS found for editable requirement "%s" in: %r', + display, location, ) - comments = [ - f'# Editable install with no version control ({req})' - ] - return (location, True, comments) + return _EditableInfo( + requirement=location, + comments=[f"# Editable install with no version control ({display})"], + ) + + vcs_name = type(vcs_backend).__name__ try: - req = vcs_backend.get_src_requirement(location, dist.project_name) + req = vcs_backend.get_src_requirement(location, dist.raw_name) except RemoteNotFoundError: - req = dist.as_requirement() - comments = [ - '# Editable {} install with no remote ({})'.format( - type(vcs_backend).__name__, req, - ) - ] - return (location, True, comments) - + display = _format_as_name_version(dist) + return _EditableInfo( + requirement=location, + comments=[f"# Editable {vcs_name} install with no remote ({display})"], + ) + except RemoteNotValidError as ex: + display = _format_as_name_version(dist) + return _EditableInfo( + requirement=location, + comments=[ + f"# Editable {vcs_name} install ({display}) with either a deleted " + f"local remote or invalid URI:", + f"# '{ex.url}'", + ], + ) except BadCommand: logger.warning( - 'cannot determine version of editable source in %s ' - '(%s command not found in path)', + "cannot determine version of editable source in %s " + "(%s command not found in path)", location, vcs_backend.name, ) - return (None, True, []) - + return _EditableInfo(requirement=location, comments=[]) except InstallationError as exc: - logger.warning( - "Error when trying to get requirement for VCS system %s, " - "falling back to uneditable format", exc - ) + logger.warning("Error when trying to get requirement for VCS system %s", exc) else: - return (req, True, []) + return _EditableInfo(requirement=req, comments=[]) - logger.warning( - 'Could not determine repository location of %s', location - ) - comments = ['## !! Could not determine repository location'] + logger.warning("Could not determine repository location of %s", location) - return (None, False, comments) + return _EditableInfo( + requirement=location, + comments=["## !! Could not determine repository location"], + ) class FrozenRequirement: - def __init__(self, name, req, editable, comments=()): - # type: (str, Union[str, Requirement], bool, Iterable[str]) -> None + def __init__( + self, + name: str, + req: str, + editable: bool, + comments: Iterable[str] = (), + ) -> None: self.name = name self.canonical_name = canonicalize_name(name) self.req = req @@ -236,29 +232,24 @@ class FrozenRequirement: self.comments = comments @classmethod - def from_dist(cls, dist): - # type: (Distribution) -> FrozenRequirement - # TODO `get_requirement_info` is taking care of editable requirements. - # TODO This should be refactored when we will add detection of - # editable that provide .dist-info metadata. - req, editable, comments = get_requirement_info(dist) - if req is None and not editable: - # if PEP 610 metadata is present, attempt to use it - direct_url = dist_get_direct_url(dist) + def from_dist(cls, dist: BaseDistribution) -> "FrozenRequirement": + editable = dist.editable + if editable: + req, comments = _get_editable_info(dist) + else: + comments = [] + direct_url = dist.direct_url if direct_url: - req = direct_url_as_pep440_direct_reference( - direct_url, dist.project_name - ) - comments = [] - if req is None: - # name==version requirement - req = dist.as_requirement() + # if PEP 610 metadata is present, use it + req = direct_url_as_pep440_direct_reference(direct_url, dist.raw_name) + else: + # name==version requirement + req = _format_as_name_version(dist) - return cls(dist.project_name, req, editable, comments=comments) + return cls(dist.raw_name, req, editable, comments=comments) - def __str__(self): - # type: () -> str + def __str__(self) -> str: req = self.req if self.editable: - req = f'-e {req}' - return '\n'.join(list(self.comments) + [str(req)]) + '\n' + req = f"-e {req}" + return "\n".join(list(self.comments) + [str(req)]) + "\n" diff --git a/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 9a65ac0c0f5bbfdfe368092284022fe9c568d9b6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 288 zcmYe~<>g{vU|^UdaWK`Gfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}V&-13VQ za`RJ4b5e^Hic)hDOHxx5O7ayl^NLFnb8<5C(iI94ld}`kQ;YSu{4^PFvB$@!<R{0+ zuVg4<Vqky}zj~dmVnT~ki;81Xb5b&kV*K+`U5YZxQWbO+Lj63$T!Vr=LmYz@JpEk! z{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgvZ=#}s51 z=*MT~m82HsCFbbo7o-*?mSpDV73)JCsvjSpnU`4-AFo$Xd5gma;v+kduRnu=0RRrE BRSy6F diff --git a/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-39.pyc deleted file mode 100644 index cee2f90ad4a6ea80e854079da5d3fd9c0f8cdbf9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1331 zcmYe~<>g{vU|^UdaWJ)nm4V?gh=Yuo85kHG7#J9e(-;^SQW&BbQW#U1au}l+Qy5d2 zbC`0OqnLA9qF8cSqgWY1ax6J)x$IHwU^Z(GM=oa+Cz#Ea!<EY&#SLb&=kVn6M)5K- zq%tnxOXXk47$uOxk;2)+5G9zx6wIK>Rb}s!nx2?ksgRnIS(2EPld6!JS6q^qlapAI znV+XnP?VpXT3oE7kg1odr;t#bT2fk|S5T>tl3JFUlV6aa$Mq8A1wT#ZTP!}A#U-~m z{0l%D6LW5H1g933rsgH5YBJsua4OBrNpa09%Ph*z%T3KI(PX^Em6?~4npYB^lb^21 zcuOWXF*`LLY<@|8eok>b)Q0%PqV!@-##{W!i8(p(#idD57bSzk5@a_60|Pe$0|O@m z1A{Xt^lBIw7)lrxFs3lpur6d`WGG>(VXI-RVW?rRVX9%SVM$@?Wv}HbVQyyVcVJ|w z;pmrPWGG>&;i}<GVeVyOWC&+SVPRolVQ6M%WXKaRWGD_WU|<BpNCqsjdC0OUEWr$# ztX0vTkT6t8R47PH&Q44Rg(@P1bMsSD^%Q*bi%S#|i_%L$;ZdxRSd^+zkXT%-Tar<f zUz(o5rJ$goP?E2J2ogQ8P?da8X<lAtUOGeuDKZq&@{1Hyi#6G9@ulbFCne^@=Y!*- z_!d7jPT>N4dHM0B#i>Q{$@zI{nd!IK3W`$GGAnMeWaQ_j-r_ASPK8JpXO@7Xk2$$K z#ZQy<7F$k!dU|TnEtbr@wEQA=1_p*AHW0zVz`&r%T?C4fB2YXO@qk2mK?ENI1H&zr zyhM<(V6Vg%RK^!1mSo)G$Sls!Ni0cCxy6|TN*(d3d1bdGOY=Y>mYNb@oL^d$oEo2! zS(KVwl3!GLiv^StRx%VxFfcIun&NB~6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e z8Wijq;ux&p>F46_=Njzk7!&O3>lz&58l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>b z1M;jc$o9na)Z&<e%mV%R%)FA+qP)Z${rrN|B5;l<)`y0rJ}kq;=YTViUP0w80jOL& zOb+DxVg*nt72siFVnl&I*|<0u*&t&7iljh6D0GWGK0YNsIX?atJ1D3#^U`mzl~fjF z=A{=gfkG2hL=>@rf>gX9vp^5-K0SB{7O{e4rBP)|OEPnc^`It#qwJOnHWlCqf@D9i zf#4{<C5KfhJSP@`V*eIrdTNOeBz17a$AjWKKE6l*<Yti1z>$VTNP-;6VUwGmQks)$ X#|X-{Ahj$^9E>7NJd9w-#KjB%Y~g}0 diff --git a/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-39.pyc deleted file mode 100644 index 169e89e976b5a41b8890758f11cda62494d5cc2f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3219 zcmYe~<>g{vU|^UdaWFMdfPvvLh=Yt-7#J8F7#J9e4>2$>q%cG=q%fv1<uFDuf@!8G zCNRw$#hk*J!kojB%NoVX2vWn6!<Ne)#h%L%#gWSy#R(Q;&Ed-Bj^YNh*>ZStd82s2 zZ1x<!T>dD2Fq<PsAXhL-5X|Px5y};g5(cxmazt`PqeQ`M?i{gP@hEXHn<qyiS29YH zks+0FfmEvWLdGZ=cZL++6uuUQ6uwm1X67il6#f)}7KSMK6sBMXO~EQNpVaik<VuCi zyyB9?oSejx%=|osf};H7)Z$_tg-pFvJ%xng)RNKyy#lzR1U;^opiuGCWW2?loROH9 zo*G}2pI@TMe2c{=v$*6IhkpUcoWz`49KorDrKx$zshW(p1e{7Ub5dOM$})@c^Kw)3 zN;Da733?*g>snNlU!=)+i!C@gBQ+PKg)1{JB{i=kJ|{n2lkpZ;YF=?^QEGfjCP<Y` zZen(7JlJg|`T04;@lY?sCl;j_Yck%FE-KB-OD&2o&n(G^FD}Rgb8=IQixbm9M)QWG z<`%eQ7NsVa<QG*YgZzVxnP4$3!oa|g$`Hkv!T^cg7KSM16y{(CO_p0Ckg$V#!7VW} zr?e<FnGwkt5F2EYGbqjQF)%QcFf3qP$WX%&&y>Ot%&?NtPm}o;b8%(yEsoTR<oL|I zwESCa1&KwFz+ov)%}HCyPy}+quWo0nn9$<XqT-m;oRrL>82`Lfm!izFR0UmyP(RNw z*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!klnAE(o7@y3f znBvTmRNaEa<m|-s)Z&<e%mV%R%)FA+qP)Z${rrN|B5-Ob)`teHehxUP=oM7n;)svW z%*!l^j~54d4CF%wrYc!%!J!9J>8Hs8(w3K)n;IW~iz_}pH$SB`2gK%yk1s4u%z?-h zi7_xhd<^zBgb)RZfr1YtSq!p{gRuz2PX-aN@Rns@U;y!%L2j~RVqmCY&tj<MD*<QD zUd9QG{c^SZRR>C#vX~dJ)bM99r!X&Msud_<t>LI)tYN4T=wPT}so|?(u3@d=tYJ%G z>E*5!EMZGwt>K!@Fqf&Bu~w*ry_uokfsvtxyI+Qpp+=}iu!bjvt(S?BA)FzFfrWvE zp_!SHAy2@Np}4_-fe{QN8L-ICLzV@*h@(beA!G5S63zu&DeN@@3&Cb0o0`HA%n;6y zC&t21!d>|aVs;5n6JsPp9+Lq>32%)+Gh@F@t#FO-0=|U|3-}i@)QTYM&l56an7~*p zfowAtc?)Fuc7`;@6wVZ`7LHoc8W9(USe;riuxkZs#1=Bvir0uQ5KQ4-$T)$qD5yrX zM!cD^R)UdX0%PH%35<n7DLe~=YIqki)=HKL*GM)qHZi6%)JlQPai|rm5nCX#kfBx@ zY@TS1G}x2_HDG?0m^nkObdA&kaj>jJjcAQ@Gh>a!LZ*d`VDo3yNG*_D$iT=@B2^>N z%*e<9R>x8!k;1!>saB?hw?-y~ubHV|1sopIDf|mqYNQr2rtph1fK0&fH&d|zvcFRV zK!u~<Ew-Z6<ou!(O~zX+*_nAMRYK6LpbHV#E2${a<hsR|o|B)Hm=m85F7=9U@k3Q1 z1R%=e(=u~XLCO3U3#hof#a2+1nwD8{iz_2FF(tJKRIc4($;i)5y~SHvoEl$RoLUqQ z%A&XU^70|P<ovv}%=BBF1(nJ9xdoXysa3K;rFnUodFcw^f)J^YR!GY)QqW|&#hjd* za*H{+Jf%t^2<#aJkSi2aixu+nOBB-bOY>6PFv=`Y77_+!BQ*vFh7N`lhEj%NkrIY1 z#sy3@3=0{HC2AOg8A_Nt7-|@rnSvQWWmyqF0|Tf~WXdnT#Zr)1l5vYQvp6xSxCoS8 zH5rRE85kH=G8V~$vNEVZD*|QeTRa6tsRgNdDd74e8e}6IC_6KWFtRXJ$wI?X&n727 zIWec$P7hgi6{lWmdb%#C%&cmuu2o3MOaXf-GcP4GIk6;Fp(G=*L?N>TR<)(3C?w`7 z!1XAkz{-9-1^>L9N<;t_6y;~7CYKZ|q^IVA%fP&JEZQ<tixm=!QWc6z3kvd!N>Wqw zs)V8LO-<1Sg>f+`dE8<wzs1NEqA7EW9TLmMMZBOO&;SvjFuBE&m7kec#0}!}fCx?o z28LT~sTG;UCB?Vca`MyDQ;Tk~rlcm7rr+Xptw>G<r!sKycZ(&zAT{q6OHpcK$}O(q zf}G5foXot`;#=$~nML4)#*vzrQVgmAZ?UE27v(0F6tRPhXDu!%$}9lIP)cUeE#~6X zf?I5f1)zwy#a@(}1CBnH;{2kLB2ati7HfG?W=X21Y!Rr4Es_Db5*&|8AeI7%PzDjI zAfwre!Ik$dUT}hpFQ|+Mo5qn@oS&0elA3ahqbRj79_%>IBv6AOJ~glGmSkxjs2)m9 zi7(DCElLL0@sOJN7C%URN@{U(Q6|LaiXdw^N>XzRKslyJ4#eew20gg)zr_Zr`fo9& z-Qs~}J#e@b>44O-fY`S<;qiZqCpA4CT=#;^yTuM|Bi!Q5OD&HFsV%<60g6wso56V- zoRN#c9)na++92<P6Er*2A)r7iE&`=xAvPvHMkYo9Mkeg=D;pmZBgcOhW{@f-My7vG ztUQc7OkzwtOkC_-j6O^}>>P|dj694Sj9ko2|Cv~r{;;reFtIRlFmf>RG4e37Fbe$V zV21Hbn2JI{IZ@#jdwhIKesX;LEp|{M%FIhI0w+2FP#Ex~WEPi{mSpA>>w!pcCcVX0 zQds~}2Fm?Kpr&pSD@d()L1uv-ykVdRkF+9CR=p*GDw_&Rpv91sCXFhco1c=JQ>+I` zBSjn_<Iz-roKvg^b1^tGpjiP?k(*hZ3`w0Ts8&Fv!Kn|@E(ALmoWX9%VO3h11a0sZ zfimDN8ElH+$qkfyZ*iulmiT~kW)Y|bRAdB-e-jV^YJh+v0Fp4kB^{Umrw$IATyU$$ c4%9F#2IU+UaKwQkScC}_$w-)qi&=mT0LdPShyVZp diff --git a/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-39.pyc deleted file mode 100644 index 7e73e396d930cefd1f44f6945a056b33128e6174..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20841 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 Vd&9`^gR7pQp23NQkxKw30szjCOLPDL diff --git a/env/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py b/env/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py index 6882c475..bebe24e6 100644 --- a/env/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py +++ b/env/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py @@ -1,7 +1,7 @@ """Legacy editable installation process, i.e. `setup.py develop`. """ import logging -from typing import List, Optional, Sequence +from typing import Optional, Sequence from pip._internal.build_env import BuildEnvironment from pip._internal.utils.logging import indent_log @@ -12,27 +12,25 @@ logger = logging.getLogger(__name__) def install_editable( - install_options, # type: List[str] - global_options, # type: Sequence[str] - prefix, # type: Optional[str] - home, # type: Optional[str] - use_user_site, # type: bool - name, # type: str - setup_py_path, # type: str - isolated, # type: bool - build_env, # type: BuildEnvironment - unpacked_source_directory, # type: str -): - # type: (...) -> None + *, + global_options: Sequence[str], + prefix: Optional[str], + home: Optional[str], + use_user_site: bool, + name: str, + setup_py_path: str, + isolated: bool, + build_env: BuildEnvironment, + unpacked_source_directory: str, +) -> None: """Install a package in editable mode. Most arguments are pass-through to setuptools. """ - logger.info('Running setup.py develop for %s', name) + logger.info("Running setup.py develop for %s", name) args = make_setuptools_develop_args( setup_py_path, global_options=global_options, - install_options=install_options, no_user_config=isolated, prefix=prefix, home=home, @@ -43,5 +41,6 @@ def install_editable( with build_env: call_subprocess( args, + command_desc="python setup.py develop", cwd=unpacked_source_directory, ) diff --git a/env/Lib/site-packages/pip/_internal/operations/install/legacy.py b/env/Lib/site-packages/pip/_internal/operations/install/legacy.py deleted file mode 100644 index 41d0c1f9..00000000 --- a/env/Lib/site-packages/pip/_internal/operations/install/legacy.py +++ /dev/null @@ -1,125 +0,0 @@ -"""Legacy installation process, i.e. `setup.py install`. -""" - -import logging -import os -import sys -from distutils.util import change_root -from typing import List, Optional, Sequence - -from pip._internal.build_env import BuildEnvironment -from pip._internal.exceptions import InstallationError -from pip._internal.models.scheme import Scheme -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import ensure_dir -from pip._internal.utils.setuptools_build import make_setuptools_install_args -from pip._internal.utils.subprocess import runner_with_spinner_message -from pip._internal.utils.temp_dir import TempDirectory - -logger = logging.getLogger(__name__) - - -class LegacyInstallFailure(Exception): - def __init__(self): - # type: () -> None - self.parent = sys.exc_info() - - -def install( - install_options, # type: List[str] - global_options, # type: Sequence[str] - root, # type: Optional[str] - home, # type: Optional[str] - prefix, # type: Optional[str] - use_user_site, # type: bool - pycompile, # type: bool - scheme, # type: Scheme - setup_py_path, # type: str - isolated, # type: bool - req_name, # type: str - build_env, # type: BuildEnvironment - unpacked_source_directory, # type: str - req_description, # type: str -): - # type: (...) -> bool - - header_dir = scheme.headers - - with TempDirectory(kind="record") as temp_dir: - try: - record_filename = os.path.join(temp_dir.path, 'install-record.txt') - install_args = make_setuptools_install_args( - setup_py_path, - global_options=global_options, - install_options=install_options, - record_filename=record_filename, - root=root, - prefix=prefix, - header_dir=header_dir, - home=home, - use_user_site=use_user_site, - no_user_config=isolated, - pycompile=pycompile, - ) - - runner = runner_with_spinner_message( - f"Running setup.py install for {req_name}" - ) - with indent_log(), build_env: - runner( - cmd=install_args, - cwd=unpacked_source_directory, - ) - - if not os.path.exists(record_filename): - logger.debug('Record file %s not found', record_filename) - # Signal to the caller that we didn't install the new package - return False - - except Exception: - # Signal to the caller that we didn't install the new package - raise LegacyInstallFailure - - # At this point, we have successfully installed the requirement. - - # We intentionally do not use any encoding to read the file because - # setuptools writes the file using distutils.file_util.write_file, - # which does not specify an encoding. - with open(record_filename) as f: - record_lines = f.read().splitlines() - - def prepend_root(path): - # type: (str) -> str - if root is None or not os.path.isabs(path): - return path - else: - return change_root(root, path) - - for line in record_lines: - directory = os.path.dirname(line) - if directory.endswith('.egg-info'): - egg_info_dir = prepend_root(directory) - break - else: - message = ( - "{} did not indicate that it installed an " - ".egg-info directory. Only setup.py projects " - "generating .egg-info directories are supported." - ).format(req_description) - raise InstallationError(message) - - new_lines = [] - for line in record_lines: - filename = line.strip() - if os.path.isdir(filename): - filename += os.path.sep - new_lines.append( - os.path.relpath(prepend_root(filename), egg_info_dir) - ) - new_lines.sort() - ensure_dir(egg_info_dir) - inst_files_path = os.path.join(egg_info_dir, 'installed-files.txt') - with open(inst_files_path, 'w') as f: - f.write('\n'.join(new_lines) + '\n') - - return True diff --git a/env/Lib/site-packages/pip/_internal/operations/install/wheel.py b/env/Lib/site-packages/pip/_internal/operations/install/wheel.py index 10e5b15f..a8cd1330 100644 --- a/env/Lib/site-packages/pip/_internal/operations/install/wheel.py +++ b/env/Lib/site-packages/pip/_internal/operations/install/wheel.py @@ -22,6 +22,7 @@ from typing import ( BinaryIO, Callable, Dict, + Generator, Iterable, Iterator, List, @@ -35,14 +36,17 @@ from typing import ( ) from zipfile import ZipFile, ZipInfo -from pip._vendor import pkg_resources from pip._vendor.distlib.scripts import ScriptMaker from pip._vendor.distlib.util import get_export_entry -from pip._vendor.pkg_resources import Distribution -from pip._vendor.six import ensure_str, ensure_text, reraise +from pip._vendor.packaging.utils import canonicalize_name from pip._internal.exceptions import InstallationError from pip._internal.locations import get_major_minor_version +from pip._internal.metadata import ( + BaseDistribution, + FilesystemWheel, + get_wheel_distribution, +) from pip._internal.models.direct_url import DIRECT_URL_METADATA_NAME, DirectUrl from pip._internal.models.scheme import SCHEME_KEYS, Scheme from pip._internal.utils.filesystem import adjacent_tmp_file, replace @@ -53,98 +57,76 @@ from pip._internal.utils.unpacking import ( set_extracted_file_to_default_mode_plus_executable, zip_item_is_executable, ) -from pip._internal.utils.wheel import parse_wheel, pkg_resources_distribution_for_wheel +from pip._internal.utils.wheel import parse_wheel if TYPE_CHECKING: from typing import Protocol class File(Protocol): - src_record_path = None # type: RecordPath - dest_path = None # type: str - changed = None # type: bool + src_record_path: "RecordPath" + dest_path: str + changed: bool - def save(self): - # type: () -> None + def save(self) -> None: pass logger = logging.getLogger(__name__) -RecordPath = NewType('RecordPath', str) +RecordPath = NewType("RecordPath", str) InstalledCSVRow = Tuple[RecordPath, str, Union[int, str]] -def rehash(path, blocksize=1 << 20): - # type: (str, int) -> Tuple[str, str] +def rehash(path: str, blocksize: int = 1 << 20) -> Tuple[str, str]: """Return (encoded_digest, length) for path using hashlib.sha256()""" h, length = hash_file(path, blocksize) - digest = 'sha256=' + urlsafe_b64encode( - h.digest() - ).decode('latin1').rstrip('=') + digest = "sha256=" + urlsafe_b64encode(h.digest()).decode("latin1").rstrip("=") return (digest, str(length)) -def csv_io_kwargs(mode): - # type: (str) -> Dict[str, Any] +def csv_io_kwargs(mode: str) -> Dict[str, Any]: """Return keyword arguments to properly open a CSV file in the given mode. """ - return {'mode': mode, 'newline': '', 'encoding': 'utf-8'} + return {"mode": mode, "newline": "", "encoding": "utf-8"} -def fix_script(path): - # type: (str) -> bool +def fix_script(path: str) -> bool: """Replace #!python with #!/path/to/python Return True if file was changed. """ # XXX RECORD hashes will need to be updated assert os.path.isfile(path) - with open(path, 'rb') as script: + with open(path, "rb") as script: firstline = script.readline() - if not firstline.startswith(b'#!python'): + if not firstline.startswith(b"#!python"): return False exename = sys.executable.encode(sys.getfilesystemencoding()) - firstline = b'#!' + exename + os.linesep.encode("ascii") + firstline = b"#!" + exename + os.linesep.encode("ascii") rest = script.read() - with open(path, 'wb') as script: + with open(path, "wb") as script: script.write(firstline) script.write(rest) return True -def wheel_root_is_purelib(metadata): - # type: (Message) -> bool +def wheel_root_is_purelib(metadata: Message) -> bool: return metadata.get("Root-Is-Purelib", "").lower() == "true" -def get_entrypoints(distribution): - # type: (Distribution) -> Tuple[Dict[str, str], Dict[str, str]] - # get the entry points and then the script names - try: - console = distribution.get_entry_map('console_scripts') - gui = distribution.get_entry_map('gui_scripts') - except KeyError: - # Our dict-based Distribution raises KeyError if entry_points.txt - # doesn't exist. - return {}, {} - - def _split_ep(s): - # type: (pkg_resources.EntryPoint) -> Tuple[str, str] - """get the string representation of EntryPoint, - remove space and split on '=' - """ - split_parts = str(s).replace(" ", "").split("=") - return split_parts[0], split_parts[1] - - # convert the EntryPoint objects into strings with module:function - console = dict(_split_ep(v) for v in console.values()) - gui = dict(_split_ep(v) for v in gui.values()) - return console, gui - - -def message_about_scripts_not_on_PATH(scripts): - # type: (Sequence[str]) -> Optional[str] +def get_entrypoints(dist: BaseDistribution) -> Tuple[Dict[str, str], Dict[str, str]]: + console_scripts = {} + gui_scripts = {} + for entry_point in dist.iter_entry_points(): + if entry_point.group == "console_scripts": + console_scripts[entry_point.name] = entry_point.value + elif entry_point.group == "gui_scripts": + gui_scripts[entry_point.name] = entry_point.value + return console_scripts, gui_scripts + + +def message_about_scripts_not_on_PATH(scripts: Sequence[str]) -> Optional[str]: """Determine if any scripts are not on PATH and format a warning. Returns a warning message if one or more scripts are not on PATH, otherwise None. @@ -153,7 +135,7 @@ def message_about_scripts_not_on_PATH(scripts): return None # Group scripts by the path they were installed in - grouped_by_dir = collections.defaultdict(set) # type: Dict[str, Set[str]] + grouped_by_dir: Dict[str, Set[str]] = collections.defaultdict(set) for destfile in scripts: parent_dir = os.path.dirname(destfile) script_name = os.path.basename(destfile) @@ -161,23 +143,26 @@ def message_about_scripts_not_on_PATH(scripts): # We don't want to warn for directories that are on PATH. not_warn_dirs = [ - os.path.normcase(i).rstrip(os.sep) for i in - os.environ.get("PATH", "").split(os.pathsep) + os.path.normcase(os.path.normpath(i)).rstrip(os.sep) + for i in os.environ.get("PATH", "").split(os.pathsep) ] # If an executable sits with sys.executable, we don't warn for it. # This covers the case of venv invocations without activating the venv. - not_warn_dirs.append(os.path.normcase(os.path.dirname(sys.executable))) - warn_for = { - parent_dir: scripts for parent_dir, scripts in grouped_by_dir.items() - if os.path.normcase(parent_dir) not in not_warn_dirs - } # type: Dict[str, Set[str]] + not_warn_dirs.append( + os.path.normcase(os.path.normpath(os.path.dirname(sys.executable))) + ) + warn_for: Dict[str, Set[str]] = { + parent_dir: scripts + for parent_dir, scripts in grouped_by_dir.items() + if os.path.normcase(os.path.normpath(parent_dir)) not in not_warn_dirs + } if not warn_for: return None # Format a message msg_lines = [] for parent_dir, dir_scripts in warn_for.items(): - sorted_scripts = sorted(dir_scripts) # type: List[str] + sorted_scripts: List[str] = sorted(dir_scripts) if len(sorted_scripts) == 1: start_text = "script {} is".format(sorted_scripts[0]) else: @@ -186,8 +171,9 @@ def message_about_scripts_not_on_PATH(scripts): ) msg_lines.append( - "The {} installed in '{}' which is not on PATH." - .format(start_text, parent_dir) + "The {} installed in '{}' which is not on PATH.".format( + start_text, parent_dir + ) ) last_line_fmt = ( @@ -214,8 +200,9 @@ def message_about_scripts_not_on_PATH(scripts): return "\n".join(msg_lines) -def _normalized_outrows(outrows): - # type: (Iterable[InstalledCSVRow]) -> List[Tuple[str, str, str]] +def _normalized_outrows( + outrows: Iterable[InstalledCSVRow], +) -> List[Tuple[str, str, str]]: """Normalize the given rows of a RECORD file. Items in each row are converted into str. Rows are then sorted to make @@ -235,69 +222,57 @@ def _normalized_outrows(outrows): # For additional background, see-- # https://github.com/pypa/pip/issues/5868 return sorted( - (ensure_str(record_path, encoding='utf-8'), hash_, str(size)) - for record_path, hash_, size in outrows + (record_path, hash_, str(size)) for record_path, hash_, size in outrows ) -def _record_to_fs_path(record_path): - # type: (RecordPath) -> str - return record_path - +def _record_to_fs_path(record_path: RecordPath, lib_dir: str) -> str: + return os.path.join(lib_dir, record_path) -def _fs_to_record_path(path, relative_to=None): - # type: (str, Optional[str]) -> RecordPath - if relative_to is not None: - # On Windows, do not handle relative paths if they belong to different - # logical disks - if os.path.splitdrive(path)[0].lower() == \ - os.path.splitdrive(relative_to)[0].lower(): - path = os.path.relpath(path, relative_to) - path = path.replace(os.path.sep, '/') - return cast('RecordPath', path) +def _fs_to_record_path(path: str, lib_dir: str) -> RecordPath: + # On Windows, do not handle relative paths if they belong to different + # logical disks + if os.path.splitdrive(path)[0].lower() == os.path.splitdrive(lib_dir)[0].lower(): + path = os.path.relpath(path, lib_dir) -def _parse_record_path(record_column): - # type: (str) -> RecordPath - p = ensure_text(record_column, encoding='utf-8') - return cast('RecordPath', p) + path = path.replace(os.path.sep, "/") + return cast("RecordPath", path) def get_csv_rows_for_installed( - old_csv_rows, # type: List[List[str]] - installed, # type: Dict[RecordPath, RecordPath] - changed, # type: Set[RecordPath] - generated, # type: List[str] - lib_dir, # type: str -): - # type: (...) -> List[InstalledCSVRow] + old_csv_rows: List[List[str]], + installed: Dict[RecordPath, RecordPath], + changed: Set[RecordPath], + generated: List[str], + lib_dir: str, +) -> List[InstalledCSVRow]: """ :param installed: A map from archive RECORD path to installation RECORD path. """ - installed_rows = [] # type: List[InstalledCSVRow] + installed_rows: List[InstalledCSVRow] = [] for row in old_csv_rows: if len(row) > 3: - logger.warning('RECORD line has more than three elements: %s', row) - old_record_path = _parse_record_path(row[0]) + logger.warning("RECORD line has more than three elements: %s", row) + old_record_path = cast("RecordPath", row[0]) new_record_path = installed.pop(old_record_path, old_record_path) if new_record_path in changed: - digest, length = rehash(_record_to_fs_path(new_record_path)) + digest, length = rehash(_record_to_fs_path(new_record_path, lib_dir)) else: - digest = row[1] if len(row) > 1 else '' - length = row[2] if len(row) > 2 else '' + digest = row[1] if len(row) > 1 else "" + length = row[2] if len(row) > 2 else "" installed_rows.append((new_record_path, digest, length)) for f in generated: path = _fs_to_record_path(f, lib_dir) digest, length = rehash(f) installed_rows.append((path, digest, length)) for installed_record_path in installed.values(): - installed_rows.append((installed_record_path, '', '')) + installed_rows.append((installed_record_path, "", "")) return installed_rows -def get_console_script_specs(console): - # type: (Dict[str, str]) -> List[str] +def get_console_script_specs(console: Dict[str, str]) -> List[str]: """ Given the mapping from entrypoint name to callable, return the relevant console script specs. @@ -340,62 +315,57 @@ def get_console_script_specs(console): # DEFAULT # - The default behavior is to install pip, pipX, pipX.Y, easy_install # and easy_install-X.Y. - pip_script = console.pop('pip', None) + pip_script = console.pop("pip", None) if pip_script: if "ENSUREPIP_OPTIONS" not in os.environ: - scripts_to_generate.append('pip = ' + pip_script) + scripts_to_generate.append("pip = " + pip_script) if os.environ.get("ENSUREPIP_OPTIONS", "") != "altinstall": scripts_to_generate.append( - 'pip{} = {}'.format(sys.version_info[0], pip_script) + "pip{} = {}".format(sys.version_info[0], pip_script) ) - scripts_to_generate.append( - f'pip{get_major_minor_version()} = {pip_script}' - ) + scripts_to_generate.append(f"pip{get_major_minor_version()} = {pip_script}") # Delete any other versioned pip entry points - pip_ep = [k for k in console if re.match(r'pip(\d(\.\d)?)?$', k)] + pip_ep = [k for k in console if re.match(r"pip(\d+(\.\d+)?)?$", k)] for k in pip_ep: del console[k] - easy_install_script = console.pop('easy_install', None) + easy_install_script = console.pop("easy_install", None) if easy_install_script: if "ENSUREPIP_OPTIONS" not in os.environ: - scripts_to_generate.append( - 'easy_install = ' + easy_install_script - ) + scripts_to_generate.append("easy_install = " + easy_install_script) scripts_to_generate.append( - 'easy_install-{} = {}'.format( + "easy_install-{} = {}".format( get_major_minor_version(), easy_install_script ) ) # Delete any other versioned easy_install entry points easy_install_ep = [ - k for k in console if re.match(r'easy_install(-\d\.\d)?$', k) + k for k in console if re.match(r"easy_install(-\d+\.\d+)?$", k) ] for k in easy_install_ep: del console[k] # Generate the console entry points specified in the wheel - scripts_to_generate.extend(starmap('{} = {}'.format, console.items())) + scripts_to_generate.extend(starmap("{} = {}".format, console.items())) return scripts_to_generate class ZipBackedFile: - def __init__(self, src_record_path, dest_path, zip_file): - # type: (RecordPath, str, ZipFile) -> None + def __init__( + self, src_record_path: RecordPath, dest_path: str, zip_file: ZipFile + ) -> None: self.src_record_path = src_record_path self.dest_path = dest_path self._zip_file = zip_file self.changed = False - def _getinfo(self): - # type: () -> ZipInfo + def _getinfo(self) -> ZipInfo: return self._zip_file.getinfo(self.src_record_path) - def save(self): - # type: () -> None + def save(self) -> None: # directory creation is lazy and after file filtering # to ensure we don't install empty dirs; empty dirs can't be # uninstalled. @@ -424,22 +394,19 @@ class ZipBackedFile: class ScriptFile: - def __init__(self, file): - # type: (File) -> None + def __init__(self, file: "File") -> None: self._file = file self.src_record_path = self._file.src_record_path self.dest_path = self._file.dest_path self.changed = False - def save(self): - # type: () -> None + def save(self) -> None: self._file.save() self.changed = fix_script(self.dest_path) class MissingCallableSuffix(InstallationError): - def __init__(self, entry_point): - # type: (str) -> None + def __init__(self, entry_point: str) -> None: super().__init__( "Invalid script entry point: {} - A callable " "suffix is required. Cf https://packaging.python.org/" @@ -448,31 +415,30 @@ class MissingCallableSuffix(InstallationError): ) -def _raise_for_invalid_entrypoint(specification): - # type: (str) -> None +def _raise_for_invalid_entrypoint(specification: str) -> None: entry = get_export_entry(specification) if entry is not None and entry.suffix is None: raise MissingCallableSuffix(str(entry)) class PipScriptMaker(ScriptMaker): - def make(self, specification, options=None): - # type: (str, Dict[str, Any]) -> List[str] + def make( + self, specification: str, options: Optional[Dict[str, Any]] = None + ) -> List[str]: _raise_for_invalid_entrypoint(specification) return super().make(specification, options) def _install_wheel( - name, # type: str - wheel_zip, # type: ZipFile - wheel_path, # type: str - scheme, # type: Scheme - pycompile=True, # type: bool - warn_script_location=True, # type: bool - direct_url=None, # type: Optional[DirectUrl] - requested=False, # type: bool -): - # type: (...) -> None + name: str, + wheel_zip: ZipFile, + wheel_path: str, + scheme: Scheme, + pycompile: bool = True, + warn_script_location: bool = True, + direct_url: Optional[DirectUrl] = None, + requested: bool = False, +) -> None: """Install a wheel. :param name: Name of the project to install @@ -499,33 +465,23 @@ def _install_wheel( # installed = files copied from the wheel to the destination # changed = files changed while installing (scripts #! line typically) # generated = files newly generated during the install (script wrappers) - installed = {} # type: Dict[RecordPath, RecordPath] - changed = set() # type: Set[RecordPath] - generated = [] # type: List[str] + installed: Dict[RecordPath, RecordPath] = {} + changed: Set[RecordPath] = set() + generated: List[str] = [] - def record_installed(srcfile, destfile, modified=False): - # type: (RecordPath, str, bool) -> None + def record_installed( + srcfile: RecordPath, destfile: str, modified: bool = False + ) -> None: """Map archive RECORD paths to installation RECORD paths.""" newpath = _fs_to_record_path(destfile, lib_dir) installed[srcfile] = newpath if modified: - changed.add(_fs_to_record_path(destfile)) - - def all_paths(): - # type: () -> Iterable[RecordPath] - names = wheel_zip.namelist() - # If a flag is set, names may be unicode in Python 2. We convert to - # text explicitly so these are valid for lookup in RECORD. - decoded_names = map(ensure_text, names) - for name in decoded_names: - yield cast("RecordPath", name) - - def is_dir_path(path): - # type: (RecordPath) -> bool + changed.add(newpath) + + def is_dir_path(path: RecordPath) -> bool: return path.endswith("/") - def assert_no_path_traversal(dest_dir_path, target_path): - # type: (str, str) -> None + def assert_no_path_traversal(dest_dir_path: str, target_path: str) -> None: if not is_within_directory(dest_dir_path, target_path): message = ( "The wheel {!r} has a file {!r} trying to install" @@ -535,10 +491,10 @@ def _install_wheel( message.format(wheel_path, target_path, dest_dir_path) ) - def root_scheme_file_maker(zip_file, dest): - # type: (ZipFile, str) -> Callable[[RecordPath], File] - def make_root_scheme_file(record_path): - # type: (RecordPath) -> File + def root_scheme_file_maker( + zip_file: ZipFile, dest: str + ) -> Callable[[RecordPath], "File"]: + def make_root_scheme_file(record_path: RecordPath) -> "File": normed_path = os.path.normpath(record_path) dest_path = os.path.join(dest, normed_path) assert_no_path_traversal(dest, dest_path) @@ -546,17 +502,12 @@ def _install_wheel( return make_root_scheme_file - def data_scheme_file_maker(zip_file, scheme): - # type: (ZipFile, Scheme) -> Callable[[RecordPath], File] - scheme_paths = {} - for key in SCHEME_KEYS: - encoded_key = ensure_text(key) - scheme_paths[encoded_key] = ensure_text( - getattr(scheme, key), encoding=sys.getfilesystemencoding() - ) + def data_scheme_file_maker( + zip_file: ZipFile, scheme: Scheme + ) -> Callable[[RecordPath], "File"]: + scheme_paths = {key: getattr(scheme, key) for key in SCHEME_KEYS} - def make_data_scheme_file(record_path): - # type: (RecordPath) -> File + def make_data_scheme_file(record_path: RecordPath) -> "File": normed_path = os.path.normpath(record_path) try: _, scheme_key, dest_subpath = normed_path.split(os.path.sep, 2) @@ -575,9 +526,7 @@ def _install_wheel( "Unknown scheme key used in {}: {} (for file {!r}). .data" " directory contents should be in subdirectories named" " with a valid scheme key ({})" - ).format( - wheel_path, scheme_key, record_path, valid_scheme_keys - ) + ).format(wheel_path, scheme_key, record_path, valid_scheme_keys) raise InstallationError(message) dest_path = os.path.join(scheme_path, dest_subpath) @@ -586,30 +535,19 @@ def _install_wheel( return make_data_scheme_file - def is_data_scheme_path(path): - # type: (RecordPath) -> bool + def is_data_scheme_path(path: RecordPath) -> bool: return path.split("/", 1)[0].endswith(".data") - paths = all_paths() + paths = cast(List[RecordPath], wheel_zip.namelist()) file_paths = filterfalse(is_dir_path, paths) - root_scheme_paths, data_scheme_paths = partition( - is_data_scheme_path, file_paths - ) + root_scheme_paths, data_scheme_paths = partition(is_data_scheme_path, file_paths) - make_root_scheme_file = root_scheme_file_maker( - wheel_zip, - ensure_text(lib_dir, encoding=sys.getfilesystemencoding()), - ) - files = map(make_root_scheme_file, root_scheme_paths) + make_root_scheme_file = root_scheme_file_maker(wheel_zip, lib_dir) + files: Iterator[File] = map(make_root_scheme_file, root_scheme_paths) - def is_script_scheme_path(path): - # type: (RecordPath) -> bool + def is_script_scheme_path(path: RecordPath) -> bool: parts = path.split("/", 2) - return ( - len(parts) > 2 and - parts[0].endswith(".data") and - parts[1] == "scripts" - ) + return len(parts) > 2 and parts[0].endswith(".data") and parts[1] == "scripts" other_scheme_paths, script_scheme_paths = partition( is_script_scheme_path, data_scheme_paths @@ -620,32 +558,32 @@ def _install_wheel( files = chain(files, other_scheme_files) # Get the defined entry points - distribution = pkg_resources_distribution_for_wheel( - wheel_zip, name, wheel_path + distribution = get_wheel_distribution( + FilesystemWheel(wheel_path), + canonicalize_name(name), ) console, gui = get_entrypoints(distribution) - def is_entrypoint_wrapper(file): - # type: (File) -> bool + def is_entrypoint_wrapper(file: "File") -> bool: # EP, EP.exe and EP-script.py are scripts generated for # entry point EP by setuptools path = file.dest_path name = os.path.basename(path) - if name.lower().endswith('.exe'): + if name.lower().endswith(".exe"): matchname = name[:-4] - elif name.lower().endswith('-script.py'): + elif name.lower().endswith("-script.py"): matchname = name[:-10] elif name.lower().endswith(".pya"): matchname = name[:-4] else: matchname = name # Ignore setuptools-generated scripts - return (matchname in console or matchname in gui) + return matchname in console or matchname in gui - script_scheme_files = map(make_data_scheme_file, script_scheme_paths) - script_scheme_files = filterfalse( - is_entrypoint_wrapper, script_scheme_files + script_scheme_files: Iterator[File] = map( + make_data_scheme_file, script_scheme_paths ) + script_scheme_files = filterfalse(is_entrypoint_wrapper, script_scheme_files) script_scheme_files = map(ScriptFile, script_scheme_files) files = chain(files, script_scheme_files) @@ -653,8 +591,7 @@ def _install_wheel( file.save() record_installed(file.src_record_path, file.dest_path, file.changed) - def pyc_source_file_paths(): - # type: () -> Iterator[str] + def pyc_source_file_paths() -> Generator[str, None, None]: # We de-duplicate installation paths, since there can be overlap (e.g. # file in .data maps to same location as file in wheel root). # Sorting installation paths makes it easier to reproduce and debug @@ -663,30 +600,21 @@ def _install_wheel( full_installed_path = os.path.join(lib_dir, installed_path) if not os.path.isfile(full_installed_path): continue - if not full_installed_path.endswith('.py'): + if not full_installed_path.endswith(".py"): continue yield full_installed_path - def pyc_output_path(path): - # type: (str) -> str - """Return the path the pyc file would have been written to. - """ + def pyc_output_path(path: str) -> str: + """Return the path the pyc file would have been written to.""" return importlib.util.cache_from_source(path) # Compile all of the pyc files for the installed files if pycompile: with captured_stdout() as stdout: with warnings.catch_warnings(): - warnings.filterwarnings('ignore') + warnings.filterwarnings("ignore") for path in pyc_source_file_paths(): - # Python 2's `compileall.compile_file` requires a str in - # error cases, so we must convert to the native type. - path_arg = ensure_str( - path, encoding=sys.getfilesystemencoding() - ) - success = compileall.compile_file( - path_arg, force=True, quiet=True - ) + success = compileall.compile_file(path, force=True, quiet=True) if success: pyc_path = pyc_output_path(path) assert os.path.exists(pyc_path) @@ -705,7 +633,7 @@ def _install_wheel( # Ensure we don't generate any variants for scripts because this is almost # never what somebody wants. # See https://bitbucket.org/pypa/distlib/issue/35/ - maker.variants = {''} + maker.variants = {""} # This is required because otherwise distlib creates scripts that are not # executable. @@ -715,14 +643,12 @@ def _install_wheel( # Generate the console and GUI entry points specified in the wheel scripts_to_generate = get_console_script_specs(console) - gui_scripts_to_generate = list(starmap('{} = {}'.format, gui.items())) + gui_scripts_to_generate = list(starmap("{} = {}".format, gui.items())) generated_console_scripts = maker.make_multiple(scripts_to_generate) generated.extend(generated_console_scripts) - generated.extend( - maker.make_multiple(gui_scripts_to_generate, {'gui': True}) - ) + generated.extend(maker.make_multiple(gui_scripts_to_generate, {"gui": True})) if warn_script_location: msg = message_about_scripts_not_on_PATH(generated_console_scripts) @@ -732,8 +658,7 @@ def _install_wheel( generated_file_mode = 0o666 & ~current_umask() @contextlib.contextmanager - def _generate_file(path, **kwargs): - # type: (str, **Any) -> Iterator[BinaryIO] + def _generate_file(path: str, **kwargs: Any) -> Generator[BinaryIO, None, None]: with adjacent_tmp_file(path, **kwargs) as f: yield f os.chmod(f.name, generated_file_mode) @@ -742,9 +667,9 @@ def _install_wheel( dest_info_dir = os.path.join(lib_dir, info_dir) # Record pip as the installer - installer_path = os.path.join(dest_info_dir, 'INSTALLER') + installer_path = os.path.join(dest_info_dir, "INSTALLER") with _generate_file(installer_path) as installer_file: - installer_file.write(b'pip\n') + installer_file.write(b"pip\n") generated.append(installer_path) # Record the PEP 610 direct URL reference @@ -756,12 +681,12 @@ def _install_wheel( # Record the REQUESTED file if requested: - requested_path = os.path.join(dest_info_dir, 'REQUESTED') + requested_path = os.path.join(dest_info_dir, "REQUESTED") with open(requested_path, "wb"): pass generated.append(requested_path) - record_text = distribution.get_metadata('RECORD') + record_text = distribution.read_text("RECORD") record_rows = list(csv.reader(record_text.splitlines())) rows = get_csv_rows_for_installed( @@ -769,42 +694,38 @@ def _install_wheel( installed=installed, changed=changed, generated=generated, - lib_dir=lib_dir) + lib_dir=lib_dir, + ) # Record details of all files installed - record_path = os.path.join(dest_info_dir, 'RECORD') + record_path = os.path.join(dest_info_dir, "RECORD") - with _generate_file(record_path, **csv_io_kwargs('w')) as record_file: - # The type mypy infers for record_file is different for Python 3 - # (typing.IO[Any]) and Python 2 (typing.BinaryIO). We explicitly - # cast to typing.IO[str] as a workaround. - writer = csv.writer(cast('IO[str]', record_file)) + with _generate_file(record_path, **csv_io_kwargs("w")) as record_file: + # Explicitly cast to typing.IO[str] as a workaround for the mypy error: + # "writer" has incompatible type "BinaryIO"; expected "_Writer" + writer = csv.writer(cast("IO[str]", record_file)) writer.writerows(_normalized_outrows(rows)) @contextlib.contextmanager -def req_error_context(req_description): - # type: (str) -> Iterator[None] +def req_error_context(req_description: str) -> Generator[None, None, None]: try: yield except InstallationError as e: message = "For req: {}. {}".format(req_description, e.args[0]) - reraise( - InstallationError, InstallationError(message), sys.exc_info()[2] - ) + raise InstallationError(message) from e def install_wheel( - name, # type: str - wheel_path, # type: str - scheme, # type: Scheme - req_description, # type: str - pycompile=True, # type: bool - warn_script_location=True, # type: bool - direct_url=None, # type: Optional[DirectUrl] - requested=False, # type: bool -): - # type: (...) -> None + name: str, + wheel_path: str, + scheme: Scheme, + req_description: str, + pycompile: bool = True, + warn_script_location: bool = True, + direct_url: Optional[DirectUrl] = None, + requested: bool = False, +) -> None: with ZipFile(wheel_path, allowZip64=True) as z: with req_error_context(req_description): _install_wheel( diff --git a/env/Lib/site-packages/pip/_internal/operations/prepare.py b/env/Lib/site-packages/pip/_internal/operations/prepare.py index 3d074f9f..cb121bcb 100644 --- a/env/Lib/site-packages/pip/_internal/operations/prepare.py +++ b/env/Lib/site-packages/pip/_internal/operations/prepare.py @@ -8,10 +8,9 @@ import logging import mimetypes import os import shutil -from typing import Dict, Iterable, List, Optional, Tuple +from typing import Dict, Iterable, List, Optional from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.pkg_resources import Distribution from pip._internal.distributions import make_distribution_for_install_requirement from pip._internal.distributions.installed import InstalledDistribution @@ -20,11 +19,14 @@ from pip._internal.exceptions import ( HashMismatch, HashUnpinned, InstallationError, + MetadataInconsistent, NetworkConnectionError, PreviousBuildDirError, VcsHashUnsupported, ) from pip._internal.index.package_finder import PackageFinder +from pip._internal.metadata import BaseDistribution, get_metadata_distribution +from pip._internal.models.direct_url import ArchiveInfo from pip._internal.models.link import Link from pip._internal.models.wheel import Wheel from pip._internal.network.download import BatchDownloader, Downloader @@ -33,13 +35,20 @@ from pip._internal.network.lazy_wheel import ( dist_from_wheel_url, ) from pip._internal.network.session import PipSession +from pip._internal.operations.build.build_tracker import BuildTracker from pip._internal.req.req_install import InstallRequirement -from pip._internal.req.req_tracker import RequirementTracker -from pip._internal.utils.deprecation import deprecated -from pip._internal.utils.filesystem import copy2_fixed +from pip._internal.utils.direct_url_helpers import ( + direct_url_for_editable, + direct_url_from_link, +) from pip._internal.utils.hashes import Hashes, MissingHashes from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import display_path, hide_url, rmtree +from pip._internal.utils.misc import ( + display_path, + hash_file, + hide_url, + is_installable_dir, +) from pip._internal.utils.temp_dir import TempDirectory from pip._internal.utils.unpacking import unpack_file from pip._internal.vcs import vcs @@ -48,30 +57,29 @@ logger = logging.getLogger(__name__) def _get_prepared_distribution( - req, # type: InstallRequirement - req_tracker, # type: RequirementTracker - finder, # type: PackageFinder - build_isolation, # type: bool -): - # type: (...) -> Distribution + req: InstallRequirement, + build_tracker: BuildTracker, + finder: PackageFinder, + build_isolation: bool, + check_build_deps: bool, +) -> BaseDistribution: """Prepare a distribution for installation.""" abstract_dist = make_distribution_for_install_requirement(req) - with req_tracker.track(req): - abstract_dist.prepare_distribution_metadata(finder, build_isolation) - return abstract_dist.get_pkg_resources_distribution() + with build_tracker.track(req): + abstract_dist.prepare_distribution_metadata( + finder, build_isolation, check_build_deps + ) + return abstract_dist.get_metadata_distribution() -def unpack_vcs_link(link, location): - # type: (Link, str) -> None +def unpack_vcs_link(link: Link, location: str, verbosity: int) -> None: vcs_backend = vcs.get_backend_for_scheme(link.scheme) assert vcs_backend is not None - vcs_backend.unpack(location, url=hide_url(link.url)) + vcs_backend.unpack(location, url=hide_url(link.url), verbosity=verbosity) class File: - - def __init__(self, path, content_type): - # type: (str, Optional[str]) -> None + def __init__(self, path: str, content_type: Optional[str]) -> None: self.path = path if content_type is None: self.content_type = mimetypes.guess_type(path)[0] @@ -80,19 +88,16 @@ class File: def get_http_url( - link, # type: Link - download, # type: Downloader - download_dir=None, # type: Optional[str] - hashes=None, # type: Optional[Hashes] -): - # type: (...) -> File + link: Link, + download: Downloader, + download_dir: Optional[str] = None, + hashes: Optional[Hashes] = None, +) -> File: temp_dir = TempDirectory(kind="unpack", globally_managed=True) # If a download dir is specified, is the file already downloaded there? already_downloaded_path = None if download_dir: - already_downloaded_path = _check_download_dir( - link, download_dir, hashes - ) + already_downloaded_path = _check_download_dir(link, download_dir, hashes) if already_downloaded_path: from_path = already_downloaded_path @@ -106,72 +111,14 @@ def get_http_url( return File(from_path, content_type) -def _copy2_ignoring_special_files(src, dest): - # type: (str, str) -> None - """Copying special files is not supported, but as a convenience to users - we skip errors copying them. This supports tools that may create e.g. - socket files in the project source directory. - """ - try: - copy2_fixed(src, dest) - except shutil.SpecialFileError as e: - # SpecialFileError may be raised due to either the source or - # destination. If the destination was the cause then we would actually - # care, but since the destination directory is deleted prior to - # copy we ignore all of them assuming it is caused by the source. - logger.warning( - "Ignoring special file error '%s' encountered copying %s to %s.", - str(e), - src, - dest, - ) - - -def _copy_source_tree(source, target): - # type: (str, str) -> None - target_abspath = os.path.abspath(target) - target_basename = os.path.basename(target_abspath) - target_dirname = os.path.dirname(target_abspath) - - def ignore(d, names): - # type: (str, List[str]) -> List[str] - skipped = [] # type: List[str] - if d == source: - # Pulling in those directories can potentially be very slow, - # exclude the following directories if they appear in the top - # level dir (and only it). - # See discussion at https://github.com/pypa/pip/pull/6770 - skipped += ['.tox', '.nox'] - if os.path.abspath(d) == target_dirname: - # Prevent an infinite recursion if the target is in source. - # This can happen when TMPDIR is set to ${PWD}/... - # and we copy PWD to TMPDIR. - skipped += [target_basename] - return skipped - - shutil.copytree( - source, - target, - ignore=ignore, - symlinks=True, - copy_function=_copy2_ignoring_special_files, - ) - - def get_file_url( - link, # type: Link - download_dir=None, # type: Optional[str] - hashes=None # type: Optional[Hashes] -): - # type: (...) -> File - """Get file and optionally check its hash. - """ + link: Link, download_dir: Optional[str] = None, hashes: Optional[Hashes] = None +) -> File: + """Get file and optionally check its hash.""" # If a download dir is specified, is the file already there and valid? already_downloaded_path = None if download_dir: - already_downloaded_path = _check_download_dir( - link, download_dir, hashes - ) + already_downloaded_path = _check_download_dir(link, download_dir, hashes) if already_downloaded_path: from_path = already_downloaded_path @@ -189,13 +136,13 @@ def get_file_url( def unpack_url( - link, # type: Link - location, # type: str - download, # type: Downloader - download_dir=None, # type: Optional[str] - hashes=None, # type: Optional[Hashes] -): - # type: (...) -> Optional[File] + link: Link, + location: str, + download: Downloader, + verbosity: int, + download_dir: Optional[str] = None, + hashes: Optional[Hashes] = None, +) -> Optional[File]: """Unpack link into location, downloading if required. :param hashes: A Hashes object, one of whose embedded hashes must match, @@ -205,30 +152,10 @@ def unpack_url( """ # non-editable vcs urls if link.is_vcs: - unpack_vcs_link(link, location) + unpack_vcs_link(link, location, verbosity=verbosity) return None - # Once out-of-tree-builds are no longer supported, could potentially - # replace the below condition with `assert not link.is_existing_dir` - # - unpack_url does not need to be called for in-tree-builds. - # - # As further cleanup, _copy_source_tree and accompanying tests can - # be removed. - if link.is_existing_dir(): - deprecated( - "A future pip version will change local packages to be built " - "in-place without first copying to a temporary directory. " - "We recommend you use --use-feature=in-tree-build to test " - "your packages with this new behavior before it becomes the " - "default.\n", - replacement=None, - gone_in="21.3", - issue=7555 - ) - if os.path.isdir(location): - rmtree(location) - _copy_source_tree(link.file_path, location) - return None + assert not link.is_existing_dir() # file urls if link.is_file: @@ -251,10 +178,14 @@ def unpack_url( return file -def _check_download_dir(link, download_dir, hashes): - # type: (Link, str, Optional[Hashes]) -> Optional[str] - """ Check download_dir for previously downloaded file with correct hash - If a correct file is found return its path else None +def _check_download_dir( + link: Link, + download_dir: str, + hashes: Optional[Hashes], + warn_on_hash_mismatch: bool = True, +) -> Optional[str]: + """Check download_dir for previously downloaded file with correct hash + If a correct file is found return its path else None """ download_path = os.path.join(download_dir, link.filename) @@ -262,46 +193,46 @@ def _check_download_dir(link, download_dir, hashes): return None # If already downloaded, does its hash match? - logger.info('File was already downloaded %s', download_path) + logger.info("File was already downloaded %s", download_path) if hashes: try: hashes.check_against_path(download_path) except HashMismatch: - logger.warning( - 'Previously-downloaded file %s has bad hash. ' - 'Re-downloading.', - download_path - ) + if warn_on_hash_mismatch: + logger.warning( + "Previously-downloaded file %s has bad hash. Re-downloading.", + download_path, + ) os.unlink(download_path) return None return download_path class RequirementPreparer: - """Prepares a Requirement - """ + """Prepares a Requirement""" def __init__( self, - build_dir, # type: str - download_dir, # type: Optional[str] - src_dir, # type: str - build_isolation, # type: bool - req_tracker, # type: RequirementTracker - session, # type: PipSession - progress_bar, # type: str - finder, # type: PackageFinder - require_hashes, # type: bool - use_user_site, # type: bool - lazy_wheel, # type: bool - in_tree_build, # type: bool - ): - # type: (...) -> None + build_dir: str, + download_dir: Optional[str], + src_dir: str, + build_isolation: bool, + check_build_deps: bool, + build_tracker: BuildTracker, + session: PipSession, + progress_bar: str, + finder: PackageFinder, + require_hashes: bool, + use_user_site: bool, + lazy_wheel: bool, + verbosity: int, + legacy_resolver: bool, + ) -> None: super().__init__() self.src_dir = src_dir self.build_dir = build_dir - self.req_tracker = req_tracker + self.build_tracker = build_tracker self._session = session self._download = Downloader(session, progress_bar) self._batch_download = BatchDownloader(session, progress_bar) @@ -314,6 +245,9 @@ class RequirementPreparer: # Is build isolation allowed? self.build_isolation = build_isolation + # Should check build dependencies? + self.check_build_deps = check_build_deps + # Should hash-checking be required? self.require_hashes = require_hashes @@ -323,35 +257,48 @@ class RequirementPreparer: # Should wheels be downloaded lazily? self.use_lazy_wheel = lazy_wheel - # Should in-tree builds be used for local paths? - self.in_tree_build = in_tree_build + # How verbose should underlying tooling be? + self.verbosity = verbosity + + # Are we using the legacy resolver? + self.legacy_resolver = legacy_resolver - # Memoized downloaded files, as mapping of url: (path, mime type) - self._downloaded = {} # type: Dict[str, Tuple[str, str]] + # Memoized downloaded files, as mapping of url: path. + self._downloaded: Dict[str, str] = {} # Previous "header" printed for a link-based InstallRequirement self._previous_requirement_header = ("", "") - def _log_preparing_link(self, req): - # type: (InstallRequirement) -> None + def _log_preparing_link(self, req: InstallRequirement) -> None: """Provide context for the requirement being prepared.""" - if req.link.is_file and not req.original_link_is_in_wheel_cache: + if req.link.is_file and not req.is_wheel_from_cache: message = "Processing %s" information = str(display_path(req.link.file_path)) else: message = "Collecting %s" information = str(req.req or req) + # If we used req.req, inject requirement source if available (this + # would already be included if we used req directly) + if req.req and req.comes_from: + if isinstance(req.comes_from, str): + comes_from: Optional[str] = req.comes_from + else: + comes_from = req.comes_from.from_path() + if comes_from: + information += f" (from {comes_from})" + if (message, information) != self._previous_requirement_header: self._previous_requirement_header = (message, information) logger.info(message, information) - if req.original_link_is_in_wheel_cache: + if req.is_wheel_from_cache: with indent_log(): logger.info("Using cached %s", req.link.filename) - def _ensure_link_req_src_dir(self, req, parallel_builds): - # type: (InstallRequirement, bool) -> None + def _ensure_link_req_src_dir( + self, req: InstallRequirement, parallel_builds: bool + ) -> None: """Ensure source_dir of a linked InstallRequirement.""" # Since source_dir is only set for editable requirements. if req.link.is_wheel: @@ -359,7 +306,7 @@ class RequirementPreparer: # directory. return assert req.source_dir is None - if req.link.is_existing_dir() and self.in_tree_build: + if req.link.is_existing_dir(): # build local directories in-tree req.source_dir = req.link.file_path return @@ -376,7 +323,8 @@ class RequirementPreparer: # installation. # FIXME: this won't upgrade when there's an existing # package unpacked in `req.source_dir` - if os.path.exists(os.path.join(req.source_dir, 'setup.py')): + # TODO: this check is now probably dead code + if is_installable_dir(req.source_dir): raise PreviousBuildDirError( "pip can't proceed with requirements '{}' due to a" "pre-existing build directory ({}). This is likely " @@ -385,8 +333,7 @@ class RequirementPreparer: "Please delete it and try again.".format(req, req.source_dir) ) - def _get_linked_req_hashes(self, req): - # type: (InstallRequirement) -> Hashes + def _get_linked_req_hashes(self, req: InstallRequirement) -> Hashes: # By the time this is called, the requirement's link should have # been checked so we can tell what kind of requirements req is # and raise some more informative errors than otherwise. @@ -409,7 +356,7 @@ class RequirementPreparer: # a surprising hash mismatch in the future. # file:/// URLs aren't pinnable, so don't complain about them # not being pinned. - if req.original_link is None and not req.is_pinned: + if not req.is_direct and not req.is_pinned: raise HashUnpinned() # If known-good hashes are missing for this requirement, @@ -418,18 +365,77 @@ class RequirementPreparer: # showing the user what the hash should be. return req.hashes(trust_internet=False) or MissingHashes() - def _fetch_metadata_using_lazy_wheel(self, link): - # type: (Link) -> Optional[Distribution] - """Fetch metadata using lazy wheel, if possible.""" - if not self.use_lazy_wheel: + def _fetch_metadata_only( + self, + req: InstallRequirement, + ) -> Optional[BaseDistribution]: + if self.legacy_resolver: + logger.debug( + "Metadata-only fetching is not used in the legacy resolver", + ) return None if self.require_hashes: - logger.debug('Lazy wheel is not used as hash checking is required') + logger.debug( + "Metadata-only fetching is not used as hash checking is required", + ) + return None + # Try PEP 658 metadata first, then fall back to lazy wheel if unavailable. + return self._fetch_metadata_using_link_data_attr( + req + ) or self._fetch_metadata_using_lazy_wheel(req.link) + + def _fetch_metadata_using_link_data_attr( + self, + req: InstallRequirement, + ) -> Optional[BaseDistribution]: + """Fetch metadata from the data-dist-info-metadata attribute, if possible.""" + # (1) Get the link to the metadata file, if provided by the backend. + metadata_link = req.link.metadata_link() + if metadata_link is None: + return None + assert req.req is not None + logger.info( + "Obtaining dependency information for %s from %s", + req.req, + metadata_link, + ) + # (2) Download the contents of the METADATA file, separate from the dist itself. + metadata_file = get_http_url( + metadata_link, + self._download, + hashes=metadata_link.as_hashes(), + ) + with open(metadata_file.path, "rb") as f: + metadata_contents = f.read() + # (3) Generate a dist just from those file contents. + metadata_dist = get_metadata_distribution( + metadata_contents, + req.link.filename, + req.req.name, + ) + # (4) Ensure the Name: field from the METADATA file matches the name from the + # install requirement. + # + # NB: raw_name will fall back to the name from the install requirement if + # the Name: field is not present, but it's noted in the raw_name docstring + # that that should NEVER happen anyway. + if canonicalize_name(metadata_dist.raw_name) != canonicalize_name(req.req.name): + raise MetadataInconsistent( + req, "Name", req.req.name, metadata_dist.raw_name + ) + return metadata_dist + + def _fetch_metadata_using_lazy_wheel( + self, + link: Link, + ) -> Optional[BaseDistribution]: + """Fetch metadata using lazy wheel, if possible.""" + # --use-feature=fast-deps must be provided. + if not self.use_lazy_wheel: return None if link.is_file or not link.is_wheel: logger.debug( - 'Lazy wheel is not used as ' - '%r does not points to a remote wheel', + "Lazy wheel is not used as %r does not point to a remote wheel", link, ) return None @@ -437,22 +443,22 @@ class RequirementPreparer: wheel = Wheel(link.filename) name = canonicalize_name(wheel.name) logger.info( - 'Obtaining dependency information from %s %s', - name, wheel.version, + "Obtaining dependency information from %s %s", + name, + wheel.version, ) - url = link.url.split('#', 1)[0] + url = link.url.split("#", 1)[0] try: return dist_from_wheel_url(name, url, self._session) except HTTPRangeRequestUnsupported: - logger.debug('%s does not support range requests', url) + logger.debug("%s does not support range requests", url) return None def _complete_partial_requirements( self, - partially_downloaded_reqs, # type: Iterable[InstallRequirement] - parallel_builds=False, # type: bool - ): - # type: (...) -> None + partially_downloaded_reqs: Iterable[InstallRequirement], + parallel_builds: bool = False, + ) -> None: """Download any requirements which were only fetched by metadata.""" # Download to a temporary directory. These will be copied over as # needed for downstream 'download', 'wheel', and 'install' commands. @@ -461,7 +467,7 @@ class RequirementPreparer: # Map each link to the requirement that owns it. This allows us to set # `req.local_file_path` on the appropriate requirement after passing # all the links at once into BatchDownloader. - links_to_fully_download = {} # type: Dict[Link, InstallRequirement] + links_to_fully_download: Dict[Link, InstallRequirement] = {} for req in partially_downloaded_reqs: assert req.link links_to_fully_download[req.link] = req @@ -474,41 +480,66 @@ class RequirementPreparer: logger.debug("Downloading link %s to %s", link, filepath) req = links_to_fully_download[link] req.local_file_path = filepath + # TODO: This needs fixing for sdists + # This is an emergency fix for #11847, which reports that + # distributions get downloaded twice when metadata is loaded + # from a PEP 658 standalone metadata file. Setting _downloaded + # fixes this for wheels, but breaks the sdist case (tests + # test_download_metadata). As PyPI is currently only serving + # metadata for wheels, this is not an immediate issue. + # Fixing the problem properly looks like it will require a + # complete refactoring of the `prepare_linked_requirements_more` + # logic, and I haven't a clue where to start on that, so for now + # I have fixed the issue *just* for wheels. + if req.is_wheel: + self._downloaded[req.link.url] = filepath # This step is necessary to ensure all lazy wheels are processed # successfully by the 'download', 'wheel', and 'install' commands. for req in partially_downloaded_reqs: self._prepare_linked_requirement(req, parallel_builds) - def prepare_linked_requirement(self, req, parallel_builds=False): - # type: (InstallRequirement, bool) -> Distribution + def prepare_linked_requirement( + self, req: InstallRequirement, parallel_builds: bool = False + ) -> BaseDistribution: """Prepare a requirement to be obtained from req.link.""" assert req.link - link = req.link self._log_preparing_link(req) with indent_log(): # Check if the relevant file is already available # in the download directory file_path = None - if self.download_dir is not None and link.is_wheel: + if self.download_dir is not None and req.link.is_wheel: hashes = self._get_linked_req_hashes(req) - file_path = _check_download_dir(req.link, self.download_dir, hashes) + file_path = _check_download_dir( + req.link, + self.download_dir, + hashes, + # When a locally built wheel has been found in cache, we don't warn + # about re-downloading when the already downloaded wheel hash does + # not match. This is because the hash must be checked against the + # original link, not the cached link. It that case the already + # downloaded file will be removed and re-fetched from cache (which + # implies a hash check against the cache entry's origin.json). + warn_on_hash_mismatch=not req.is_wheel_from_cache, + ) if file_path is not None: # The file is already available, so mark it as downloaded - self._downloaded[req.link.url] = file_path, None + self._downloaded[req.link.url] = file_path else: # The file is not available, attempt to fetch only metadata - wheel_dist = self._fetch_metadata_using_lazy_wheel(link) - if wheel_dist is not None: + metadata_dist = self._fetch_metadata_only(req) + if metadata_dist is not None: req.needs_more_preparation = True - return wheel_dist + return metadata_dist # None of the optimizations worked, fully prepare the requirement return self._prepare_linked_requirement(req, parallel_builds) - def prepare_linked_requirements_more(self, reqs, parallel_builds=False): - # type: (Iterable[InstallRequirement], bool) -> None + def prepare_linked_requirements_more( + self, reqs: Iterable[InstallRequirement], parallel_builds: bool = False + ) -> None: """Prepare linked requirements more, if needed.""" reqs = [req for req in reqs if req.needs_more_preparation] for req in reqs: @@ -517,12 +548,12 @@ class RequirementPreparer: hashes = self._get_linked_req_hashes(req) file_path = _check_download_dir(req.link, self.download_dir, hashes) if file_path is not None: - self._downloaded[req.link.url] = file_path, None + self._downloaded[req.link.url] = file_path req.needs_more_preparation = False # Prepare requirements we found were already downloaded for some # reason. The other downloads will be completed separately. - partially_downloaded_reqs = [] # type: List[InstallRequirement] + partially_downloaded_reqs: List[InstallRequirement] = [] for req in reqs: if req.needs_more_preparation: partially_downloaded_reqs.append(req) @@ -532,35 +563,87 @@ class RequirementPreparer: # TODO: separate this part out from RequirementPreparer when the v1 # resolver can be removed! self._complete_partial_requirements( - partially_downloaded_reqs, parallel_builds=parallel_builds, + partially_downloaded_reqs, + parallel_builds=parallel_builds, ) - def _prepare_linked_requirement(self, req, parallel_builds): - # type: (InstallRequirement, bool) -> Distribution + def _prepare_linked_requirement( + self, req: InstallRequirement, parallel_builds: bool + ) -> BaseDistribution: assert req.link link = req.link - self._ensure_link_req_src_dir(req, parallel_builds) hashes = self._get_linked_req_hashes(req) - if link.is_existing_dir() and self.in_tree_build: + if hashes and req.is_wheel_from_cache: + assert req.download_info is not None + assert link.is_wheel + assert link.is_file + # We need to verify hashes, and we have found the requirement in the cache + # of locally built wheels. + if ( + isinstance(req.download_info.info, ArchiveInfo) + and req.download_info.info.hashes + and hashes.has_one_of(req.download_info.info.hashes) + ): + # At this point we know the requirement was built from a hashable source + # artifact, and we verified that the cache entry's hash of the original + # artifact matches one of the hashes we expect. We don't verify hashes + # against the cached wheel, because the wheel is not the original. + hashes = None + else: + logger.warning( + "The hashes of the source archive found in cache entry " + "don't match, ignoring cached built wheel " + "and re-downloading source." + ) + req.link = req.cached_wheel_source_link + link = req.link + + self._ensure_link_req_src_dir(req, parallel_builds) + + if link.is_existing_dir(): local_file = None elif link.url not in self._downloaded: try: local_file = unpack_url( - link, req.source_dir, self._download, - self.download_dir, hashes + link, + req.source_dir, + self._download, + self.verbosity, + self.download_dir, + hashes, ) except NetworkConnectionError as exc: raise InstallationError( - 'Could not install requirement {} because of HTTP ' - 'error {} for URL {}'.format(req, exc, link) + "Could not install requirement {} because of HTTP " + "error {} for URL {}".format(req, exc, link) ) else: - file_path, content_type = self._downloaded[link.url] + file_path = self._downloaded[link.url] if hashes: hashes.check_against_path(file_path) - local_file = File(file_path, content_type) + local_file = File(file_path, content_type=None) + + # If download_info is set, we got it from the wheel cache. + if req.download_info is None: + # Editables don't go through this function (see + # prepare_editable_requirement). + assert not req.editable + req.download_info = direct_url_from_link(link, req.source_dir) + # Make sure we have a hash in download_info. If we got it as part of the + # URL, it will have been verified and we can rely on it. Otherwise we + # compute it from the downloaded file. + # FIXME: https://github.com/pypa/pip/issues/11943 + if ( + isinstance(req.download_info.info, ArchiveInfo) + and not req.download_info.info.hashes + and local_file + ): + hash = hash_file(local_file.path)[0].hexdigest() + # We populate info.hash for backward compatibility. + # This will automatically populate info.hashes. + req.download_info.info.hash = f"sha256={hash}" # For use in later processing, # preserve the file path on the requirement. @@ -568,12 +651,15 @@ class RequirementPreparer: req.local_file_path = local_file.path dist = _get_prepared_distribution( - req, self.req_tracker, self.finder, self.build_isolation, + req, + self.build_tracker, + self.finder, + self.build_isolation, + self.check_build_deps, ) return dist - def save_linked_requirement(self, req): - # type: (InstallRequirement) -> None + def save_linked_requirement(self, req: InstallRequirement) -> None: assert self.download_dir is not None assert req.link is not None link = req.link @@ -584,8 +670,9 @@ class RequirementPreparer: if link.is_existing_dir(): logger.debug( - 'Not copying link to destination directory ' - 'since it is a directory: %s', link, + "Not copying link to destination directory " + "since it is a directory: %s", + link, ) return if req.local_file_path is None: @@ -596,31 +683,35 @@ class RequirementPreparer: if not os.path.exists(download_location): shutil.copy(req.local_file_path, download_location) download_path = display_path(download_location) - logger.info('Saved %s', download_path) + logger.info("Saved %s", download_path) def prepare_editable_requirement( self, - req, # type: InstallRequirement - ): - # type: (...) -> Distribution - """Prepare an editable requirement - """ + req: InstallRequirement, + ) -> BaseDistribution: + """Prepare an editable requirement.""" assert req.editable, "cannot prepare a non-editable req as editable" - logger.info('Obtaining %s', req) + logger.info("Obtaining %s", req) with indent_log(): if self.require_hashes: raise InstallationError( - 'The editable requirement {} cannot be installed when ' - 'requiring hashes, because there is no single file to ' - 'hash.'.format(req) + "The editable requirement {} cannot be installed when " + "requiring hashes, because there is no single file to " + "hash.".format(req) ) req.ensure_has_source_dir(self.src_dir) req.update_editable() + assert req.source_dir + req.download_info = direct_url_for_editable(req.unpacked_source_directory) dist = _get_prepared_distribution( - req, self.req_tracker, self.finder, self.build_isolation, + req, + self.build_tracker, + self.finder, + self.build_isolation, + self.check_build_deps, ) req.check_if_exists(self.use_user_site) @@ -629,27 +720,24 @@ class RequirementPreparer: def prepare_installed_requirement( self, - req, # type: InstallRequirement - skip_reason # type: str - ): - # type: (...) -> Distribution - """Prepare an already-installed requirement - """ + req: InstallRequirement, + skip_reason: str, + ) -> BaseDistribution: + """Prepare an already-installed requirement.""" assert req.satisfied_by, "req should have been satisfied but isn't" assert skip_reason is not None, ( "did not get skip reason skipped but req.satisfied_by " "is set to {}".format(req.satisfied_by) ) logger.info( - 'Requirement %s: %s (%s)', - skip_reason, req, req.satisfied_by.version + "Requirement %s: %s (%s)", skip_reason, req, req.satisfied_by.version ) with indent_log(): if self.require_hashes: logger.debug( - 'Since it is already installed, we are trusting this ' - 'package without checking its hash. To ensure a ' - 'completely repeatable environment, install into an ' - 'empty virtualenv.' + "Since it is already installed, we are trusting this " + "package without checking its hash. To ensure a " + "completely repeatable environment, install into an " + "empty virtualenv." ) - return InstalledDistribution(req).get_pkg_resources_distribution() + return InstalledDistribution(req).get_metadata_distribution() diff --git a/env/Lib/site-packages/pip/_internal/pyproject.py b/env/Lib/site-packages/pip/_internal/pyproject.py index 9016d355..eb8e12b2 100644 --- a/env/Lib/site-packages/pip/_internal/pyproject.py +++ b/env/Lib/site-packages/pip/_internal/pyproject.py @@ -1,38 +1,34 @@ +import importlib.util import os from collections import namedtuple from typing import Any, List, Optional -from pip._vendor import toml +from pip._vendor import tomli from pip._vendor.packaging.requirements import InvalidRequirement, Requirement -from pip._internal.exceptions import InstallationError +from pip._internal.exceptions import ( + InstallationError, + InvalidPyProjectBuildRequires, + MissingPyProjectBuildRequires, +) -def _is_list_of_str(obj): - # type: (Any) -> bool - return ( - isinstance(obj, list) and - all(isinstance(item, str) for item in obj) - ) +def _is_list_of_str(obj: Any) -> bool: + return isinstance(obj, list) and all(isinstance(item, str) for item in obj) -def make_pyproject_path(unpacked_source_directory): - # type: (str) -> str - return os.path.join(unpacked_source_directory, 'pyproject.toml') +def make_pyproject_path(unpacked_source_directory: str) -> str: + return os.path.join(unpacked_source_directory, "pyproject.toml") -BuildSystemDetails = namedtuple('BuildSystemDetails', [ - 'requires', 'backend', 'check', 'backend_path' -]) +BuildSystemDetails = namedtuple( + "BuildSystemDetails", ["requires", "backend", "check", "backend_path"] +) def load_pyproject_toml( - use_pep517, # type: Optional[bool] - pyproject_toml, # type: str - setup_py, # type: str - req_name # type: str -): - # type: (...) -> Optional[BuildSystemDetails] + use_pep517: Optional[bool], pyproject_toml: str, setup_py: str, req_name: str +) -> Optional[BuildSystemDetails]: """Load the pyproject.toml file. Parameters: @@ -57,9 +53,15 @@ def load_pyproject_toml( has_pyproject = os.path.isfile(pyproject_toml) has_setup = os.path.isfile(setup_py) + if not has_pyproject and not has_setup: + raise InstallationError( + f"{req_name} does not appear to be a Python project: " + f"neither 'setup.py' nor 'pyproject.toml' found." + ) + if has_pyproject: with open(pyproject_toml, encoding="utf-8") as f: - pp_toml = toml.load(f) + pp_toml = tomli.loads(f.read()) build_system = pp_toml.get("build-system") else: build_system = None @@ -82,17 +84,26 @@ def load_pyproject_toml( raise InstallationError( "Disabling PEP 517 processing is invalid: " "project specifies a build backend of {} " - "in pyproject.toml".format( - build_system["build-backend"] - ) + "in pyproject.toml".format(build_system["build-backend"]) ) use_pep517 = True # If we haven't worked out whether to use PEP 517 yet, # and the user hasn't explicitly stated a preference, - # we do so if the project has a pyproject.toml file. + # we do so if the project has a pyproject.toml file + # or if we cannot import setuptools or wheels. + + # We fallback to PEP 517 when without setuptools or without the wheel package, + # so setuptools can be installed as a default build backend. + # For more info see: + # https://discuss.python.org/t/pip-without-setuptools-could-the-experience-be-improved/11810/9 + # https://github.com/pypa/pip/issues/8559 elif use_pep517 is None: - use_pep517 = has_pyproject + use_pep517 = ( + has_pyproject + or not importlib.util.find_spec("setuptools") + or not importlib.util.find_spec("wheel") + ) # At this point, we know whether we're going to use PEP 517. assert use_pep517 is not None @@ -124,52 +135,37 @@ def load_pyproject_toml( # Ensure that the build-system section in pyproject.toml conforms # to PEP 518. - error_template = ( - "{package} has a pyproject.toml file that does not comply " - "with PEP 518: {reason}" - ) # Specifying the build-system table but not the requires key is invalid if "requires" not in build_system: - raise InstallationError( - error_template.format(package=req_name, reason=( - "it has a 'build-system' table but not " - "'build-system.requires' which is mandatory in the table" - )) - ) + raise MissingPyProjectBuildRequires(package=req_name) # Error out if requires is not a list of strings requires = build_system["requires"] if not _is_list_of_str(requires): - raise InstallationError(error_template.format( + raise InvalidPyProjectBuildRequires( package=req_name, - reason="'build-system.requires' is not a list of strings.", - )) + reason="It is not a list of strings.", + ) # Each requirement must be valid as per PEP 508 for requirement in requires: try: Requirement(requirement) - except InvalidRequirement: - raise InstallationError( - error_template.format( - package=req_name, - reason=( - "'build-system.requires' contains an invalid " - "requirement: {!r}".format(requirement) - ), - ) - ) + except InvalidRequirement as error: + raise InvalidPyProjectBuildRequires( + package=req_name, + reason=f"It contains an invalid requirement: {requirement!r}", + ) from error backend = build_system.get("build-backend") backend_path = build_system.get("backend-path", []) - check = [] # type: List[str] + check: List[str] = [] if backend is None: # If the user didn't specify a backend, we assume they want to use # the setuptools backend. But we can't be sure they have included - # a version of setuptools which supplies the backend, or wheel - # (which is needed by the backend) in their requirements. So we - # make a note to check that those requirements are present once + # a version of setuptools which supplies the backend. So we + # make a note to check that this requirement is present once # we have set up the environment. # This is quite a lot of work to check for a very specific case. But # the problem is, that case is potentially quite common - projects that @@ -178,6 +174,6 @@ def load_pyproject_toml( # tools themselves. The original PEP 518 code had a similar check (but # implemented in a different way). backend = "setuptools.build_meta:__legacy__" - check = ["setuptools>=40.8.0", "wheel"] + check = ["setuptools>=40.8.0"] return BuildSystemDetails(requires, backend, check, backend_path) diff --git a/env/Lib/site-packages/pip/_internal/req/__init__.py b/env/Lib/site-packages/pip/_internal/req/__init__.py index 06f0a082..16de903a 100644 --- a/env/Lib/site-packages/pip/_internal/req/__init__.py +++ b/env/Lib/site-packages/pip/_internal/req/__init__.py @@ -1,6 +1,6 @@ import collections import logging -from typing import Iterator, List, Optional, Sequence, Tuple +from typing import Generator, List, Optional, Sequence, Tuple from pip._internal.utils.logging import indent_log @@ -9,44 +9,41 @@ from .req_install import InstallRequirement from .req_set import RequirementSet __all__ = [ - "RequirementSet", "InstallRequirement", - "parse_requirements", "install_given_reqs", + "RequirementSet", + "InstallRequirement", + "parse_requirements", + "install_given_reqs", ] logger = logging.getLogger(__name__) class InstallationResult: - def __init__(self, name): - # type: (str) -> None + def __init__(self, name: str) -> None: self.name = name - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return f"InstallationResult(name={self.name!r})" def _validate_requirements( - requirements, # type: List[InstallRequirement] -): - # type: (...) -> Iterator[Tuple[str, InstallRequirement]] + requirements: List[InstallRequirement], +) -> Generator[Tuple[str, InstallRequirement], None, None]: for req in requirements: assert req.name, f"invalid to-be-installed requirement: {req}" yield req.name, req def install_given_reqs( - requirements, # type: List[InstallRequirement] - install_options, # type: List[str] - global_options, # type: Sequence[str] - root, # type: Optional[str] - home, # type: Optional[str] - prefix, # type: Optional[str] - warn_script_location, # type: bool - use_user_site, # type: bool - pycompile, # type: bool -): - # type: (...) -> List[InstallationResult] + requirements: List[InstallRequirement], + global_options: Sequence[str], + root: Optional[str], + home: Optional[str], + prefix: Optional[str], + warn_script_location: bool, + use_user_site: bool, + pycompile: bool, +) -> List[InstallationResult]: """ Install everything in the given list. @@ -56,8 +53,8 @@ def install_given_reqs( if to_install: logger.info( - 'Installing collected packages: %s', - ', '.join(to_install.keys()), + "Installing collected packages: %s", + ", ".join(to_install.keys()), ) installed = [] @@ -65,17 +62,14 @@ def install_given_reqs( with indent_log(): for req_name, requirement in to_install.items(): if requirement.should_reinstall: - logger.info('Attempting uninstall: %s', req_name) + logger.info("Attempting uninstall: %s", req_name) with indent_log(): - uninstalled_pathset = requirement.uninstall( - auto_confirm=True - ) + uninstalled_pathset = requirement.uninstall(auto_confirm=True) else: uninstalled_pathset = None try: requirement.install( - install_options, global_options, root=root, home=home, diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 0d885a37520c3b3217e78fc6cb6234c6c0e88a2c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2371 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 diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/constructors.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/constructors.cpython-39.pyc deleted file mode 100644 index baafd90039bce100bf9133d5ac821014652d809c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11031 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 diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_file.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_file.cpython-39.pyc deleted file mode 100644 index a25b0ce6f0cf68355884b766e8202b2cec5915a2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12464 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 diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_install.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_install.cpython-39.pyc deleted file mode 100644 index 20a582b9dedfd7eb8a1a1618ff02c95261c2c24d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20542 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%0A#Err!qb_F)uMa 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 J>KPD_0RZ-s0F?j$ diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_set.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_set.cpython-39.pyc deleted file mode 100644 index ae2f115ee96cf7a029041a3522402ee344b888d5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5708 zcmYe~<>g{vU|^UdaWFMWj)CDZh=Yuo85kHG7#J9eI~W)kQW#Pga~PsPG*b>^E>jc} zBZ$qM!<@?!#gfY!#hS|&#g@w+#h%L%#Q~OM$>Gf9isAyZS#!8^d7^m0Y_=TUT)rqi zFq=JxKUW}10L<pd5zG~e5@KXXWmq7bDzcC<O4OYpg)@b#g&~EjnJG#vg)x{xllvve zjeeSpx48X_Qc{ajQ(Q8WOEg(;v4H4X9G)eqMTto{skc~sGK))YarhUMWaj53=G<Zp zDJ{rJ)nvRSn4FlGpO=}On3GwR8lRV#3l{XuD=taQ$w>sMb}cH(FVbYZ#TuTGnwq1@ zcuNQ>8<bjDnpu>Zo0?Yw5>3v}El4cMOv=p3EUAnyNlY(J200EH!visffq@~FA&N1D zA&MzQG=(XJxrH%`IfW&KwS^&yC50`8y@er)HH9OEvxOmwErlzEyM-Z&Jw+^qH-)c- zF^VIFKSiL0A&N6aFh!_^A&M)NJ4HA}q=liGF^VUJCzwG~{1zXQ^MX@LLXw$~TmoW) zurnw|B^VeON*J0MY8c`fYZz-7;+fJxY-Vr>GgT=%7o{eaq$(sTpqi-1r2qwfnk+>i z({Aw;A%dj%mRNE|YI1gbacMz8eo;wkN_;se0E=≪(lLIVB!hwI<Uomg3Z$v?6{6 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 N4-*d~7&37&0|4Ek=5+u7 diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-39.pyc deleted file mode 100644 index 62c7068c5d89ef9d8e8bd8db579753e39128cd2e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4053 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 WqXH8TBM+z{$;`sYCB?$X#SZ|qL*C5* diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-39.pyc deleted file mode 100644 index 58ad9d78cad1ff38a3ef66aa1765f5687f9cc177..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17489 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	RyyU1093R1T8x% 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 Y;ALXu66X-%Q0Fk_%jc_SsAu2?0C@$KRR910 diff --git a/env/Lib/site-packages/pip/_internal/req/constructors.py b/env/Lib/site-packages/pip/_internal/req/constructors.py index 3f9e7dd7..c5ca2d85 100644 --- a/env/Lib/site-packages/pip/_internal/req/constructors.py +++ b/env/Lib/site-packages/pip/_internal/req/constructors.py @@ -11,37 +11,36 @@ InstallRequirement. import logging import os import re -from typing import Any, Dict, Optional, Set, Tuple, Union +from typing import Dict, List, Optional, Set, Tuple, Union from pip._vendor.packaging.markers import Marker from pip._vendor.packaging.requirements import InvalidRequirement, Requirement from pip._vendor.packaging.specifiers import Specifier -from pip._vendor.pkg_resources import RequirementParseError, parse_requirements from pip._internal.exceptions import InstallationError from pip._internal.models.index import PyPI, TestPyPI from pip._internal.models.link import Link from pip._internal.models.wheel import Wheel -from pip._internal.pyproject import make_pyproject_path from pip._internal.req.req_file import ParsedRequirement from pip._internal.req.req_install import InstallRequirement from pip._internal.utils.filetypes import is_archive_file from pip._internal.utils.misc import is_installable_dir +from pip._internal.utils.packaging import get_requirement from pip._internal.utils.urls import path_to_url from pip._internal.vcs import is_url, vcs __all__ = [ - "install_req_from_editable", "install_req_from_line", - "parse_editable" + "install_req_from_editable", + "install_req_from_line", + "parse_editable", ] logger = logging.getLogger(__name__) operators = Specifier._operators.keys() -def _strip_extras(path): - # type: (str) -> Tuple[str, Optional[str]] - m = re.match(r'^(.+)(\[[^\]]+\])$', path) +def _strip_extras(path: str) -> Tuple[str, Optional[str]]: + m = re.match(r"^(.+)(\[[^\]]+\])$", path) extras = None if m: path_no_extras = m.group(1) @@ -52,15 +51,13 @@ def _strip_extras(path): return path_no_extras, extras -def convert_extras(extras): - # type: (Optional[str]) -> Set[str] +def convert_extras(extras: Optional[str]) -> Set[str]: if not extras: return set() - return Requirement("placeholder" + extras.lower()).extras + return get_requirement("placeholder" + extras.lower()).extras -def parse_editable(editable_req): - # type: (str) -> Tuple[Optional[str], str, Set[str]] +def parse_editable(editable_req: str) -> Tuple[Optional[str], str, Set[str]]: """Parses an editable requirement into: - a requirement name - an URL @@ -77,39 +74,23 @@ def parse_editable(editable_req): url_no_extras, extras = _strip_extras(url) if os.path.isdir(url_no_extras): - setup_py = os.path.join(url_no_extras, 'setup.py') - setup_cfg = os.path.join(url_no_extras, 'setup.cfg') - if not os.path.exists(setup_py) and not os.path.exists(setup_cfg): - msg = ( - 'File "setup.py" or "setup.cfg" not found. Directory cannot be ' - 'installed in editable mode: {}' - .format(os.path.abspath(url_no_extras)) - ) - pyproject_path = make_pyproject_path(url_no_extras) - if os.path.isfile(pyproject_path): - msg += ( - '\n(A "pyproject.toml" file was found, but editable ' - 'mode currently requires a setuptools-based build.)' - ) - raise InstallationError(msg) - # Treating it as code that has already been checked out url_no_extras = path_to_url(url_no_extras) - if url_no_extras.lower().startswith('file:'): + if url_no_extras.lower().startswith("file:"): package_name = Link(url_no_extras).egg_fragment if extras: return ( package_name, url_no_extras, - Requirement("placeholder" + extras.lower()).extras, + get_requirement("placeholder" + extras.lower()).extras, ) else: return package_name, url_no_extras, set() for version_control in vcs: - if url.lower().startswith(f'{version_control}:'): - url = f'{version_control}+{url}' + if url.lower().startswith(f"{version_control}:"): + url = f"{version_control}+{url}" break link = Link(url) @@ -117,9 +98,9 @@ def parse_editable(editable_req): if not link.is_vcs: backends = ", ".join(vcs.all_schemes) raise InstallationError( - f'{editable_req} is not a valid editable requirement. ' - f'It should either be a path to a local project or a VCS URL ' - f'(beginning with {backends}).' + f"{editable_req} is not a valid editable requirement. " + f"It should either be a path to a local project or a VCS URL " + f"(beginning with {backends})." ) package_name = link.egg_fragment @@ -131,44 +112,66 @@ def parse_editable(editable_req): return package_name, url, set() -def deduce_helpful_msg(req): - # type: (str) -> str +def check_first_requirement_in_file(filename: str) -> None: + """Check if file is parsable as a requirements file. + + This is heavily based on ``pkg_resources.parse_requirements``, but + simplified to just check the first meaningful line. + + :raises InvalidRequirement: If the first meaningful line cannot be parsed + as an requirement. + """ + with open(filename, encoding="utf-8", errors="ignore") as f: + # Create a steppable iterator, so we can handle \-continuations. + lines = ( + line + for line in (line.strip() for line in f) + if line and not line.startswith("#") # Skip blank lines/comments. + ) + + for line in lines: + # Drop comments -- a hash without a space may be in a URL. + if " #" in line: + line = line[: line.find(" #")] + # If there is a line continuation, drop it, and append the next line. + if line.endswith("\\"): + line = line[:-2].strip() + next(lines, "") + Requirement(line) + return + + +def deduce_helpful_msg(req: str) -> str: """Returns helpful msg in case requirements file does not exist, or cannot be parsed. :params req: Requirements file path """ - msg = "" - if os.path.exists(req): - msg = " The path does exist. " - # Try to parse and check if it is a requirements file. - try: - with open(req) as fp: - # parse first line only - next(parse_requirements(fp.read())) - msg += ( - "The argument you provided " - "({}) appears to be a" - " requirements file. If that is the" - " case, use the '-r' flag to install" - " the packages specified within it." - ).format(req) - except RequirementParseError: - logger.debug( - "Cannot parse '%s' as requirements file", req, exc_info=True - ) + if not os.path.exists(req): + return f" File '{req}' does not exist." + msg = " The path does exist. " + # Try to parse and check if it is a requirements file. + try: + check_first_requirement_in_file(req) + except InvalidRequirement: + logger.debug("Cannot parse '%s' as requirements file", req) else: - msg += f" File '{req}' does not exist." + msg += ( + f"The argument you provided " + f"({req}) appears to be a" + f" requirements file. If that is the" + f" case, use the '-r' flag to install" + f" the packages specified within it." + ) return msg class RequirementParts: def __init__( - self, - requirement, # type: Optional[Requirement] - link, # type: Optional[Link] - markers, # type: Optional[Marker] - extras, # type: Set[str] + self, + requirement: Optional[Requirement], + link: Optional[Link], + markers: Optional[Marker], + extras: Set[str], ): self.requirement = requirement self.link = link @@ -176,13 +179,12 @@ class RequirementParts: self.extras = extras -def parse_req_from_editable(editable_req): - # type: (str) -> RequirementParts +def parse_req_from_editable(editable_req: str) -> RequirementParts: name, url, extras_override = parse_editable(editable_req) if name is not None: try: - req = Requirement(name) # type: Optional[Requirement] + req: Optional[Requirement] = Requirement(name) except InvalidRequirement: raise InstallationError(f"Invalid requirement: '{name}'") else: @@ -197,16 +199,18 @@ def parse_req_from_editable(editable_req): def install_req_from_editable( - editable_req, # type: str - comes_from=None, # type: Optional[Union[InstallRequirement, str]] - use_pep517=None, # type: Optional[bool] - isolated=False, # type: bool - options=None, # type: Optional[Dict[str, Any]] - constraint=False, # type: bool - user_supplied=False, # type: bool -): - # type: (...) -> InstallRequirement - + editable_req: str, + comes_from: Optional[Union[InstallRequirement, str]] = None, + *, + use_pep517: Optional[bool] = None, + isolated: bool = False, + global_options: Optional[List[str]] = None, + hash_options: Optional[Dict[str, List[str]]] = None, + constraint: bool = False, + user_supplied: bool = False, + permit_editable_wheels: bool = False, + config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, +) -> InstallRequirement: parts = parse_req_from_editable(editable_req) return InstallRequirement( @@ -214,19 +218,19 @@ def install_req_from_editable( comes_from=comes_from, user_supplied=user_supplied, editable=True, + permit_editable_wheels=permit_editable_wheels, link=parts.link, constraint=constraint, use_pep517=use_pep517, isolated=isolated, - install_options=options.get("install_options", []) if options else [], - global_options=options.get("global_options", []) if options else [], - hash_options=options.get("hashes", {}) if options else {}, + global_options=global_options, + hash_options=hash_options, + config_settings=config_settings, extras=parts.extras, ) -def _looks_like_path(name): - # type: (str) -> bool +def _looks_like_path(name: str) -> bool: """Checks whether the string "looks like" a path on the filesystem. This does not check whether the target actually exists, only judge from the @@ -245,11 +249,10 @@ def _looks_like_path(name): return False -def _get_url_from_path(path, name): - # type: (str, str) -> Optional[str] +def _get_url_from_path(path: str, name: str) -> Optional[str]: """ - First, it checks whether a provided path is an installable directory - (e.g. it has a setup.py). If it is, returns the path. + First, it checks whether a provided path is an installable directory. If it + is, returns the path. If false, check if the path is an archive file (such as a .whl). The function checks if the path is a file. If false, if the path has @@ -258,6 +261,8 @@ def _get_url_from_path(path, name): if _looks_like_path(name) and os.path.isdir(path): if is_installable_dir(path): return path_to_url(path) + # TODO: The is_installable_dir test here might not be necessary + # now that it is done in load_pyproject_toml too. raise InstallationError( f"Directory {name!r} is not installable. Neither 'setup.py' " "nor 'pyproject.toml' found." @@ -266,25 +271,23 @@ def _get_url_from_path(path, name): return None if os.path.isfile(path): return path_to_url(path) - urlreq_parts = name.split('@', 1) + urlreq_parts = name.split("@", 1) if len(urlreq_parts) >= 2 and not _looks_like_path(urlreq_parts[0]): # If the path contains '@' and the part before it does not look # like a path, try to treat it as a PEP 440 URL req instead. return None logger.warning( - 'Requirement %r looks like a filename, but the ' - 'file does not exist', - name + "Requirement %r looks like a filename, but the file does not exist", + name, ) return path_to_url(path) -def parse_req_from_line(name, line_source): - # type: (str, Optional[str]) -> RequirementParts +def parse_req_from_line(name: str, line_source: Optional[str]) -> RequirementParts: if is_url(name): - marker_sep = '; ' + marker_sep = "; " else: - marker_sep = ';' + marker_sep = ";" if marker_sep in name: name, markers_as_string = name.split(marker_sep, 1) markers_as_string = markers_as_string.strip() @@ -311,9 +314,8 @@ def parse_req_from_line(name, line_source): # it's a local file, dir, or url if link: # Handle relative file URLs - if link.scheme == 'file' and re.search(r'\.\./', link.url): - link = Link( - path_to_url(os.path.normpath(os.path.abspath(link.path)))) + if link.scheme == "file" and re.search(r"\.\./", link.url): + link = Link(path_to_url(os.path.normpath(os.path.abspath(link.path)))) # wheel file if link.is_wheel: wheel = Wheel(link.filename) # can raise InvalidWheelFilename @@ -329,29 +331,27 @@ def parse_req_from_line(name, line_source): extras = convert_extras(extras_as_string) - def with_source(text): - # type: (str) -> str + def with_source(text: str) -> str: if not line_source: return text - return f'{text} (from {line_source})' + return f"{text} (from {line_source})" def _parse_req_string(req_as_string: str) -> Requirement: try: - req = Requirement(req_as_string) + req = get_requirement(req_as_string) except InvalidRequirement: if os.path.sep in req_as_string: add_msg = "It looks like a path." add_msg += deduce_helpful_msg(req_as_string) - elif ('=' in req_as_string and - not any(op in req_as_string for op in operators)): + elif "=" in req_as_string and not any( + op in req_as_string for op in operators + ): add_msg = "= is not a valid operator. Did you mean == ?" else: - add_msg = '' - msg = with_source( - f'Invalid requirement: {req_as_string!r}' - ) + add_msg = "" + msg = with_source(f"Invalid requirement: {req_as_string!r}") if add_msg: - msg += f'\nHint: {add_msg}' + msg += f"\nHint: {add_msg}" raise InstallationError(msg) else: # Deprecate extras after specifiers: "name>=1.0[extras]" @@ -360,13 +360,13 @@ def parse_req_from_line(name, line_source): # RequirementParts for spec in req.specifier: spec_str = str(spec) - if spec_str.endswith(']'): + if spec_str.endswith("]"): msg = f"Extras after version '{spec_str}'." raise InstallationError(msg) return req if req_as_string is not None: - req = _parse_req_string(req_as_string) # type: Optional[Requirement] + req: Optional[Requirement] = _parse_req_string(req_as_string) else: req = None @@ -374,16 +374,18 @@ def parse_req_from_line(name, line_source): def install_req_from_line( - name, # type: str - comes_from=None, # type: Optional[Union[str, InstallRequirement]] - use_pep517=None, # type: Optional[bool] - isolated=False, # type: bool - options=None, # type: Optional[Dict[str, Any]] - constraint=False, # type: bool - line_source=None, # type: Optional[str] - user_supplied=False, # type: bool -): - # type: (...) -> InstallRequirement + name: str, + comes_from: Optional[Union[str, InstallRequirement]] = None, + *, + use_pep517: Optional[bool] = None, + isolated: bool = False, + global_options: Optional[List[str]] = None, + hash_options: Optional[Dict[str, List[str]]] = None, + constraint: bool = False, + line_source: Optional[str] = None, + user_supplied: bool = False, + config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, +) -> InstallRequirement: """Creates an InstallRequirement from a name, which might be a requirement, directory containing 'setup.py', filename, or URL. @@ -393,11 +395,15 @@ def install_req_from_line( parts = parse_req_from_line(name, line_source) return InstallRequirement( - parts.requirement, comes_from, link=parts.link, markers=parts.markers, - use_pep517=use_pep517, isolated=isolated, - install_options=options.get("install_options", []) if options else [], - global_options=options.get("global_options", []) if options else [], - hash_options=options.get("hashes", {}) if options else {}, + parts.requirement, + comes_from, + link=parts.link, + markers=parts.markers, + use_pep517=use_pep517, + isolated=isolated, + global_options=global_options, + hash_options=hash_options, + config_settings=config_settings, constraint=constraint, extras=parts.extras, user_supplied=user_supplied, @@ -405,15 +411,14 @@ def install_req_from_line( def install_req_from_req_string( - req_string, # type: str - comes_from=None, # type: Optional[InstallRequirement] - isolated=False, # type: bool - use_pep517=None, # type: Optional[bool] - user_supplied=False, # type: bool -): - # type: (...) -> InstallRequirement + req_string: str, + comes_from: Optional[InstallRequirement] = None, + isolated: bool = False, + use_pep517: Optional[bool] = None, + user_supplied: bool = False, +) -> InstallRequirement: try: - req = Requirement(req_string) + req = get_requirement(req_string) except InvalidRequirement: raise InstallationError(f"Invalid requirement: '{req_string}'") @@ -421,8 +426,12 @@ def install_req_from_req_string( PyPI.file_storage_domain, TestPyPI.file_storage_domain, ] - if (req.url and comes_from and comes_from.link and - comes_from.link.netloc in domains_not_allowed): + if ( + req.url + and comes_from + and comes_from.link + and comes_from.link.netloc in domains_not_allowed + ): # Explicitly disallow pypi packages that depend on external urls raise InstallationError( "Packages installed from PyPI cannot depend on packages " @@ -440,12 +449,12 @@ def install_req_from_req_string( def install_req_from_parsed_requirement( - parsed_req, # type: ParsedRequirement - isolated=False, # type: bool - use_pep517=None, # type: Optional[bool] - user_supplied=False, # type: bool -): - # type: (...) -> InstallRequirement + parsed_req: ParsedRequirement, + isolated: bool = False, + use_pep517: Optional[bool] = None, + user_supplied: bool = False, + config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, +) -> InstallRequirement: if parsed_req.is_editable: req = install_req_from_editable( parsed_req.requirement, @@ -454,6 +463,7 @@ def install_req_from_parsed_requirement( constraint=parsed_req.constraint, isolated=isolated, user_supplied=user_supplied, + config_settings=config_settings, ) else: @@ -462,16 +472,25 @@ def install_req_from_parsed_requirement( comes_from=parsed_req.comes_from, use_pep517=use_pep517, isolated=isolated, - options=parsed_req.options, + global_options=( + parsed_req.options.get("global_options", []) + if parsed_req.options + else [] + ), + hash_options=( + parsed_req.options.get("hashes", {}) if parsed_req.options else {} + ), constraint=parsed_req.constraint, line_source=parsed_req.line_source, user_supplied=user_supplied, + config_settings=config_settings, ) return req -def install_req_from_link_and_ireq(link, ireq): - # type: (Link, InstallRequirement) -> InstallRequirement +def install_req_from_link_and_ireq( + link: Link, ireq: InstallRequirement +) -> InstallRequirement: return InstallRequirement( req=ireq.req, comes_from=ireq.comes_from, @@ -480,7 +499,8 @@ def install_req_from_link_and_ireq(link, ireq): markers=ireq.markers, use_pep517=ireq.use_pep517, isolated=ireq.isolated, - install_options=ireq.install_options, global_options=ireq.global_options, hash_options=ireq.hash_options, + config_settings=ireq.config_settings, + user_supplied=ireq.user_supplied, ) diff --git a/env/Lib/site-packages/pip/_internal/req/req_file.py b/env/Lib/site-packages/pip/_internal/req/req_file.py index 080c1281..f717c1cc 100644 --- a/env/Lib/site-packages/pip/_internal/req/req_file.py +++ b/env/Lib/site-packages/pip/_internal/req/req_file.py @@ -2,13 +2,24 @@ Requirements file parsing """ +import logging import optparse import os import re import shlex import urllib.parse from optparse import Values -from typing import TYPE_CHECKING, Any, Callable, Dict, Iterator, List, Optional, Tuple +from typing import ( + TYPE_CHECKING, + Any, + Callable, + Dict, + Generator, + Iterable, + List, + Optional, + Tuple, +) from pip._internal.cli import cmdoptions from pip._internal.exceptions import InstallationError, RequirementsFileParseError @@ -16,7 +27,7 @@ from pip._internal.models.search_scope import SearchScope from pip._internal.network.session import PipSession from pip._internal.network.utils import raise_for_status from pip._internal.utils.encoding import auto_decode -from pip._internal.utils.urls import get_url_scheme, url_to_path +from pip._internal.utils.urls import get_url_scheme if TYPE_CHECKING: # NoReturn introduced in 3.6.2; imported only for type checking to maintain @@ -25,22 +36,22 @@ if TYPE_CHECKING: from pip._internal.index.package_finder import PackageFinder -__all__ = ['parse_requirements'] +__all__ = ["parse_requirements"] -ReqFileLines = Iterator[Tuple[int, str]] +ReqFileLines = Iterable[Tuple[int, str]] LineParser = Callable[[str], Tuple[str, Values]] -SCHEME_RE = re.compile(r'^(http|https|file):', re.I) -COMMENT_RE = re.compile(r'(^|\s+)#.*$') +SCHEME_RE = re.compile(r"^(http|https|file):", re.I) +COMMENT_RE = re.compile(r"(^|\s+)#.*$") # Matches environment variable-style values in '${MY_VARIABLE_1}' with the # variable name consisting of only uppercase letters, digits or the '_' # (underscore). This follows the POSIX standard defined in IEEE Std 1003.1, # 2013 Edition. -ENV_VAR_RE = re.compile(r'(?P<var>\$\{(?P<name>[A-Z0-9_]+)\})') +ENV_VAR_RE = re.compile(r"(?P<var>\$\{(?P<name>[A-Z0-9_]+)\})") -SUPPORTED_OPTIONS = [ +SUPPORTED_OPTIONS: List[Callable[..., optparse.Option]] = [ cmdoptions.index_url, cmdoptions.extra_index_url, cmdoptions.no_index, @@ -55,30 +66,31 @@ SUPPORTED_OPTIONS = [ cmdoptions.pre, cmdoptions.trusted_host, cmdoptions.use_new_feature, -] # type: List[Callable[..., optparse.Option]] +] # options to be passed to requirements -SUPPORTED_OPTIONS_REQ = [ - cmdoptions.install_options, +SUPPORTED_OPTIONS_REQ: List[Callable[..., optparse.Option]] = [ cmdoptions.global_options, cmdoptions.hash, -] # type: List[Callable[..., optparse.Option]] + cmdoptions.config_settings, +] # the 'dest' string values SUPPORTED_OPTIONS_REQ_DEST = [str(o().dest) for o in SUPPORTED_OPTIONS_REQ] +logger = logging.getLogger(__name__) + class ParsedRequirement: def __init__( self, - requirement, # type:str - is_editable, # type: bool - comes_from, # type: str - constraint, # type: bool - options=None, # type: Optional[Dict[str, Any]] - line_source=None, # type: Optional[str] - ): - # type: (...) -> None + requirement: str, + is_editable: bool, + comes_from: str, + constraint: bool, + options: Optional[Dict[str, Any]] = None, + line_source: Optional[str] = None, + ) -> None: self.requirement = requirement self.is_editable = is_editable self.comes_from = comes_from @@ -90,13 +102,12 @@ class ParsedRequirement: class ParsedLine: def __init__( self, - filename, # type: str - lineno, # type: int - args, # type: str - opts, # type: Values - constraint, # type: bool - ): - # type: (...) -> None + filename: str, + lineno: int, + args: str, + opts: Values, + constraint: bool, + ) -> None: self.filename = filename self.lineno = lineno self.opts = opts @@ -116,13 +127,12 @@ class ParsedLine: def parse_requirements( - filename, # type: str - session, # type: PipSession - finder=None, # type: Optional[PackageFinder] - options=None, # type: Optional[optparse.Values] - constraint=False, # type: bool -): - # type: (...) -> Iterator[ParsedRequirement] + filename: str, + session: PipSession, + finder: Optional["PackageFinder"] = None, + options: Optional[optparse.Values] = None, + constraint: bool = False, +) -> Generator[ParsedRequirement, None, None]: """Parse a requirements file and yield ParsedRequirement instances. :param filename: Path or url of requirements file. @@ -137,22 +147,18 @@ def parse_requirements( for parsed_line in parser.parse(filename, constraint): parsed_req = handle_line( - parsed_line, - options=options, - finder=finder, - session=session + parsed_line, options=options, finder=finder, session=session ) if parsed_req is not None: yield parsed_req -def preprocess(content): - # type: (str) -> ReqFileLines +def preprocess(content: str) -> ReqFileLines: """Split, filter, and join lines, and return a line iterator :param content: the content of the requirements file """ - lines_enum = enumerate(content.splitlines(), start=1) # type: ReqFileLines + lines_enum: ReqFileLines = enumerate(content.splitlines(), start=1) lines_enum = join_lines(lines_enum) lines_enum = ignore_comments(lines_enum) lines_enum = expand_env_variables(lines_enum) @@ -160,14 +166,14 @@ def preprocess(content): def handle_requirement_line( - line, # type: ParsedLine - options=None, # type: Optional[optparse.Values] -): - # type: (...) -> ParsedRequirement - + line: ParsedLine, + options: Optional[optparse.Values] = None, +) -> ParsedRequirement: # preserve for the nested code path - line_comes_from = '{} {} (line {})'.format( - '-c' if line.constraint else '-r', line.filename, line.lineno, + line_comes_from = "{} {} (line {})".format( + "-c" if line.constraint else "-r", + line.filename, + line.lineno, ) assert line.is_requirement @@ -182,17 +188,13 @@ def handle_requirement_line( constraint=line.constraint, ) else: - if options: - # Disable wheels if the user has specified build options - cmdoptions.check_install_build_global(options, line.opts) - # get the options that apply to requirements req_options = {} for dest in SUPPORTED_OPTIONS_REQ_DEST: if dest in line.opts.__dict__ and line.opts.__dict__[dest]: req_options[dest] = line.opts.__dict__[dest] - line_source = f'line {line.lineno} of {line.filename}' + line_source = f"line {line.lineno} of {line.filename}" return ParsedRequirement( requirement=line.requirement, is_editable=line.is_editable, @@ -204,14 +206,19 @@ def handle_requirement_line( def handle_option_line( - opts, # type: Values - filename, # type: str - lineno, # type: int - finder=None, # type: Optional[PackageFinder] - options=None, # type: Optional[optparse.Values] - session=None, # type: Optional[PipSession] -): - # type: (...) -> None + opts: Values, + filename: str, + lineno: int, + finder: Optional["PackageFinder"] = None, + options: Optional[optparse.Values] = None, + session: Optional[PipSession] = None, +) -> None: + if opts.hashes: + logger.warning( + "%s line %s has --hash but no requirement, and will be ignored.", + filename, + lineno, + ) if options: # percolate options upward @@ -219,19 +226,20 @@ def handle_option_line( options.require_hashes = opts.require_hashes if opts.features_enabled: options.features_enabled.extend( - f for f in opts.features_enabled - if f not in options.features_enabled + f for f in opts.features_enabled if f not in options.features_enabled ) # set finder options if finder: find_links = finder.find_links index_urls = finder.index_urls - if opts.index_url: - index_urls = [opts.index_url] + no_index = finder.search_scope.no_index if opts.no_index is True: + no_index = True index_urls = [] - if opts.extra_index_urls: + if opts.index_url and not no_index: + index_urls = [opts.index_url] + if opts.extra_index_urls and not no_index: index_urls.extend(opts.extra_index_urls) if opts.find_links: # FIXME: it would be nice to keep track of the source @@ -251,6 +259,7 @@ def handle_option_line( search_scope = SearchScope( find_links=find_links, index_urls=index_urls, + no_index=no_index, ) finder.search_scope = search_scope @@ -262,17 +271,16 @@ def handle_option_line( if session: for host in opts.trusted_hosts or []: - source = f'line {lineno} of {filename}' + source = f"line {lineno} of {filename}" session.add_trusted_host(host, source=source) def handle_line( - line, # type: ParsedLine - options=None, # type: Optional[optparse.Values] - finder=None, # type: Optional[PackageFinder] - session=None, # type: Optional[PipSession] -): - # type: (...) -> Optional[ParsedRequirement] + line: ParsedLine, + options: Optional[optparse.Values] = None, + finder: Optional["PackageFinder"] = None, + session: Optional[PipSession] = None, +) -> Optional[ParsedRequirement]: """Handle a single parsed requirements line; This can result in creating/yielding requirements, or updating the finder. @@ -314,25 +322,24 @@ def handle_line( class RequirementsFileParser: def __init__( self, - session, # type: PipSession - line_parser, # type: LineParser - ): - # type: (...) -> None + session: PipSession, + line_parser: LineParser, + ) -> None: self._session = session self._line_parser = line_parser - def parse(self, filename, constraint): - # type: (str, bool) -> Iterator[ParsedLine] - """Parse a given file, yielding parsed lines. - """ + def parse( + self, filename: str, constraint: bool + ) -> Generator[ParsedLine, None, None]: + """Parse a given file, yielding parsed lines.""" yield from self._parse_and_recurse(filename, constraint) - def _parse_and_recurse(self, filename, constraint): - # type: (str, bool) -> Iterator[ParsedLine] + def _parse_and_recurse( + self, filename: str, constraint: bool + ) -> Generator[ParsedLine, None, None]: for line in self._parse_file(filename, constraint): - if ( - not line.is_requirement and - (line.opts.requirements or line.opts.constraints) + if not line.is_requirement and ( + line.opts.requirements or line.opts.constraints ): # parse a nested requirements file if line.opts.requirements: @@ -350,15 +357,17 @@ class RequirementsFileParser: elif not SCHEME_RE.search(req_path): # do a join so relative paths work req_path = os.path.join( - os.path.dirname(filename), req_path, + os.path.dirname(filename), + req_path, ) yield from self._parse_and_recurse(req_path, nested_constraint) else: yield line - def _parse_file(self, filename, constraint): - # type: (str, bool) -> Iterator[ParsedLine] + def _parse_file( + self, filename: str, constraint: bool + ) -> Generator[ParsedLine, None, None]: _, content = get_file_content(filename, self._session) lines_enum = preprocess(content) @@ -368,7 +377,7 @@ class RequirementsFileParser: args_str, opts = self._line_parser(line) except OptionParsingError as e: # add offending line - msg = f'Invalid requirement: {line}\n{e.msg}' + msg = f"Invalid requirement: {line}\n{e.msg}" raise RequirementsFileParseError(msg) yield ParsedLine( @@ -380,10 +389,8 @@ class RequirementsFileParser: ) -def get_line_parser(finder): - # type: (Optional[PackageFinder]) -> LineParser - def parse_line(line): - # type: (str) -> Tuple[str, Values] +def get_line_parser(finder: Optional["PackageFinder"]) -> LineParser: + def parse_line(line: str) -> Tuple[str, Values]: # Build new parser for each line since it accumulates appendable # options. parser = build_parser() @@ -394,39 +401,41 @@ def get_line_parser(finder): args_str, options_str = break_args_options(line) - opts, _ = parser.parse_args(shlex.split(options_str), defaults) + try: + options = shlex.split(options_str) + except ValueError as e: + raise OptionParsingError(f"Could not split options: {options_str}") from e + + opts, _ = parser.parse_args(options, defaults) return args_str, opts return parse_line -def break_args_options(line): - # type: (str) -> Tuple[str, str] +def break_args_options(line: str) -> Tuple[str, str]: """Break up the line into an args and options string. We only want to shlex (and then optparse) the options, not the args. args can contain markers which are corrupted by shlex. """ - tokens = line.split(' ') + tokens = line.split(" ") args = [] options = tokens[:] for token in tokens: - if token.startswith('-') or token.startswith('--'): + if token.startswith("-") or token.startswith("--"): break else: args.append(token) options.pop(0) - return ' '.join(args), ' '.join(options) + return " ".join(args), " ".join(options) class OptionParsingError(Exception): - def __init__(self, msg): - # type: (str) -> None + def __init__(self, msg: str) -> None: self.msg = msg -def build_parser(): - # type: () -> optparse.OptionParser +def build_parser() -> optparse.OptionParser: """ Return a parser for parsing requirement lines """ @@ -439,9 +448,9 @@ def build_parser(): # By default optparse sys.exits on parsing errors. We want to wrap # that in our own exception. - def parser_exit(self, msg): - # type: (Any, str) -> NoReturn + def parser_exit(self: Any, msg: str) -> "NoReturn": raise OptionParsingError(msg) + # NOTE: mypy disallows assigning to a method # https://github.com/python/mypy/issues/2427 parser.exit = parser_exit # type: ignore @@ -449,52 +458,49 @@ def build_parser(): return parser -def join_lines(lines_enum): - # type: (ReqFileLines) -> ReqFileLines +def join_lines(lines_enum: ReqFileLines) -> ReqFileLines: """Joins a line ending in '\' with the previous line (except when following comments). The joined line takes on the index of the first line. """ primary_line_number = None - new_line = [] # type: List[str] + new_line: List[str] = [] for line_number, line in lines_enum: - if not line.endswith('\\') or COMMENT_RE.match(line): + if not line.endswith("\\") or COMMENT_RE.match(line): if COMMENT_RE.match(line): # this ensures comments are always matched later - line = ' ' + line + line = " " + line if new_line: new_line.append(line) assert primary_line_number is not None - yield primary_line_number, ''.join(new_line) + yield primary_line_number, "".join(new_line) new_line = [] else: yield line_number, line else: if not new_line: primary_line_number = line_number - new_line.append(line.strip('\\')) + new_line.append(line.strip("\\")) # last line contains \ if new_line: assert primary_line_number is not None - yield primary_line_number, ''.join(new_line) + yield primary_line_number, "".join(new_line) # TODO: handle space after '\'. -def ignore_comments(lines_enum): - # type: (ReqFileLines) -> ReqFileLines +def ignore_comments(lines_enum: ReqFileLines) -> ReqFileLines: """ Strips comments and filter empty lines. """ for line_number, line in lines_enum: - line = COMMENT_RE.sub('', line) + line = COMMENT_RE.sub("", line) line = line.strip() if line: yield line_number, line -def expand_env_variables(lines_enum): - # type: (ReqFileLines) -> ReqFileLines +def expand_env_variables(lines_enum: ReqFileLines) -> ReqFileLines: """Replace all environment variables that can be retrieved via `os.getenv`. The only allowed format for environment variables defined in the @@ -521,8 +527,7 @@ def expand_env_variables(lines_enum): yield line_number, line -def get_file_content(url, session): - # type: (str, PipSession) -> Tuple[str, str] +def get_file_content(url: str, session: PipSession) -> Tuple[str, str]: """Gets the content of a file; it may be a filename, file: URL, or http: URL. Returns (location, content). Content is unicode. Respects # -*- coding: declarations on the retrieved files. @@ -532,20 +537,16 @@ def get_file_content(url, session): """ scheme = get_url_scheme(url) - if scheme in ['http', 'https']: - # FIXME: catch some errors + # Pip has special support for file:// URLs (LocalFSAdapter). + if scheme in ["http", "https", "file"]: resp = session.get(url) raise_for_status(resp) return resp.url, resp.text - elif scheme == 'file': - url = url_to_path(url) - + # Assume this is a bare path. try: - with open(url, 'rb') as f: + with open(url, "rb") as f: content = auto_decode(f.read()) except OSError as exc: - raise InstallationError( - f'Could not open requirements file: {exc}' - ) + raise InstallationError(f"Could not open requirements file: {exc}") return url, content diff --git a/env/Lib/site-packages/pip/_internal/req/req_install.py b/env/Lib/site-packages/pip/_internal/req/req_install.py index f4d62514..1f479713 100644 --- a/env/Lib/site-packages/pip/_internal/req/req_install.py +++ b/env/Lib/site-packages/pip/_internal/req/req_install.py @@ -1,55 +1,59 @@ # The following comment should be removed at some point in the future. # mypy: strict-optional=False +import functools import logging import os import shutil import sys import uuid import zipfile -from typing import Any, Dict, Iterable, List, Optional, Sequence, Union +from optparse import Values +from typing import Any, Collection, Dict, Iterable, List, Optional, Sequence, Union -from pip._vendor import pkg_resources, six from pip._vendor.packaging.markers import Marker from pip._vendor.packaging.requirements import Requirement from pip._vendor.packaging.specifiers import SpecifierSet from pip._vendor.packaging.utils import canonicalize_name from pip._vendor.packaging.version import Version from pip._vendor.packaging.version import parse as parse_version -from pip._vendor.pep517.wrappers import Pep517HookCaller -from pip._vendor.pkg_resources import Distribution +from pip._vendor.pyproject_hooks import BuildBackendHookCaller from pip._internal.build_env import BuildEnvironment, NoOpBuildEnvironment from pip._internal.exceptions import InstallationError from pip._internal.locations import get_scheme +from pip._internal.metadata import ( + BaseDistribution, + get_default_environment, + get_directory_distribution, + get_wheel_distribution, +) +from pip._internal.metadata.base import FilesystemWheel +from pip._internal.models.direct_url import DirectUrl from pip._internal.models.link import Link from pip._internal.operations.build.metadata import generate_metadata +from pip._internal.operations.build.metadata_editable import generate_editable_metadata from pip._internal.operations.build.metadata_legacy import ( generate_metadata as generate_metadata_legacy, ) from pip._internal.operations.install.editable_legacy import ( install_editable as install_editable_legacy, ) -from pip._internal.operations.install.legacy import LegacyInstallFailure -from pip._internal.operations.install.legacy import install as install_legacy from pip._internal.operations.install.wheel import install_wheel from pip._internal.pyproject import load_pyproject_toml, make_pyproject_path from pip._internal.req.req_uninstall import UninstallPathSet from pip._internal.utils.deprecation import deprecated -from pip._internal.utils.direct_url_helpers import direct_url_from_link from pip._internal.utils.hashes import Hashes -from pip._internal.utils.logging import indent_log from pip._internal.utils.misc import ( + ConfiguredBuildBackendHookCaller, ask_path_exists, backup_dir, display_path, - dist_in_site_packages, - dist_in_usersite, - get_distribution, hide_url, redact_auth_from_url, ) -from pip._internal.utils.packaging import get_metadata +from pip._internal.utils.packaging import safe_extra +from pip._internal.utils.subprocess import runner_with_spinner_message from pip._internal.utils.temp_dir import TempDirectory, tempdir_kinds from pip._internal.utils.virtualenv import running_under_virtualenv from pip._internal.vcs import vcs @@ -57,33 +61,6 @@ from pip._internal.vcs import vcs logger = logging.getLogger(__name__) -def _get_dist(metadata_directory): - # type: (str) -> Distribution - """Return a pkg_resources.Distribution for the provided - metadata directory. - """ - dist_dir = metadata_directory.rstrip(os.sep) - - # Build a PathMetadata object, from path to metadata. :wink: - base_dir, dist_dir_name = os.path.split(dist_dir) - metadata = pkg_resources.PathMetadata(base_dir, dist_dir) - - # Determine the correct Distribution object type. - if dist_dir.endswith(".egg-info"): - dist_cls = pkg_resources.Distribution - dist_name = os.path.splitext(dist_dir_name)[0] - else: - assert dist_dir.endswith(".dist-info") - dist_cls = pkg_resources.DistInfoDistribution - dist_name = os.path.splitext(dist_dir_name)[0].split("-")[0] - - return dist_cls( - base_dir, - project_name=dist_name, - metadata=metadata, - ) - - class InstallRequirement: """ Represents something that may be installed later on, may have information @@ -93,78 +70,84 @@ class InstallRequirement: def __init__( self, - req, # type: Optional[Requirement] - comes_from, # type: Optional[Union[str, InstallRequirement]] - editable=False, # type: bool - link=None, # type: Optional[Link] - markers=None, # type: Optional[Marker] - use_pep517=None, # type: Optional[bool] - isolated=False, # type: bool - install_options=None, # type: Optional[List[str]] - global_options=None, # type: Optional[List[str]] - hash_options=None, # type: Optional[Dict[str, List[str]]] - constraint=False, # type: bool - extras=(), # type: Iterable[str] - user_supplied=False, # type: bool - ): - # type: (...) -> None + req: Optional[Requirement], + comes_from: Optional[Union[str, "InstallRequirement"]], + editable: bool = False, + link: Optional[Link] = None, + markers: Optional[Marker] = None, + use_pep517: Optional[bool] = None, + isolated: bool = False, + *, + global_options: Optional[List[str]] = None, + hash_options: Optional[Dict[str, List[str]]] = None, + config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, + constraint: bool = False, + extras: Collection[str] = (), + user_supplied: bool = False, + permit_editable_wheels: bool = False, + ) -> None: assert req is None or isinstance(req, Requirement), req self.req = req self.comes_from = comes_from self.constraint = constraint self.editable = editable - self.legacy_install_reason = None # type: Optional[int] + self.permit_editable_wheels = permit_editable_wheels # source_dir is the local directory where the linked requirement is # located, or unpacked. In case unpacking is needed, creating and # populating source_dir is done by the RequirementPreparer. Note this # is not necessarily the directory where pyproject.toml or setup.py is # located - that one is obtained via unpacked_source_directory. - self.source_dir = None # type: Optional[str] + self.source_dir: Optional[str] = None if self.editable: assert link if link.is_file: - self.source_dir = os.path.normpath( - os.path.abspath(link.file_path) - ) + self.source_dir = os.path.normpath(os.path.abspath(link.file_path)) + # original_link is the direct URL that was provided by the user for the + # requirement, either directly or via a constraints file. if link is None and req and req.url: # PEP 508 URL requirement link = Link(req.url) self.link = self.original_link = link - self.original_link_is_in_wheel_cache = False + + # When this InstallRequirement is a wheel obtained from the cache of locally + # built wheels, this is the source link corresponding to the cache entry, which + # was used to download and build the cached wheel. + self.cached_wheel_source_link: Optional[Link] = None + + # Information about the location of the artifact that was downloaded . This + # property is guaranteed to be set in resolver results. + self.download_info: Optional[DirectUrl] = None # Path to any downloaded or already-existing package. - self.local_file_path = None # type: Optional[str] + self.local_file_path: Optional[str] = None if self.link and self.link.is_file: self.local_file_path = self.link.file_path if extras: self.extras = extras elif req: - self.extras = { - pkg_resources.safe_extra(extra) for extra in req.extras - } + self.extras = {safe_extra(extra) for extra in req.extras} else: self.extras = set() if markers is None and req: markers = req.marker self.markers = markers - # This holds the pkg_resources.Distribution object if this requirement - # is already available: - self.satisfied_by = None # type: Optional[Distribution] + # This holds the Distribution object if this requirement is already installed. + self.satisfied_by: Optional[BaseDistribution] = None # Whether the installation process should try to uninstall an existing # distribution before installing this requirement. self.should_reinstall = False # Temporary build location - self._temp_build_dir = None # type: Optional[TempDirectory] + self._temp_build_dir: Optional[TempDirectory] = None # Set to True after successful installation - self.install_succeeded = None # type: Optional[bool] + self.install_succeeded: Optional[bool] = None # Supplied options - self.install_options = install_options if install_options else [] self.global_options = global_options if global_options else [] self.hash_options = hash_options if hash_options else {} + self.config_settings = config_settings # Set to True after successful preparation of this requirement self.prepared = False # User supplied requirement are explicitly requested for installation @@ -173,22 +156,22 @@ class InstallRequirement: self.user_supplied = user_supplied self.isolated = isolated - self.build_env = NoOpBuildEnvironment() # type: BuildEnvironment + self.build_env: BuildEnvironment = NoOpBuildEnvironment() # For PEP 517, the directory where we request the project metadata # gets stored. We need this to pass to build_wheel, so the backend # can ensure that the wheel matches the metadata (see the PEP for # details). - self.metadata_directory = None # type: Optional[str] + self.metadata_directory: Optional[str] = None # The static build requirements (from pyproject.toml) - self.pyproject_requires = None # type: Optional[List[str]] + self.pyproject_requires: Optional[List[str]] = None # Build requirements that we will check are available - self.requirements_to_check = [] # type: List[str] + self.requirements_to_check: List[str] = [] # The PEP 517 backend we should use to build the project - self.pep517_backend = None # type: Optional[Pep517HookCaller] + self.pep517_backend: Optional[BuildBackendHookCaller] = None # Are we using PEP 517 for this requirement? # After pyproject.toml has been loaded, the only valid values are True @@ -200,87 +183,97 @@ class InstallRequirement: # This requirement needs more preparation before it can be built self.needs_more_preparation = False - def __str__(self): - # type: () -> str + def __str__(self) -> str: if self.req: s = str(self.req) if self.link: - s += ' from {}'.format(redact_auth_from_url(self.link.url)) + s += " from {}".format(redact_auth_from_url(self.link.url)) elif self.link: s = redact_auth_from_url(self.link.url) else: - s = '<InstallRequirement>' + s = "<InstallRequirement>" if self.satisfied_by is not None: - s += ' in {}'.format(display_path(self.satisfied_by.location)) + if self.satisfied_by.location is not None: + location = display_path(self.satisfied_by.location) + else: + location = "<memory>" + s += f" in {location}" if self.comes_from: if isinstance(self.comes_from, str): - comes_from = self.comes_from # type: Optional[str] + comes_from: Optional[str] = self.comes_from else: comes_from = self.comes_from.from_path() if comes_from: - s += f' (from {comes_from})' + s += f" (from {comes_from})" return s - def __repr__(self): - # type: () -> str - return '<{} object: {} editable={!r}>'.format( - self.__class__.__name__, str(self), self.editable) + def __repr__(self) -> str: + return "<{} object: {} editable={!r}>".format( + self.__class__.__name__, str(self), self.editable + ) - def format_debug(self): - # type: () -> str - """An un-tested helper for getting state, for debugging. - """ + def format_debug(self) -> str: + """An un-tested helper for getting state, for debugging.""" attributes = vars(self) names = sorted(attributes) - state = ( - "{}={!r}".format(attr, attributes[attr]) for attr in sorted(names) - ) - return '<{name} object: {{{state}}}>'.format( + state = ("{}={!r}".format(attr, attributes[attr]) for attr in sorted(names)) + return "<{name} object: {{{state}}}>".format( name=self.__class__.__name__, state=", ".join(state), ) # Things that are valid for all kinds of requirements? @property - def name(self): - # type: () -> Optional[str] + def name(self) -> Optional[str]: if self.req is None: return None - return pkg_resources.safe_name(self.req.name) + return self.req.name + + @functools.lru_cache() # use cached_property in python 3.8+ + def supports_pyproject_editable(self) -> bool: + if not self.use_pep517: + return False + assert self.pep517_backend + with self.build_env: + runner = runner_with_spinner_message( + "Checking if build backend supports build_editable" + ) + with self.pep517_backend.subprocess_runner(runner): + return "build_editable" in self.pep517_backend._supported_features() @property - def specifier(self): - # type: () -> SpecifierSet + def specifier(self) -> SpecifierSet: return self.req.specifier @property - def is_pinned(self): - # type: () -> bool + def is_direct(self) -> bool: + """Whether this requirement was specified as a direct URL.""" + return self.original_link is not None + + @property + def is_pinned(self) -> bool: """Return whether I am pinned to an exact version. For example, some-package==1.2 is pinned; some-package>1.2 is not. """ specifiers = self.specifier - return (len(specifiers) == 1 and - next(iter(specifiers)).operator in {'==', '==='}) + return len(specifiers) == 1 and next(iter(specifiers)).operator in {"==", "==="} - def match_markers(self, extras_requested=None): - # type: (Optional[Iterable[str]]) -> bool + def match_markers(self, extras_requested: Optional[Iterable[str]] = None) -> bool: if not extras_requested: # Provide an extra to safely evaluate the markers # without matching any extra - extras_requested = ('',) + extras_requested = ("",) if self.markers is not None: return any( - self.markers.evaluate({'extra': extra}) - for extra in extras_requested) + self.markers.evaluate({"extra": extra}) for extra in extras_requested + ) else: return True @property - def has_hash_options(self): - # type: () -> bool + def has_hash_options(self) -> bool: """Return whether any known-good hashes are specified as options. These activate --require-hashes mode; hashes specified as part of a @@ -289,8 +282,7 @@ class InstallRequirement: """ return bool(self.hash_options) - def hashes(self, trust_internet=True): - # type: (bool) -> Hashes + def hashes(self, trust_internet: bool = True) -> Hashes: """Return a hash-comparer that considers my option- and URL-based hashes to be known-good. @@ -306,15 +298,18 @@ class InstallRequirement: """ good_hashes = self.hash_options.copy() - link = self.link if trust_internet else self.original_link + if trust_internet: + link = self.link + elif self.is_direct and self.user_supplied: + link = self.original_link + else: + link = None if link and link.hash: good_hashes.setdefault(link.hash_name, []).append(link.hash) return Hashes(good_hashes) - def from_path(self): - # type: () -> Optional[str] - """Format a nice indicator to show where this "comes from" - """ + def from_path(self) -> Optional[str]: + """Format a nice indicator to show where this "comes from" """ if self.req is None: return None s = str(self.req) @@ -324,11 +319,12 @@ class InstallRequirement: else: comes_from = self.comes_from.from_path() if comes_from: - s += '->' + comes_from + s += "->" + comes_from return s - def ensure_build_location(self, build_dir, autodelete, parallel_builds): - # type: (str, bool, bool) -> str + def ensure_build_location( + self, build_dir: str, autodelete: bool, parallel_builds: bool + ) -> str: assert build_dir is not None if self._temp_build_dir is not None: assert self._temp_build_dir.path @@ -349,14 +345,14 @@ class InstallRequirement: # When parallel builds are enabled, add a UUID to the build directory # name so multiple builds do not interfere with each other. - dir_name = canonicalize_name(self.name) # type: str + dir_name: str = canonicalize_name(self.name) if parallel_builds: dir_name = f"{dir_name}_{uuid.uuid4().hex}" # FIXME: Is there a better place to create the build_dir? (hg and bzr # need this) if not os.path.exists(build_dir): - logger.debug('Creating directory %s', build_dir) + logger.debug("Creating directory %s", build_dir) os.makedirs(build_dir) actual_build_dir = os.path.join(build_dir, dir_name) # `None` indicates that we respect the globally-configured deletion @@ -369,10 +365,8 @@ class InstallRequirement: globally_managed=True, ).path - def _set_requirement(self): - # type: () -> None - """Set requirement after generating metadata. - """ + def _set_requirement(self) -> None: + """Set requirement after generating metadata.""" assert self.req is None assert self.metadata is not None assert self.source_dir is not None @@ -384,15 +378,16 @@ class InstallRequirement: op = "===" self.req = Requirement( - "".join([ - self.metadata["Name"], - op, - self.metadata["Version"], - ]) + "".join( + [ + self.metadata["Name"], + op, + self.metadata["Version"], + ] + ) ) - def warn_on_mismatching_name(self): - # type: () -> None + def warn_on_mismatching_name(self) -> None: metadata_name = canonicalize_name(self.metadata["Name"]) if canonicalize_name(self.req.name) == metadata_name: # Everything is fine. @@ -400,45 +395,40 @@ class InstallRequirement: # If we're here, there's a mismatch. Log a warning about it. logger.warning( - 'Generating metadata for package %s ' - 'produced metadata for project name %s. Fix your ' - '#egg=%s fragments.', - self.name, metadata_name, self.name + "Generating metadata for package %s " + "produced metadata for project name %s. Fix your " + "#egg=%s fragments.", + self.name, + metadata_name, + self.name, ) self.req = Requirement(metadata_name) - def check_if_exists(self, use_user_site): - # type: (bool) -> None + def check_if_exists(self, use_user_site: bool) -> None: """Find an installed distribution that satisfies or conflicts with this requirement, and set self.satisfied_by or self.should_reinstall appropriately. """ if self.req is None: return - existing_dist = get_distribution(self.req.name) + existing_dist = get_default_environment().get_distribution(self.req.name) if not existing_dist: return - # pkg_resouces may contain a different copy of packaging.version from - # pip in if the downstream distributor does a poor job debundling pip. - # We avoid existing_dist.parsed_version and let SpecifierSet.contains - # parses the version instead. - existing_version = existing_dist.version - version_compatible = ( - existing_version is not None and - self.req.specifier.contains(existing_version, prereleases=True) + version_compatible = self.req.specifier.contains( + existing_dist.version, + prereleases=True, ) if not version_compatible: self.satisfied_by = None if use_user_site: - if dist_in_usersite(existing_dist): + if existing_dist.in_usersite: self.should_reinstall = True - elif (running_under_virtualenv() and - dist_in_site_packages(existing_dist)): + elif running_under_virtualenv() and existing_dist.in_site_packages: raise InstallationError( - "Will not install to the user site because it will " - "lack sys.path precedence to {} in {}".format( - existing_dist.project_name, existing_dist.location) + f"Will not install to the user site because it will " + f"lack sys.path precedence to {existing_dist.raw_name} " + f"in {existing_dist.location}" ) else: self.should_reinstall = True @@ -453,36 +443,44 @@ class InstallRequirement: # Things valid for wheels @property - def is_wheel(self): - # type: () -> bool + def is_wheel(self) -> bool: if not self.link: return False return self.link.is_wheel + @property + def is_wheel_from_cache(self) -> bool: + # When True, it means that this InstallRequirement is a local wheel file in the + # cache of locally built wheels. + return self.cached_wheel_source_link is not None + # Things valid for sdists @property - def unpacked_source_directory(self): - # type: () -> str + def unpacked_source_directory(self) -> str: return os.path.join( - self.source_dir, - self.link and self.link.subdirectory_fragment or '') + self.source_dir, self.link and self.link.subdirectory_fragment or "" + ) @property - def setup_py_path(self): - # type: () -> str + def setup_py_path(self) -> str: assert self.source_dir, f"No source dir for {self}" - setup_py = os.path.join(self.unpacked_source_directory, 'setup.py') + setup_py = os.path.join(self.unpacked_source_directory, "setup.py") return setup_py @property - def pyproject_toml_path(self): - # type: () -> str + def setup_cfg_path(self) -> str: + assert self.source_dir, f"No source dir for {self}" + setup_cfg = os.path.join(self.unpacked_source_directory, "setup.cfg") + + return setup_cfg + + @property + def pyproject_toml_path(self) -> str: assert self.source_dir, f"No source dir for {self}" return make_pyproject_path(self.unpacked_source_directory) - def load_pyproject_toml(self): - # type: () -> None + def load_pyproject_toml(self) -> None: """Load the pyproject.toml file. After calling this routine, all of the attributes related to PEP 517 @@ -491,13 +489,19 @@ class InstallRequirement: follow the PEP 517 or legacy (setup.py) code path. """ pyproject_toml_data = load_pyproject_toml( - self.use_pep517, - self.pyproject_toml_path, - self.setup_py_path, - str(self) + self.use_pep517, self.pyproject_toml_path, self.setup_py_path, str(self) ) if pyproject_toml_data is None: + if self.config_settings: + deprecated( + reason=f"Config settings are ignored for project {self}.", + replacement=( + "to use --use-pep517 or add a " + "pyproject.toml file to the project" + ), + gone_in="23.3", + ) self.use_pep517 = False return @@ -505,48 +509,69 @@ class InstallRequirement: requires, backend, check, backend_path = pyproject_toml_data self.requirements_to_check = check self.pyproject_requires = requires - self.pep517_backend = Pep517HookCaller( - self.unpacked_source_directory, backend, backend_path=backend_path, + self.pep517_backend = ConfiguredBuildBackendHookCaller( + self, + self.unpacked_source_directory, + backend, + backend_path=backend_path, ) - def _generate_metadata(self): - # type: () -> str - """Invokes metadata generator functions, with the required arguments. - """ - if not self.use_pep517: - assert self.unpacked_source_directory - - if not os.path.exists(self.setup_py_path): - raise InstallationError( - f'File "setup.py" not found for legacy project {self}.' - ) + def isolated_editable_sanity_check(self) -> None: + """Check that an editable requirement if valid for use with PEP 517/518. - return generate_metadata_legacy( - build_env=self.build_env, - setup_py_path=self.setup_py_path, - source_dir=self.unpacked_source_directory, - isolated=self.isolated, - details=self.name or f"from {self.link}" + This verifies that an editable that has a pyproject.toml either supports PEP 660 + or as a setup.py or a setup.cfg + """ + if ( + self.editable + and self.use_pep517 + and not self.supports_pyproject_editable() + and not os.path.isfile(self.setup_py_path) + and not os.path.isfile(self.setup_cfg_path) + ): + raise InstallationError( + f"Project {self} has a 'pyproject.toml' and its build " + f"backend is missing the 'build_editable' hook. Since it does not " + f"have a 'setup.py' nor a 'setup.cfg', " + f"it cannot be installed in editable mode. " + f"Consider using a build backend that supports PEP 660." ) - assert self.pep517_backend is not None - - return generate_metadata( - build_env=self.build_env, - backend=self.pep517_backend, - ) - - def prepare_metadata(self): - # type: () -> None + def prepare_metadata(self) -> None: """Ensure that project metadata is available. - Under PEP 517, call the backend hook to prepare the metadata. + Under PEP 517 and PEP 660, call the backend hook to prepare the metadata. Under legacy processing, call setup.py egg-info. """ assert self.source_dir - - with indent_log(): - self.metadata_directory = self._generate_metadata() + details = self.name or f"from {self.link}" + + if self.use_pep517: + assert self.pep517_backend is not None + if ( + self.editable + and self.permit_editable_wheels + and self.supports_pyproject_editable() + ): + self.metadata_directory = generate_editable_metadata( + build_env=self.build_env, + backend=self.pep517_backend, + details=details, + ) + else: + self.metadata_directory = generate_metadata( + build_env=self.build_env, + backend=self.pep517_backend, + details=details, + ) + else: + self.metadata_directory = generate_metadata_legacy( + build_env=self.build_env, + setup_py_path=self.setup_py_path, + source_dir=self.unpacked_source_directory, + isolated=self.isolated, + details=details, + ) # Act on the newly generated metadata, based on the name and version. if not self.name: @@ -557,30 +582,36 @@ class InstallRequirement: self.assert_source_matches_version() @property - def metadata(self): - # type: () -> Any - if not hasattr(self, '_metadata'): - self._metadata = get_metadata(self.get_dist()) + def metadata(self) -> Any: + if not hasattr(self, "_metadata"): + self._metadata = self.get_dist().metadata return self._metadata - def get_dist(self): - # type: () -> Distribution - return _get_dist(self.metadata_directory) + def get_dist(self) -> BaseDistribution: + if self.metadata_directory: + return get_directory_distribution(self.metadata_directory) + elif self.local_file_path and self.is_wheel: + return get_wheel_distribution( + FilesystemWheel(self.local_file_path), canonicalize_name(self.name) + ) + raise AssertionError( + f"InstallRequirement {self} has no metadata directory and no wheel: " + f"can't make a distribution." + ) - def assert_source_matches_version(self): - # type: () -> None + def assert_source_matches_version(self) -> None: assert self.source_dir - version = self.metadata['version'] + version = self.metadata["version"] if self.req.specifier and version not in self.req.specifier: logger.warning( - 'Requested %s, but installing version %s', + "Requested %s, but installing version %s", self, version, ) else: logger.debug( - 'Source in %s has version %s, which satisfies requirement %s', + "Source in %s has version %s, which satisfies requirement %s", display_path(self.source_dir), version, self, @@ -589,11 +620,10 @@ class InstallRequirement: # For both source distributions and editables def ensure_has_source_dir( self, - parent_dir, - autodelete=False, - parallel_builds=False, - ): - # type: (str, bool, bool) -> None + parent_dir: str, + autodelete: bool = False, + parallel_builds: bool = False, + ) -> None: """Ensure that a source_dir is set. This will create a temporary build dir if the name of the requirement @@ -611,18 +641,16 @@ class InstallRequirement: ) # For editable installations - def update_editable(self): - # type: () -> None + def update_editable(self) -> None: if not self.link: logger.debug( - "Cannot update repository at %s; repository location is " - "unknown", + "Cannot update repository at %s; repository location is unknown", self.source_dir, ) return assert self.editable assert self.source_dir - if self.link.scheme == 'file': + if self.link.scheme == "file": # Static paths don't get updated return vcs_backend = vcs.get_backend_for_scheme(self.link.scheme) @@ -630,11 +658,12 @@ class InstallRequirement: # So here, if it's neither a path nor a valid VCS URL, it's a bug. assert vcs_backend, f"Unsupported VCS URL {self.link.url}" hidden_url = hide_url(self.link.url) - vcs_backend.obtain(self.source_dir, url=hidden_url) + vcs_backend.obtain(self.source_dir, url=hidden_url, verbosity=0) # Top-level Actions - def uninstall(self, auto_confirm=False, verbose=False): - # type: (bool, bool) -> Optional[UninstallPathSet] + def uninstall( + self, auto_confirm: bool = False, verbose: bool = False + ) -> Optional[UninstallPathSet]: """ Uninstall the distribution currently satisfying this requirement. @@ -648,34 +677,30 @@ class InstallRequirement: """ assert self.req - dist = get_distribution(self.req.name) + dist = get_default_environment().get_distribution(self.req.name) if not dist: logger.warning("Skipping %s as it is not installed.", self.name) return None - logger.info('Found existing installation: %s', dist) + logger.info("Found existing installation: %s", dist) uninstalled_pathset = UninstallPathSet.from_dist(dist) uninstalled_pathset.remove(auto_confirm, verbose) return uninstalled_pathset - def _get_archive_name(self, path, parentdir, rootdir): - # type: (str, str, str) -> str - - def _clean_zip_name(name, prefix): - # type: (str, str) -> str - assert name.startswith(prefix + os.path.sep), ( - f"name {name!r} doesn't start with prefix {prefix!r}" - ) - name = name[len(prefix) + 1:] - name = name.replace(os.path.sep, '/') + def _get_archive_name(self, path: str, parentdir: str, rootdir: str) -> str: + def _clean_zip_name(name: str, prefix: str) -> str: + assert name.startswith( + prefix + os.path.sep + ), f"name {name!r} doesn't start with prefix {prefix!r}" + name = name[len(prefix) + 1 :] + name = name.replace(os.path.sep, "/") return name path = os.path.join(parentdir, path) name = _clean_zip_name(path, rootdir) - return self.name + '/' + name + return self.name + "/" + name - def archive(self, build_dir): - # type: (Optional[str]) -> None + def archive(self, build_dir: Optional[str]) -> None: """Saves archive to provided build_dir. Used for saving downloaded VCS requirements as part of `pip download`. @@ -685,70 +710,73 @@ class InstallRequirement: return create_archive = True - archive_name = '{}-{}.zip'.format(self.name, self.metadata["version"]) + archive_name = "{}-{}.zip".format(self.name, self.metadata["version"]) archive_path = os.path.join(build_dir, archive_name) if os.path.exists(archive_path): response = ask_path_exists( - 'The file {} exists. (i)gnore, (w)ipe, ' - '(b)ackup, (a)bort '.format( - display_path(archive_path)), - ('i', 'w', 'b', 'a')) - if response == 'i': + "The file {} exists. (i)gnore, (w)ipe, " + "(b)ackup, (a)bort ".format(display_path(archive_path)), + ("i", "w", "b", "a"), + ) + if response == "i": create_archive = False - elif response == 'w': - logger.warning('Deleting %s', display_path(archive_path)) + elif response == "w": + logger.warning("Deleting %s", display_path(archive_path)) os.remove(archive_path) - elif response == 'b': + elif response == "b": dest_file = backup_dir(archive_path) logger.warning( - 'Backing up %s to %s', + "Backing up %s to %s", display_path(archive_path), display_path(dest_file), ) shutil.move(archive_path, dest_file) - elif response == 'a': + elif response == "a": sys.exit(-1) if not create_archive: return zip_output = zipfile.ZipFile( - archive_path, 'w', zipfile.ZIP_DEFLATED, allowZip64=True, + archive_path, + "w", + zipfile.ZIP_DEFLATED, + allowZip64=True, ) with zip_output: - dir = os.path.normcase( - os.path.abspath(self.unpacked_source_directory) - ) + dir = os.path.normcase(os.path.abspath(self.unpacked_source_directory)) for dirpath, dirnames, filenames in os.walk(dir): for dirname in dirnames: dir_arcname = self._get_archive_name( - dirname, parentdir=dirpath, rootdir=dir, + dirname, + parentdir=dirpath, + rootdir=dir, ) - zipdir = zipfile.ZipInfo(dir_arcname + '/') + zipdir = zipfile.ZipInfo(dir_arcname + "/") zipdir.external_attr = 0x1ED << 16 # 0o755 - zip_output.writestr(zipdir, '') + zip_output.writestr(zipdir, "") for filename in filenames: file_arcname = self._get_archive_name( - filename, parentdir=dirpath, rootdir=dir, + filename, + parentdir=dirpath, + rootdir=dir, ) filename = os.path.join(dirpath, filename) zip_output.write(filename, file_arcname) - logger.info('Saved %s', display_path(archive_path)) + logger.info("Saved %s", display_path(archive_path)) def install( self, - install_options, # type: List[str] - global_options=None, # type: Optional[Sequence[str]] - root=None, # type: Optional[str] - home=None, # type: Optional[str] - prefix=None, # type: Optional[str] - warn_script_location=True, # type: bool - use_user_site=False, # type: bool - pycompile=True # type: bool - ): - # type: (...) -> None + global_options: Optional[Sequence[str]] = None, + root: Optional[str] = None, + home: Optional[str] = None, + prefix: Optional[str] = None, + warn_script_location: bool = True, + use_user_site: bool = False, + pycompile: bool = True, + ) -> None: scheme = get_scheme( self.name, user=use_user_site, @@ -758,11 +786,9 @@ class InstallRequirement: prefix=prefix, ) - global_options = global_options if global_options is not None else [] - if self.editable: + if self.editable and not self.is_wheel: install_editable_legacy( - install_options, - global_options, + global_options=global_options if global_options is not None else [], prefix=prefix, home=home, use_user_site=use_user_site, @@ -775,80 +801,23 @@ class InstallRequirement: self.install_succeeded = True return - if self.is_wheel: - assert self.local_file_path - direct_url = None - if self.original_link: - direct_url = direct_url_from_link( - self.original_link, - self.source_dir, - self.original_link_is_in_wheel_cache, - ) - install_wheel( - self.name, - self.local_file_path, - scheme=scheme, - req_description=str(self.req), - pycompile=pycompile, - warn_script_location=warn_script_location, - direct_url=direct_url, - requested=self.user_supplied, - ) - self.install_succeeded = True - return - - # TODO: Why don't we do this for editable installs? - - # Extend the list of global and install options passed on to - # the setup.py call with the ones from the requirements file. - # Options specified in requirements file override those - # specified on the command line, since the last option given - # to setup.py is the one that is used. - global_options = list(global_options) + self.global_options - install_options = list(install_options) + self.install_options - - try: - success = install_legacy( - install_options=install_options, - global_options=global_options, - root=root, - home=home, - prefix=prefix, - use_user_site=use_user_site, - pycompile=pycompile, - scheme=scheme, - setup_py_path=self.setup_py_path, - isolated=self.isolated, - req_name=self.name, - build_env=self.build_env, - unpacked_source_directory=self.unpacked_source_directory, - req_description=str(self.req), - ) - except LegacyInstallFailure as exc: - self.install_succeeded = False - six.reraise(*exc.parent) - except Exception: - self.install_succeeded = True - raise - - self.install_succeeded = success - - if success and self.legacy_install_reason == 8368: - deprecated( - reason=( - "{} was installed using the legacy 'setup.py install' " - "method, because a wheel could not be built for it.". - format(self.name) - ), - replacement="to fix the wheel build issue reported above", - gone_in=None, - issue=8368, - ) + assert self.is_wheel + assert self.local_file_path + install_wheel( + self.name, + self.local_file_path, + scheme=scheme, + req_description=str(self.req), + pycompile=pycompile, + warn_script_location=warn_script_location, + direct_url=self.download_info if self.is_direct else None, + requested=self.user_supplied, + ) + self.install_succeeded = True -def check_invalid_constraint_type(req): - # type: (InstallRequirement) -> str +def check_invalid_constraint_type(req: InstallRequirement) -> str: # Check for unsupported forms problem = "" if not req.name: @@ -867,12 +836,39 @@ def check_invalid_constraint_type(req): "undocumented. The new implementation of the resolver no " "longer supports these forms." ), - replacement=( - "replacing the constraint with a requirement." - ), + replacement="replacing the constraint with a requirement", # No plan yet for when the new resolver becomes default gone_in=None, - issue=8210 + issue=8210, ) return problem + + +def _has_option(options: Values, reqs: List[InstallRequirement], option: str) -> bool: + if getattr(options, option, None): + return True + for req in reqs: + if getattr(req, option, None): + return True + return False + + +def check_legacy_setup_py_options( + options: Values, + reqs: List[InstallRequirement], +) -> None: + has_build_options = _has_option(options, reqs, "build_options") + has_global_options = _has_option(options, reqs, "global_options") + if has_build_options or has_global_options: + deprecated( + reason="--build-option and --global-option are deprecated.", + issue=11859, + replacement="to use --config-settings", + gone_in="23.3", + ) + logger.warning( + "Implying --no-binary=:all: due to the presence of " + "--build-option / --global-option. " + ) + options.format_control.disallow_binaries() diff --git a/env/Lib/site-packages/pip/_internal/req/req_set.py b/env/Lib/site-packages/pip/_internal/req/req_set.py index 59c58435..cff67601 100644 --- a/env/Lib/site-packages/pip/_internal/req/req_set.py +++ b/env/Lib/site-packages/pip/_internal/req/req_set.py @@ -1,191 +1,65 @@ import logging from collections import OrderedDict -from typing import Dict, Iterable, List, Optional, Tuple +from typing import Dict, List +from pip._vendor.packaging.specifiers import LegacySpecifier from pip._vendor.packaging.utils import canonicalize_name +from pip._vendor.packaging.version import LegacyVersion -from pip._internal.exceptions import InstallationError -from pip._internal.models.wheel import Wheel from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils import compatibility_tags +from pip._internal.utils.deprecation import deprecated logger = logging.getLogger(__name__) class RequirementSet: + def __init__(self, check_supported_wheels: bool = True) -> None: + """Create a RequirementSet.""" - def __init__(self, check_supported_wheels=True): - # type: (bool) -> None - """Create a RequirementSet. - """ - - self.requirements = OrderedDict() # type: Dict[str, InstallRequirement] + self.requirements: Dict[str, InstallRequirement] = OrderedDict() self.check_supported_wheels = check_supported_wheels - self.unnamed_requirements = [] # type: List[InstallRequirement] + self.unnamed_requirements: List[InstallRequirement] = [] - def __str__(self): - # type: () -> str + def __str__(self) -> str: requirements = sorted( (req for req in self.requirements.values() if not req.comes_from), key=lambda req: canonicalize_name(req.name or ""), ) - return ' '.join(str(req.req) for req in requirements) + return " ".join(str(req.req) for req in requirements) - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: requirements = sorted( self.requirements.values(), key=lambda req: canonicalize_name(req.name or ""), ) - format_string = '<{classname} object; {count} requirement(s): {reqs}>' + format_string = "<{classname} object; {count} requirement(s): {reqs}>" return format_string.format( classname=self.__class__.__name__, count=len(requirements), - reqs=', '.join(str(req.req) for req in requirements), + reqs=", ".join(str(req.req) for req in requirements), ) - def add_unnamed_requirement(self, install_req): - # type: (InstallRequirement) -> None + def add_unnamed_requirement(self, install_req: InstallRequirement) -> None: assert not install_req.name self.unnamed_requirements.append(install_req) - def add_named_requirement(self, install_req): - # type: (InstallRequirement) -> None + def add_named_requirement(self, install_req: InstallRequirement) -> None: assert install_req.name project_name = canonicalize_name(install_req.name) self.requirements[project_name] = install_req - def add_requirement( - self, - install_req, # type: InstallRequirement - parent_req_name=None, # type: Optional[str] - extras_requested=None # type: Optional[Iterable[str]] - ): - # type: (...) -> Tuple[List[InstallRequirement], Optional[InstallRequirement]] - """Add install_req as a requirement to install. - - :param parent_req_name: The name of the requirement that needed this - added. The name is used because when multiple unnamed requirements - resolve to the same name, we could otherwise end up with dependency - links that point outside the Requirements set. parent_req must - already be added. Note that None implies that this is a user - supplied requirement, vs an inferred one. - :param extras_requested: an iterable of extras used to evaluate the - environment markers. - :return: Additional requirements to scan. That is either [] if - the requirement is not applicable, or [install_req] if the - requirement is applicable and has just been added. - """ - # If the markers do not match, ignore this requirement. - if not install_req.match_markers(extras_requested): - logger.info( - "Ignoring %s: markers '%s' don't match your environment", - install_req.name, install_req.markers, - ) - return [], None - - # If the wheel is not supported, raise an error. - # Should check this after filtering out based on environment markers to - # allow specifying different wheels based on the environment/OS, in a - # single requirements file. - if install_req.link and install_req.link.is_wheel: - wheel = Wheel(install_req.link.filename) - tags = compatibility_tags.get_supported() - if (self.check_supported_wheels and not wheel.supported(tags)): - raise InstallationError( - "{} is not a supported wheel on this platform.".format( - wheel.filename) - ) - - # This next bit is really a sanity check. - assert not install_req.user_supplied or parent_req_name is None, ( - "a user supplied req shouldn't have a parent" - ) - - # Unnamed requirements are scanned again and the requirement won't be - # added as a dependency until after scanning. - if not install_req.name: - self.add_unnamed_requirement(install_req) - return [install_req], None - - try: - existing_req = self.get_requirement( - install_req.name) # type: Optional[InstallRequirement] - except KeyError: - existing_req = None - - has_conflicting_requirement = ( - parent_req_name is None and - existing_req and - not existing_req.constraint and - existing_req.extras == install_req.extras and - existing_req.req and - install_req.req and - existing_req.req.specifier != install_req.req.specifier - ) - if has_conflicting_requirement: - raise InstallationError( - "Double requirement given: {} (already in {}, name={!r})" - .format(install_req, existing_req, install_req.name) - ) - - # When no existing requirement exists, add the requirement as a - # dependency and it will be scanned again after. - if not existing_req: - self.add_named_requirement(install_req) - # We'd want to rescan this requirement later - return [install_req], install_req - - # Assume there's no need to scan, and that we've already - # encountered this for scanning. - if install_req.constraint or not existing_req.constraint: - return [], existing_req - - does_not_satisfy_constraint = ( - install_req.link and - not ( - existing_req.link and - install_req.link.path == existing_req.link.path - ) - ) - if does_not_satisfy_constraint: - raise InstallationError( - "Could not satisfy constraints for '{}': " - "installation from path or url cannot be " - "constrained to a version".format(install_req.name) - ) - # If we're now installing a constraint, mark the existing - # object for real installation. - existing_req.constraint = False - # If we're now installing a user supplied requirement, - # mark the existing object as such. - if install_req.user_supplied: - existing_req.user_supplied = True - existing_req.extras = tuple(sorted( - set(existing_req.extras) | set(install_req.extras) - )) - logger.debug( - "Setting %s extras to: %s", - existing_req, existing_req.extras, - ) - # Return the existing requirement for addition to the parent and - # scanning again. - return [existing_req], existing_req - - def has_requirement(self, name): - # type: (str) -> bool + def has_requirement(self, name: str) -> bool: project_name = canonicalize_name(name) return ( - project_name in self.requirements and - not self.requirements[project_name].constraint + project_name in self.requirements + and not self.requirements[project_name].constraint ) - def get_requirement(self, name): - # type: (str) -> InstallRequirement + def get_requirement(self, name: str) -> InstallRequirement: project_name = canonicalize_name(name) if project_name in self.requirements: @@ -194,6 +68,52 @@ class RequirementSet: raise KeyError(f"No project with the name {name!r}") @property - def all_requirements(self): - # type: () -> List[InstallRequirement] + def all_requirements(self) -> List[InstallRequirement]: return self.unnamed_requirements + list(self.requirements.values()) + + @property + def requirements_to_install(self) -> List[InstallRequirement]: + """Return the list of requirements that need to be installed. + + TODO remove this property together with the legacy resolver, since the new + resolver only returns requirements that need to be installed. + """ + return [ + install_req + for install_req in self.all_requirements + if not install_req.constraint and not install_req.satisfied_by + ] + + def warn_legacy_versions_and_specifiers(self) -> None: + for req in self.requirements_to_install: + version = req.get_dist().version + if isinstance(version, LegacyVersion): + deprecated( + reason=( + f"pip has selected the non standard version {version} " + f"of {req}. In the future this version will be " + f"ignored as it isn't standard compliant." + ), + replacement=( + "set or update constraints to select another version " + "or contact the package author to fix the version number" + ), + issue=12063, + gone_in="23.3", + ) + for dep in req.get_dist().iter_dependencies(): + if any(isinstance(spec, LegacySpecifier) for spec in dep.specifier): + deprecated( + reason=( + f"pip has selected {req} {version} which has non " + f"standard dependency specifier {dep}. " + f"In the future this version of {req} will be " + f"ignored as it isn't standard compliant." + ), + replacement=( + "set or update constraints to select another version " + "or contact the package author to fix the version number" + ), + issue=12063, + gone_in="23.3", + ) diff --git a/env/Lib/site-packages/pip/_internal/req/req_tracker.py b/env/Lib/site-packages/pip/_internal/req/req_tracker.py deleted file mode 100644 index 542e0d94..00000000 --- a/env/Lib/site-packages/pip/_internal/req/req_tracker.py +++ /dev/null @@ -1,140 +0,0 @@ -import contextlib -import hashlib -import logging -import os -from types import TracebackType -from typing import Dict, Iterator, Optional, Set, Type, Union - -from pip._internal.models.link import Link -from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils.temp_dir import TempDirectory - -logger = logging.getLogger(__name__) - - -@contextlib.contextmanager -def update_env_context_manager(**changes): - # type: (str) -> Iterator[None] - target = os.environ - - # Save values from the target and change them. - non_existent_marker = object() - saved_values = {} # type: Dict[str, Union[object, str]] - for name, new_value in changes.items(): - try: - saved_values[name] = target[name] - except KeyError: - saved_values[name] = non_existent_marker - target[name] = new_value - - try: - yield - finally: - # Restore original values in the target. - for name, original_value in saved_values.items(): - if original_value is non_existent_marker: - del target[name] - else: - assert isinstance(original_value, str) # for mypy - target[name] = original_value - - -@contextlib.contextmanager -def get_requirement_tracker(): - # type: () -> Iterator[RequirementTracker] - root = os.environ.get('PIP_REQ_TRACKER') - with contextlib.ExitStack() as ctx: - if root is None: - root = ctx.enter_context( - TempDirectory(kind='req-tracker') - ).path - ctx.enter_context(update_env_context_manager(PIP_REQ_TRACKER=root)) - logger.debug("Initialized build tracking at %s", root) - - with RequirementTracker(root) as tracker: - yield tracker - - -class RequirementTracker: - - def __init__(self, root): - # type: (str) -> None - self._root = root - self._entries = set() # type: Set[InstallRequirement] - logger.debug("Created build tracker: %s", self._root) - - def __enter__(self): - # type: () -> RequirementTracker - logger.debug("Entered build tracker: %s", self._root) - return self - - def __exit__( - self, - exc_type, # type: Optional[Type[BaseException]] - exc_val, # type: Optional[BaseException] - exc_tb # type: Optional[TracebackType] - ): - # type: (...) -> None - self.cleanup() - - def _entry_path(self, link): - # type: (Link) -> str - hashed = hashlib.sha224(link.url_without_fragment.encode()).hexdigest() - return os.path.join(self._root, hashed) - - def add(self, req): - # type: (InstallRequirement) -> None - """Add an InstallRequirement to build tracking. - """ - - assert req.link - # Get the file to write information about this requirement. - entry_path = self._entry_path(req.link) - - # Try reading from the file. If it exists and can be read from, a build - # is already in progress, so a LookupError is raised. - try: - with open(entry_path) as fp: - contents = fp.read() - except FileNotFoundError: - pass - else: - message = '{} is already being built: {}'.format( - req.link, contents) - raise LookupError(message) - - # If we're here, req should really not be building already. - assert req not in self._entries - - # Start tracking this requirement. - with open(entry_path, 'w', encoding="utf-8") as fp: - fp.write(str(req)) - self._entries.add(req) - - logger.debug('Added %s to build tracker %r', req, self._root) - - def remove(self, req): - # type: (InstallRequirement) -> None - """Remove an InstallRequirement from build tracking. - """ - - assert req.link - # Delete the created file and the corresponding entries. - os.unlink(self._entry_path(req.link)) - self._entries.remove(req) - - logger.debug('Removed %s from build tracker %r', req, self._root) - - def cleanup(self): - # type: () -> None - for req in set(self._entries): - self.remove(req) - - logger.debug("Removed build tracker: %r", self._root) - - @contextlib.contextmanager - def track(self, req): - # type: (InstallRequirement) -> Iterator[None] - self.add(req) - yield - self.remove(req) diff --git a/env/Lib/site-packages/pip/_internal/req/req_uninstall.py b/env/Lib/site-packages/pip/_internal/req/req_uninstall.py index b7223417..ad5178e7 100644 --- a/env/Lib/site-packages/pip/_internal/req/req_uninstall.py +++ b/env/Lib/site-packages/pip/_internal/req/req_uninstall.py @@ -1,72 +1,58 @@ -import csv import functools -import logging import os import sys import sysconfig from importlib.util import cache_from_source -from typing import Any, Callable, Dict, Iterable, Iterator, List, Optional, Set, Tuple - -from pip._vendor import pkg_resources -from pip._vendor.pkg_resources import Distribution +from typing import Any, Callable, Dict, Generator, Iterable, List, Optional, Set, Tuple from pip._internal.exceptions import UninstallationError from pip._internal.locations import get_bin_prefix, get_bin_user +from pip._internal.metadata import BaseDistribution from pip._internal.utils.compat import WINDOWS -from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import ( - ask, - dist_in_usersite, - dist_is_local, - egg_link_path, - is_local, - normalize_path, - renames, - rmtree, -) +from pip._internal.utils.egg_link import egg_link_path_from_location +from pip._internal.utils.logging import getLogger, indent_log +from pip._internal.utils.misc import ask, normalize_path, renames, rmtree from pip._internal.utils.temp_dir import AdjacentTempDirectory, TempDirectory +from pip._internal.utils.virtualenv import running_under_virtualenv -logger = logging.getLogger(__name__) +logger = getLogger(__name__) -def _script_names(dist, script_name, is_gui): - # type: (Distribution, str, bool) -> List[str] +def _script_names( + bin_dir: str, script_name: str, is_gui: bool +) -> Generator[str, None, None]: """Create the fully qualified name of the files created by {console,gui}_scripts for the given ``dist``. Returns the list of file names """ - if dist_in_usersite(dist): - bin_dir = get_bin_user() - else: - bin_dir = get_bin_prefix() exe_name = os.path.join(bin_dir, script_name) - paths_to_remove = [exe_name] - if WINDOWS: - paths_to_remove.append(exe_name + '.exe') - paths_to_remove.append(exe_name + '.exe.manifest') - if is_gui: - paths_to_remove.append(exe_name + '-script.pyw') - else: - paths_to_remove.append(exe_name + '-script.py') - return paths_to_remove + yield exe_name + if not WINDOWS: + return + yield f"{exe_name}.exe" + yield f"{exe_name}.exe.manifest" + if is_gui: + yield f"{exe_name}-script.pyw" + else: + yield f"{exe_name}-script.py" -def _unique(fn): - # type: (Callable[..., Iterator[Any]]) -> Callable[..., Iterator[Any]] +def _unique( + fn: Callable[..., Generator[Any, None, None]] +) -> Callable[..., Generator[Any, None, None]]: @functools.wraps(fn) - def unique(*args, **kw): - # type: (Any, Any) -> Iterator[Any] - seen = set() # type: Set[Any] + def unique(*args: Any, **kw: Any) -> Generator[Any, None, None]: + seen: Set[Any] = set() for item in fn(*args, **kw): if item not in seen: seen.add(item) yield item + return unique @_unique -def uninstallation_paths(dist): - # type: (Distribution) -> Iterator[str] +def uninstallation_paths(dist: BaseDistribution) -> Generator[str, None, None]: """ Yield all the uninstallation paths for dist based on RECORD-without-.py[co] @@ -74,33 +60,53 @@ def uninstallation_paths(dist): the .pyc and .pyo in the same directory. UninstallPathSet.add() takes care of the __pycache__ .py[co]. + + If RECORD is not found, raises UninstallationError, + with possible information from the INSTALLER file. + + https://packaging.python.org/specifications/recording-installed-packages/ """ - r = csv.reader(dist.get_metadata_lines('RECORD')) - for row in r: - path = os.path.join(dist.location, row[0]) + location = dist.location + assert location is not None, "not installed" + + entries = dist.iter_declared_entries() + if entries is None: + msg = "Cannot uninstall {dist}, RECORD file not found.".format(dist=dist) + installer = dist.installer + if not installer or installer == "pip": + dep = "{}=={}".format(dist.raw_name, dist.version) + msg += ( + " You might be able to recover from this via: " + "'pip install --force-reinstall --no-deps {}'.".format(dep) + ) + else: + msg += " Hint: The package was installed by {}.".format(installer) + raise UninstallationError(msg) + + for entry in entries: + path = os.path.join(location, entry) yield path - if path.endswith('.py'): + if path.endswith(".py"): dn, fn = os.path.split(path) base = fn[:-3] - path = os.path.join(dn, base + '.pyc') + path = os.path.join(dn, base + ".pyc") yield path - path = os.path.join(dn, base + '.pyo') + path = os.path.join(dn, base + ".pyo") yield path -def compact(paths): - # type: (Iterable[str]) -> Set[str] +def compact(paths: Iterable[str]) -> Set[str]: """Compact a path set to contain the minimal number of paths necessary to contain all paths in the set. If /a/path/ and /a/path/to/a/file.txt are both in the set, leave only the shorter path.""" sep = os.path.sep - short_paths = set() # type: Set[str] + short_paths: Set[str] = set() for path in sorted(paths, key=len): should_skip = any( - path.startswith(shortpath.rstrip("*")) and - path[len(shortpath.rstrip("*").rstrip(sep))] == sep + path.startswith(shortpath.rstrip("*")) + and path[len(shortpath.rstrip("*").rstrip(sep))] == sep for shortpath in short_paths ) if not should_skip: @@ -108,8 +114,7 @@ def compact(paths): return short_paths -def compress_for_rename(paths): - # type: (Iterable[str]) -> Set[str] +def compress_for_rename(paths: Iterable[str]) -> Set[str]: """Returns a set containing the paths that need to be renamed. This set may include directories when the original sequence of paths @@ -118,25 +123,21 @@ def compress_for_rename(paths): case_map = {os.path.normcase(p): p for p in paths} remaining = set(case_map) unchecked = sorted({os.path.split(p)[0] for p in case_map.values()}, key=len) - wildcards = set() # type: Set[str] + wildcards: Set[str] = set() - def norm_join(*a): - # type: (str) -> str + def norm_join(*a: str) -> str: return os.path.normcase(os.path.join(*a)) for root in unchecked: - if any(os.path.normcase(root).startswith(w) - for w in wildcards): + if any(os.path.normcase(root).startswith(w) for w in wildcards): # This directory has already been handled. continue - all_files = set() # type: Set[str] - all_subdirs = set() # type: Set[str] + all_files: Set[str] = set() + all_subdirs: Set[str] = set() for dirname, subdirs, files in os.walk(root): - all_subdirs.update(norm_join(root, dirname, d) - for d in subdirs) - all_files.update(norm_join(root, dirname, f) - for f in files) + all_subdirs.update(norm_join(root, dirname, d) for d in subdirs) + all_files.update(norm_join(root, dirname, f) for f in files) # If all the files we found are in our remaining set of files to # remove, then remove them from the latter set and add a wildcard # for the directory. @@ -147,8 +148,7 @@ def compress_for_rename(paths): return set(map(case_map.__getitem__, remaining)) | wildcards -def compress_for_output_listing(paths): - # type: (Iterable[str]) -> Tuple[Set[str], Set[str]] +def compress_for_output_listing(paths: Iterable[str]) -> Tuple[Set[str], Set[str]]: """Returns a tuple of 2 sets of which paths to display to user The first set contains paths that would be deleted. Files of a package @@ -186,14 +186,14 @@ def compress_for_output_listing(paths): continue file_ = os.path.join(dirpath, fname) - if (os.path.isfile(file_) and - os.path.normcase(file_) not in _normcased_files): + if ( + os.path.isfile(file_) + and os.path.normcase(file_) not in _normcased_files + ): # We are skipping this file. Add it to the set. will_skip.add(file_) - will_remove = files | { - os.path.join(folder, "*") for folder in folders - } + will_remove = files | {os.path.join(folder, "*") for folder in folders} return will_remove, will_skip @@ -201,32 +201,30 @@ def compress_for_output_listing(paths): class StashedUninstallPathSet: """A set of file rename operations to stash files while tentatively uninstalling them.""" - def __init__(self): - # type: () -> None + + def __init__(self) -> None: # Mapping from source file root to [Adjacent]TempDirectory # for files under that directory. - self._save_dirs = {} # type: Dict[str, TempDirectory] + self._save_dirs: Dict[str, TempDirectory] = {} # (old path, new path) tuples for each move that may need # to be undone. - self._moves = [] # type: List[Tuple[str, str]] + self._moves: List[Tuple[str, str]] = [] - def _get_directory_stash(self, path): - # type: (str) -> str + def _get_directory_stash(self, path: str) -> str: """Stashes a directory. Directories are stashed adjacent to their original location if possible, or else moved/copied into the user's temp dir.""" try: - save_dir = AdjacentTempDirectory(path) # type: TempDirectory + save_dir: TempDirectory = AdjacentTempDirectory(path) except OSError: save_dir = TempDirectory(kind="uninstall") self._save_dirs[os.path.normcase(path)] = save_dir return save_dir.path - def _get_file_stash(self, path): - # type: (str) -> str + def _get_file_stash(self, path: str) -> str: """Stashes a file. If no root has been provided, one will be created for the directory @@ -245,7 +243,7 @@ class StashedUninstallPathSet: else: # Did not find any suitable root head = os.path.dirname(path) - save_dir = TempDirectory(kind='uninstall') + save_dir = TempDirectory(kind="uninstall") self._save_dirs[head] = save_dir relpath = os.path.relpath(path, head) @@ -253,8 +251,7 @@ class StashedUninstallPathSet: return os.path.join(save_dir.path, relpath) return save_dir.path - def stash(self, path): - # type: (str) -> str + def stash(self, path: str) -> str: """Stashes the directory or file and returns its new location. Handle symlinks as files to avoid modifying the symlink targets. """ @@ -265,7 +262,7 @@ class StashedUninstallPathSet: new_path = self._get_file_stash(path) self._moves.append((path, new_path)) - if (path_is_dir and os.path.isdir(new_path)): + if path_is_dir and os.path.isdir(new_path): # If we're moving a directory, we need to # remove the destination first or else it will be # moved to inside the existing directory. @@ -275,23 +272,21 @@ class StashedUninstallPathSet: renames(path, new_path) return new_path - def commit(self): - # type: () -> None + def commit(self) -> None: """Commits the uninstall by removing stashed files.""" for _, save_dir in self._save_dirs.items(): save_dir.cleanup() self._moves = [] self._save_dirs = {} - def rollback(self): - # type: () -> None + def rollback(self) -> None: """Undoes the uninstall by moving stashed files back.""" for p in self._moves: logger.info("Moving to %s\n from %s", *p) for new_path, path in self._moves: try: - logger.debug('Replacing %s from %s', new_path, path) + logger.debug("Replacing %s from %s", new_path, path) if os.path.isfile(new_path) or os.path.islink(new_path): os.unlink(new_path) elif os.path.isdir(new_path): @@ -304,100 +299,97 @@ class StashedUninstallPathSet: self.commit() @property - def can_rollback(self): - # type: () -> bool + def can_rollback(self) -> bool: return bool(self._moves) class UninstallPathSet: """A set of file paths to be removed in the uninstallation of a requirement.""" - def __init__(self, dist): - # type: (Distribution) -> None - self.paths = set() # type: Set[str] - self._refuse = set() # type: Set[str] - self.pth = {} # type: Dict[str, UninstallPthEntries] - self.dist = dist + + def __init__(self, dist: BaseDistribution) -> None: + self._paths: Set[str] = set() + self._refuse: Set[str] = set() + self._pth: Dict[str, UninstallPthEntries] = {} + self._dist = dist self._moved_paths = StashedUninstallPathSet() + # Create local cache of normalize_path results. Creating an UninstallPathSet + # can result in hundreds/thousands of redundant calls to normalize_path with + # the same args, which hurts performance. + self._normalize_path_cached = functools.lru_cache()(normalize_path) - def _permitted(self, path): - # type: (str) -> bool + def _permitted(self, path: str) -> bool: """ Return True if the given path is one we are permitted to remove/modify, False otherwise. """ - return is_local(path) + # aka is_local, but caching normalized sys.prefix + if not running_under_virtualenv(): + return True + return path.startswith(self._normalize_path_cached(sys.prefix)) - def add(self, path): - # type: (str) -> None + def add(self, path: str) -> None: head, tail = os.path.split(path) # we normalize the head to resolve parent directory symlinks, but not # the tail, since we only want to uninstall symlinks, not their targets - path = os.path.join(normalize_path(head), os.path.normcase(tail)) + path = os.path.join(self._normalize_path_cached(head), os.path.normcase(tail)) if not os.path.exists(path): return if self._permitted(path): - self.paths.add(path) + self._paths.add(path) else: self._refuse.add(path) # __pycache__ files can show up after 'installed-files.txt' is created, # due to imports - if os.path.splitext(path)[1] == '.py': + if os.path.splitext(path)[1] == ".py": self.add(cache_from_source(path)) - def add_pth(self, pth_file, entry): - # type: (str, str) -> None - pth_file = normalize_path(pth_file) + def add_pth(self, pth_file: str, entry: str) -> None: + pth_file = self._normalize_path_cached(pth_file) if self._permitted(pth_file): - if pth_file not in self.pth: - self.pth[pth_file] = UninstallPthEntries(pth_file) - self.pth[pth_file].add(entry) + if pth_file not in self._pth: + self._pth[pth_file] = UninstallPthEntries(pth_file) + self._pth[pth_file].add(entry) else: self._refuse.add(pth_file) - def remove(self, auto_confirm=False, verbose=False): - # type: (bool, bool) -> None - """Remove paths in ``self.paths`` with confirmation (unless + def remove(self, auto_confirm: bool = False, verbose: bool = False) -> None: + """Remove paths in ``self._paths`` with confirmation (unless ``auto_confirm`` is True).""" - if not self.paths: + if not self._paths: logger.info( "Can't uninstall '%s'. No files were found to uninstall.", - self.dist.project_name, + self._dist.raw_name, ) return - dist_name_version = ( - self.dist.project_name + "-" + self.dist.version - ) - logger.info('Uninstalling %s:', dist_name_version) + dist_name_version = f"{self._dist.raw_name}-{self._dist.version}" + logger.info("Uninstalling %s:", dist_name_version) with indent_log(): if auto_confirm or self._allowed_to_proceed(verbose): moved = self._moved_paths - for_rename = compress_for_rename(self.paths) + for_rename = compress_for_rename(self._paths) for path in sorted(compact(for_rename)): moved.stash(path) - logger.debug('Removing file or directory %s', path) + logger.verbose("Removing file or directory %s", path) - for pth in self.pth.values(): + for pth in self._pth.values(): pth.remove() - logger.info('Successfully uninstalled %s', dist_name_version) + logger.info("Successfully uninstalled %s", dist_name_version) - def _allowed_to_proceed(self, verbose): - # type: (bool) -> bool - """Display which files would be deleted and prompt for confirmation - """ + def _allowed_to_proceed(self, verbose: bool) -> bool: + """Display which files would be deleted and prompt for confirmation""" - def _display(msg, paths): - # type: (str, Iterable[str]) -> None + def _display(msg: str, paths: Iterable[str]) -> None: if not paths: return @@ -407,182 +399,206 @@ class UninstallPathSet: logger.info(path) if not verbose: - will_remove, will_skip = compress_for_output_listing(self.paths) + will_remove, will_skip = compress_for_output_listing(self._paths) else: # In verbose mode, display all the files that are going to be # deleted. - will_remove = set(self.paths) + will_remove = set(self._paths) will_skip = set() - _display('Would remove:', will_remove) - _display('Would not remove (might be manually added):', will_skip) - _display('Would not remove (outside of prefix):', self._refuse) + _display("Would remove:", will_remove) + _display("Would not remove (might be manually added):", will_skip) + _display("Would not remove (outside of prefix):", self._refuse) if verbose: - _display('Will actually move:', compress_for_rename(self.paths)) + _display("Will actually move:", compress_for_rename(self._paths)) - return ask('Proceed (y/n)? ', ('y', 'n')) == 'y' + return ask("Proceed (Y/n)? ", ("y", "n", "")) != "n" - def rollback(self): - # type: () -> None + def rollback(self) -> None: """Rollback the changes previously made by remove().""" if not self._moved_paths.can_rollback: logger.error( "Can't roll back %s; was not uninstalled", - self.dist.project_name, + self._dist.raw_name, ) return - logger.info('Rolling back uninstall of %s', self.dist.project_name) + logger.info("Rolling back uninstall of %s", self._dist.raw_name) self._moved_paths.rollback() - for pth in self.pth.values(): + for pth in self._pth.values(): pth.rollback() - def commit(self): - # type: () -> None + def commit(self) -> None: """Remove temporary save dir: rollback will no longer be possible.""" self._moved_paths.commit() @classmethod - def from_dist(cls, dist): - # type: (Distribution) -> UninstallPathSet - dist_path = normalize_path(dist.location) - if not dist_is_local(dist): + def from_dist(cls, dist: BaseDistribution) -> "UninstallPathSet": + dist_location = dist.location + info_location = dist.info_location + if dist_location is None: + logger.info( + "Not uninstalling %s since it is not installed", + dist.canonical_name, + ) + return cls(dist) + + normalized_dist_location = normalize_path(dist_location) + if not dist.local: logger.info( "Not uninstalling %s at %s, outside environment %s", - dist.key, - dist_path, + dist.canonical_name, + normalized_dist_location, sys.prefix, ) return cls(dist) - if dist_path in {p for p in {sysconfig.get_path("stdlib"), - sysconfig.get_path("platstdlib")} - if p}: + if normalized_dist_location in { + p + for p in {sysconfig.get_path("stdlib"), sysconfig.get_path("platstdlib")} + if p + }: logger.info( "Not uninstalling %s at %s, as it is in the standard library.", - dist.key, - dist_path, + dist.canonical_name, + normalized_dist_location, ) return cls(dist) paths_to_remove = cls(dist) - develop_egg_link = egg_link_path(dist) - develop_egg_link_egg_info = '{}.egg-info'.format( - pkg_resources.to_filename(dist.project_name)) - egg_info_exists = dist.egg_info and os.path.exists(dist.egg_info) - # Special case for distutils installed package - distutils_egg_info = getattr(dist._provider, 'path', None) + develop_egg_link = egg_link_path_from_location(dist.raw_name) + + # Distribution is installed with metadata in a "flat" .egg-info + # directory. This means it is not a modern .dist-info installation, an + # egg, or legacy editable. + setuptools_flat_installation = ( + dist.installed_with_setuptools_egg_info + and info_location is not None + and os.path.exists(info_location) + # If dist is editable and the location points to a ``.egg-info``, + # we are in fact in the legacy editable case. + and not info_location.endswith(f"{dist.setuptools_filename}.egg-info") + ) # Uninstall cases order do matter as in the case of 2 installs of the # same package, pip needs to uninstall the currently detected version - if (egg_info_exists and dist.egg_info.endswith('.egg-info') and - not dist.egg_info.endswith(develop_egg_link_egg_info)): - # if dist.egg_info.endswith(develop_egg_link_egg_info), we - # are in fact in the develop_egg_link case - paths_to_remove.add(dist.egg_info) - if dist.has_metadata('installed-files.txt'): - for installed_file in dist.get_metadata( - 'installed-files.txt').splitlines(): - path = os.path.normpath( - os.path.join(dist.egg_info, installed_file) - ) - paths_to_remove.add(path) + if setuptools_flat_installation: + if info_location is not None: + paths_to_remove.add(info_location) + installed_files = dist.iter_declared_entries() + if installed_files is not None: + for installed_file in installed_files: + paths_to_remove.add(os.path.join(dist_location, installed_file)) # FIXME: need a test for this elif block # occurs with --single-version-externally-managed/--record outside # of pip - elif dist.has_metadata('top_level.txt'): - if dist.has_metadata('namespace_packages.txt'): - namespaces = dist.get_metadata('namespace_packages.txt') - else: + elif dist.is_file("top_level.txt"): + try: + namespace_packages = dist.read_text("namespace_packages.txt") + except FileNotFoundError: namespaces = [] + else: + namespaces = namespace_packages.splitlines(keepends=False) for top_level_pkg in [ - p for p - in dist.get_metadata('top_level.txt').splitlines() - if p and p not in namespaces]: - path = os.path.join(dist.location, top_level_pkg) + p + for p in dist.read_text("top_level.txt").splitlines() + if p and p not in namespaces + ]: + path = os.path.join(dist_location, top_level_pkg) paths_to_remove.add(path) - paths_to_remove.add(path + '.py') - paths_to_remove.add(path + '.pyc') - paths_to_remove.add(path + '.pyo') + paths_to_remove.add(f"{path}.py") + paths_to_remove.add(f"{path}.pyc") + paths_to_remove.add(f"{path}.pyo") - elif distutils_egg_info: + elif dist.installed_by_distutils: raise UninstallationError( "Cannot uninstall {!r}. It is a distutils installed project " "and thus we cannot accurately determine which files belong " "to it which would lead to only a partial uninstall.".format( - dist.project_name, + dist.raw_name, ) ) - elif dist.location.endswith('.egg'): + elif dist.installed_as_egg: # package installed by easy_install # We cannot match on dist.egg_name because it can slightly vary # i.e. setuptools-0.6c11-py2.6.egg vs setuptools-0.6rc11-py2.6.egg - paths_to_remove.add(dist.location) - easy_install_egg = os.path.split(dist.location)[1] - easy_install_pth = os.path.join(os.path.dirname(dist.location), - 'easy-install.pth') - paths_to_remove.add_pth(easy_install_pth, './' + easy_install_egg) + paths_to_remove.add(dist_location) + easy_install_egg = os.path.split(dist_location)[1] + easy_install_pth = os.path.join( + os.path.dirname(dist_location), + "easy-install.pth", + ) + paths_to_remove.add_pth(easy_install_pth, "./" + easy_install_egg) - elif egg_info_exists and dist.egg_info.endswith('.dist-info'): + elif dist.installed_with_dist_info: for path in uninstallation_paths(dist): paths_to_remove.add(path) elif develop_egg_link: - # develop egg + # PEP 660 modern editable is handled in the ``.dist-info`` case + # above, so this only covers the setuptools-style editable. with open(develop_egg_link) as fh: link_pointer = os.path.normcase(fh.readline().strip()) - assert (link_pointer == dist.location), ( - 'Egg-link {} does not match installed location of {} ' - '(at {})'.format( - link_pointer, dist.project_name, dist.location) + normalized_link_pointer = paths_to_remove._normalize_path_cached( + link_pointer + ) + assert os.path.samefile( + normalized_link_pointer, normalized_dist_location + ), ( + f"Egg-link {develop_egg_link} (to {link_pointer}) does not match " + f"installed location of {dist.raw_name} (at {dist_location})" ) paths_to_remove.add(develop_egg_link) - easy_install_pth = os.path.join(os.path.dirname(develop_egg_link), - 'easy-install.pth') - paths_to_remove.add_pth(easy_install_pth, dist.location) + easy_install_pth = os.path.join( + os.path.dirname(develop_egg_link), "easy-install.pth" + ) + paths_to_remove.add_pth(easy_install_pth, dist_location) else: logger.debug( - 'Not sure how to uninstall: %s - Check: %s', - dist, dist.location, + "Not sure how to uninstall: %s - Check: %s", + dist, + dist_location, ) + if dist.in_usersite: + bin_dir = get_bin_user() + else: + bin_dir = get_bin_prefix() + # find distutils scripts= scripts - if dist.has_metadata('scripts') and dist.metadata_isdir('scripts'): - for script in dist.metadata_listdir('scripts'): - if dist_in_usersite(dist): - bin_dir = get_bin_user() - else: - bin_dir = get_bin_prefix() + try: + for script in dist.iter_distutils_script_names(): paths_to_remove.add(os.path.join(bin_dir, script)) if WINDOWS: - paths_to_remove.add(os.path.join(bin_dir, script) + '.bat') - - # find console_scripts - _scripts_to_remove = [] - console_scripts = dist.get_entry_map(group='console_scripts') - for name in console_scripts.keys(): - _scripts_to_remove.extend(_script_names(dist, name, False)) - # find gui_scripts - gui_scripts = dist.get_entry_map(group='gui_scripts') - for name in gui_scripts.keys(): - _scripts_to_remove.extend(_script_names(dist, name, True)) - - for s in _scripts_to_remove: + paths_to_remove.add(os.path.join(bin_dir, f"{script}.bat")) + except (FileNotFoundError, NotADirectoryError): + pass + + # find console_scripts and gui_scripts + def iter_scripts_to_remove( + dist: BaseDistribution, + bin_dir: str, + ) -> Generator[str, None, None]: + for entry_point in dist.iter_entry_points(): + if entry_point.group == "console_scripts": + yield from _script_names(bin_dir, entry_point.name, False) + elif entry_point.group == "gui_scripts": + yield from _script_names(bin_dir, entry_point.name, True) + + for s in iter_scripts_to_remove(dist, bin_dir): paths_to_remove.add(s) return paths_to_remove class UninstallPthEntries: - def __init__(self, pth_file): - # type: (str) -> None + def __init__(self, pth_file: str) -> None: self.file = pth_file - self.entries = set() # type: Set[str] - self._saved_lines = None # type: Optional[List[bytes]] + self.entries: Set[str] = set() + self._saved_lines: Optional[List[bytes]] = None - def add(self, entry): - # type: (str) -> None + def add(self, entry: str) -> None: entry = os.path.normcase(entry) # On Windows, os.path.normcase converts the entry to use # backslashes. This is correct for entries that describe absolute @@ -594,47 +610,41 @@ class UninstallPthEntries: # have more than "\\sever\share". Valid examples: "\\server\share\" or # "\\server\share\folder". if WINDOWS and not os.path.splitdrive(entry)[0]: - entry = entry.replace('\\', '/') + entry = entry.replace("\\", "/") self.entries.add(entry) - def remove(self): - # type: () -> None - logger.debug('Removing pth entries from %s:', self.file) + def remove(self) -> None: + logger.verbose("Removing pth entries from %s:", self.file) # If the file doesn't exist, log a warning and return if not os.path.isfile(self.file): - logger.warning( - "Cannot remove entries from nonexistent file %s", self.file - ) + logger.warning("Cannot remove entries from nonexistent file %s", self.file) return - with open(self.file, 'rb') as fh: + with open(self.file, "rb") as fh: # windows uses '\r\n' with py3k, but uses '\n' with py2.x lines = fh.readlines() self._saved_lines = lines - if any(b'\r\n' in line for line in lines): - endline = '\r\n' + if any(b"\r\n" in line for line in lines): + endline = "\r\n" else: - endline = '\n' + endline = "\n" # handle missing trailing newline if lines and not lines[-1].endswith(endline.encode("utf-8")): lines[-1] = lines[-1] + endline.encode("utf-8") for entry in self.entries: try: - logger.debug('Removing entry: %s', entry) + logger.verbose("Removing entry: %s", entry) lines.remove((entry + endline).encode("utf-8")) except ValueError: pass - with open(self.file, 'wb') as fh: + with open(self.file, "wb") as fh: fh.writelines(lines) - def rollback(self): - # type: () -> bool + def rollback(self) -> bool: if self._saved_lines is None: - logger.error( - 'Cannot roll back changes to %s, none were made', self.file - ) + logger.error("Cannot roll back changes to %s, none were made", self.file) return False - logger.debug('Rolling %s back to previous state', self.file) - with open(self.file, 'wb') as fh: + logger.debug("Rolling %s back to previous state", self.file) + with open(self.file, "wb") as fh: fh.writelines(self._saved_lines) return True diff --git a/env/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 67cb3e32a8e33f9b46accd2807416b3b289d311a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 224 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<YIU}X z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP u%1g}AFG?-W&nYd*%+J%0kI&4@EQycTE2zB1VUwGmQks)$2XfwLkT(G63_REX diff --git a/env/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-39.pyc deleted file mode 100644 index 2c19d10d12f8efa3a2b94e9a2a325a3488bcb2c6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 967 zcmYe~<>g{vU|^UdaWK`GiGkrUh=Yuo85kHG7#J9ey%-o6QW#Pga~N_NqZo6UqL>&# ze5M@cT$U&nFq=7tHJ2@ljgcXhF_k@)C7mgiC5=gvA&SGDA%!J{wS^&twV5f3Gleaf zL6iL@$QDheTO7`bIXQ_*IjOf;d@_qmG#PIRdFB<DB<AD<r52WE7NzE<=7B`{khsCA zCCMP|$e0P{P#FdWhE#?q#uSDqrWD2$rWS@M<`m`>mKKI6mK4@t22HkGJWh$lsX?j5 z`8j2&Madv9!b}3O85tNDoIzd&g-i)UGeZ+&3PUi%N=CnxjJJgS@=H8(3v$5DN=<Ps zD#|a?WWL2xoSKt%i?b*{za+jWwXpb>SaL>ca&~-iX+c4LQAuh_e0fG{YEJP=h9X`D z28Lga&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW z!LGip!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g z`tg~0C8<Sui8=a3AkUVTWaj7TCnXlA>J?PpVh4+rrGk7}3<^C4rYaHSfYF00NCrzn zLkPsi5kN)k3=9lK91IK$noLC?Q$bb~#uulSfc*?1_!t-%Zi%I*mc(a5VmT4ysQCP% zl++@S9Ly!kC@#US-cOVD7Ds%1USe))eEco0`1suXl+qj!n<qZLurx6TB2&Z<a+e^8 z0EIoo9bgv7!Xh>X1_n-0bh9upFmNz(uz*GUG`ViEl~fjF=A{>b{9FV|8BwwYnFV_A zP}M6+Ed*hhSBgL;L`h;-0}2LKkms3;ONwquVW#nbqWrSVl++@y^+=9{yYv=^4a9?X Spa>`i1+)MY4<iqg05br5FZxRW diff --git a/env/Lib/site-packages/pip/_internal/resolution/base.py b/env/Lib/site-packages/pip/_internal/resolution/base.py index 1be0cb27..42dade18 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/base.py +++ b/env/Lib/site-packages/pip/_internal/resolution/base.py @@ -1,16 +1,20 @@ -from typing import Callable, List +from typing import Callable, List, Optional from pip._internal.req.req_install import InstallRequirement from pip._internal.req.req_set import RequirementSet -InstallRequirementProvider = Callable[[str, InstallRequirement], InstallRequirement] +InstallRequirementProvider = Callable[ + [str, Optional[InstallRequirement]], InstallRequirement +] class BaseResolver: - def resolve(self, root_reqs, check_supported_wheels): - # type: (List[InstallRequirement], bool) -> RequirementSet + def resolve( + self, root_reqs: List[InstallRequirement], check_supported_wheels: bool + ) -> RequirementSet: raise NotImplementedError() - def get_installation_order(self, req_set): - # type: (RequirementSet) -> List[InstallRequirement] + def get_installation_order( + self, req_set: RequirementSet + ) -> List[InstallRequirement]: raise NotImplementedError() diff --git a/env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index ea3a4b2153a625cdb95fd39d873f5ed338e4668a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 231 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>T$M; z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP z%1g}AFG?-W&nYd*%+J%$Nli~ouGEi@&&<m#iI3MSsJz8tlbfGXnv-e=a^+``Zve3Z BKZ5`O diff --git a/env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-39.pyc deleted file mode 100644 index 5af41912d9c3ae6880175189d955c46494e0023b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11504 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 diff --git a/env/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py b/env/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py index 17de7f09..b17b7e45 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py +++ b/env/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py @@ -20,7 +20,7 @@ from itertools import chain from typing import DefaultDict, Iterable, List, Optional, Set, Tuple from pip._vendor.packaging import specifiers -from pip._vendor.pkg_resources import Distribution +from pip._vendor.packaging.requirements import Requirement from pip._internal.cache import WheelCache from pip._internal.exceptions import ( @@ -28,10 +28,14 @@ from pip._internal.exceptions import ( DistributionNotFound, HashError, HashErrors, + InstallationError, + NoneMetadataError, UnsupportedPythonVersion, ) from pip._internal.index.package_finder import PackageFinder +from pip._internal.metadata import BaseDistribution from pip._internal.models.link import Link +from pip._internal.models.wheel import Wheel from pip._internal.operations.prepare import RequirementPreparer from pip._internal.req.req_install import ( InstallRequirement, @@ -39,10 +43,12 @@ from pip._internal.req.req_install import ( ) from pip._internal.req.req_set import RequirementSet from pip._internal.resolution.base import BaseResolver, InstallRequirementProvider +from pip._internal.utils import compatibility_tags from pip._internal.utils.compatibility_tags import get_supported +from pip._internal.utils.direct_url_helpers import direct_url_from_link from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import dist_in_usersite, normalize_version_info -from pip._internal.utils.packaging import check_requires_python, get_requires_python +from pip._internal.utils.misc import normalize_version_info +from pip._internal.utils.packaging import check_requires_python logger = logging.getLogger(__name__) @@ -50,11 +56,10 @@ DiscoveredDependencies = DefaultDict[str, List[InstallRequirement]] def _check_dist_requires_python( - dist, # type: Distribution - version_info, # type: Tuple[int, int, int] - ignore_requires_python=False, # type: bool -): - # type: (...) -> None + dist: BaseDistribution, + version_info: Tuple[int, int, int], + ignore_requires_python: bool = False, +) -> None: """ Check whether the given Python version is compatible with a distribution's "Requires-Python" value. @@ -67,14 +72,21 @@ def _check_dist_requires_python( :raises UnsupportedPythonVersion: When the given Python version isn't compatible. """ - requires_python = get_requires_python(dist) + # This idiosyncratically converts the SpecifierSet to str and let + # check_requires_python then parse it again into SpecifierSet. But this + # is the legacy resolver so I'm just not going to bother refactoring. + try: + requires_python = str(dist.requires_python) + except FileNotFoundError as e: + raise NoneMetadataError(dist, str(e)) try: is_compatible = check_requires_python( - requires_python, version_info=version_info + requires_python, + version_info=version_info, ) except specifiers.InvalidSpecifier as exc: logger.warning( - "Package %r has an invalid Requires-Python: %s", dist.project_name, exc + "Package %r has an invalid Requires-Python: %s", dist.raw_name, exc ) return @@ -84,8 +96,8 @@ def _check_dist_requires_python( version = ".".join(map(str, version_info)) if ignore_requires_python: logger.debug( - "Ignoring failed Requires-Python check for package %r: " "%s not in %r", - dist.project_name, + "Ignoring failed Requires-Python check for package %r: %s not in %r", + dist.raw_name, version, requires_python, ) @@ -93,7 +105,7 @@ def _check_dist_requires_python( raise UnsupportedPythonVersion( "Package {!r} requires a different Python: {} not in {!r}".format( - dist.project_name, version, requires_python + dist.raw_name, version, requires_python ) ) @@ -107,19 +119,18 @@ class Resolver(BaseResolver): def __init__( self, - preparer, # type: RequirementPreparer - finder, # type: PackageFinder - wheel_cache, # type: Optional[WheelCache] - make_install_req, # type: InstallRequirementProvider - use_user_site, # type: bool - ignore_dependencies, # type: bool - ignore_installed, # type: bool - ignore_requires_python, # type: bool - force_reinstall, # type: bool - upgrade_strategy, # type: str - py_version_info=None, # type: Optional[Tuple[int, ...]] - ): - # type: (...) -> None + preparer: RequirementPreparer, + finder: PackageFinder, + wheel_cache: Optional[WheelCache], + make_install_req: InstallRequirementProvider, + use_user_site: bool, + ignore_dependencies: bool, + ignore_installed: bool, + ignore_requires_python: bool, + force_reinstall: bool, + upgrade_strategy: str, + py_version_info: Optional[Tuple[int, ...]] = None, + ) -> None: super().__init__() assert upgrade_strategy in self._allowed_strategies @@ -142,12 +153,11 @@ class Resolver(BaseResolver): self.use_user_site = use_user_site self._make_install_req = make_install_req - self._discovered_dependencies = defaultdict( - list - ) # type: DiscoveredDependencies + self._discovered_dependencies: DiscoveredDependencies = defaultdict(list) - def resolve(self, root_reqs, check_supported_wheels): - # type: (List[InstallRequirement], bool) -> RequirementSet + def resolve( + self, root_reqs: List[InstallRequirement], check_supported_wheels: bool + ) -> RequirementSet: """Resolve what operations need to be done As a side-effect of this method, the packages (and their dependencies) @@ -162,13 +172,13 @@ class Resolver(BaseResolver): for req in root_reqs: if req.constraint: check_invalid_constraint_type(req) - requirement_set.add_requirement(req) + self._add_requirement_to_set(requirement_set, req) # Actually prepare the files, and collect any exceptions. Most hash # exceptions cannot be checked ahead of time, because # _populate_link() needs to be called before we can make decisions # based on link type. - discovered_reqs = [] # type: List[InstallRequirement] + discovered_reqs: List[InstallRequirement] = [] hash_errors = HashErrors() for req in chain(requirement_set.all_requirements, discovered_reqs): try: @@ -182,8 +192,125 @@ class Resolver(BaseResolver): return requirement_set - def _is_upgrade_allowed(self, req): - # type: (InstallRequirement) -> bool + def _add_requirement_to_set( + self, + requirement_set: RequirementSet, + install_req: InstallRequirement, + parent_req_name: Optional[str] = None, + extras_requested: Optional[Iterable[str]] = None, + ) -> Tuple[List[InstallRequirement], Optional[InstallRequirement]]: + """Add install_req as a requirement to install. + + :param parent_req_name: The name of the requirement that needed this + added. The name is used because when multiple unnamed requirements + resolve to the same name, we could otherwise end up with dependency + links that point outside the Requirements set. parent_req must + already be added. Note that None implies that this is a user + supplied requirement, vs an inferred one. + :param extras_requested: an iterable of extras used to evaluate the + environment markers. + :return: Additional requirements to scan. That is either [] if + the requirement is not applicable, or [install_req] if the + requirement is applicable and has just been added. + """ + # If the markers do not match, ignore this requirement. + if not install_req.match_markers(extras_requested): + logger.info( + "Ignoring %s: markers '%s' don't match your environment", + install_req.name, + install_req.markers, + ) + return [], None + + # If the wheel is not supported, raise an error. + # Should check this after filtering out based on environment markers to + # allow specifying different wheels based on the environment/OS, in a + # single requirements file. + if install_req.link and install_req.link.is_wheel: + wheel = Wheel(install_req.link.filename) + tags = compatibility_tags.get_supported() + if requirement_set.check_supported_wheels and not wheel.supported(tags): + raise InstallationError( + "{} is not a supported wheel on this platform.".format( + wheel.filename + ) + ) + + # This next bit is really a sanity check. + assert ( + not install_req.user_supplied or parent_req_name is None + ), "a user supplied req shouldn't have a parent" + + # Unnamed requirements are scanned again and the requirement won't be + # added as a dependency until after scanning. + if not install_req.name: + requirement_set.add_unnamed_requirement(install_req) + return [install_req], None + + try: + existing_req: Optional[ + InstallRequirement + ] = requirement_set.get_requirement(install_req.name) + except KeyError: + existing_req = None + + has_conflicting_requirement = ( + parent_req_name is None + and existing_req + and not existing_req.constraint + and existing_req.extras == install_req.extras + and existing_req.req + and install_req.req + and existing_req.req.specifier != install_req.req.specifier + ) + if has_conflicting_requirement: + raise InstallationError( + "Double requirement given: {} (already in {}, name={!r})".format( + install_req, existing_req, install_req.name + ) + ) + + # When no existing requirement exists, add the requirement as a + # dependency and it will be scanned again after. + if not existing_req: + requirement_set.add_named_requirement(install_req) + # We'd want to rescan this requirement later + return [install_req], install_req + + # Assume there's no need to scan, and that we've already + # encountered this for scanning. + if install_req.constraint or not existing_req.constraint: + return [], existing_req + + does_not_satisfy_constraint = install_req.link and not ( + existing_req.link and install_req.link.path == existing_req.link.path + ) + if does_not_satisfy_constraint: + raise InstallationError( + "Could not satisfy constraints for '{}': " + "installation from path or url cannot be " + "constrained to a version".format(install_req.name) + ) + # If we're now installing a constraint, mark the existing + # object for real installation. + existing_req.constraint = False + # If we're now installing a user supplied requirement, + # mark the existing object as such. + if install_req.user_supplied: + existing_req.user_supplied = True + existing_req.extras = tuple( + sorted(set(existing_req.extras) | set(install_req.extras)) + ) + logger.debug( + "Setting %s extras to: %s", + existing_req, + existing_req.extras, + ) + # Return the existing requirement for addition to the parent and + # scanning again. + return [existing_req], existing_req + + def _is_upgrade_allowed(self, req: InstallRequirement) -> bool: if self.upgrade_strategy == "to-satisfy-only": return False elif self.upgrade_strategy == "eager": @@ -192,19 +319,19 @@ class Resolver(BaseResolver): assert self.upgrade_strategy == "only-if-needed" return req.user_supplied or req.constraint - def _set_req_to_reinstall(self, req): - # type: (InstallRequirement) -> None + def _set_req_to_reinstall(self, req: InstallRequirement) -> None: """ Set a requirement to be installed. """ # Don't uninstall the conflict if doing a user install and the # conflict is not a user install. - if not self.use_user_site or dist_in_usersite(req.satisfied_by): + if not self.use_user_site or req.satisfied_by.in_usersite: req.should_reinstall = True req.satisfied_by = None - def _check_skip_installed(self, req_to_install): - # type: (InstallRequirement) -> Optional[str] + def _check_skip_installed( + self, req_to_install: InstallRequirement + ) -> Optional[str]: """Check if req_to_install should be skipped. This will check if the req is installed, and whether we should upgrade @@ -256,8 +383,7 @@ class Resolver(BaseResolver): self._set_req_to_reinstall(req_to_install) return None - def _find_requirement_link(self, req): - # type: (InstallRequirement) -> Optional[Link] + def _find_requirement_link(self, req: InstallRequirement) -> Optional[Link]: upgrade = self._is_upgrade_allowed(req) best_candidate = self.finder.find_requirement(req, upgrade) if not best_candidate: @@ -279,8 +405,7 @@ class Resolver(BaseResolver): return link - def _populate_link(self, req): - # type: (InstallRequirement) -> None + def _populate_link(self, req: InstallRequirement) -> None: """Ensure that if a link can be found for this, that it is found. Note that req.link may still be None - if the requirement is already @@ -306,11 +431,18 @@ class Resolver(BaseResolver): if cache_entry is not None: logger.debug("Using cached wheel link: %s", cache_entry.link) if req.link is req.original_link and cache_entry.persistent: - req.original_link_is_in_wheel_cache = True + req.cached_wheel_source_link = req.link + if cache_entry.origin is not None: + req.download_info = cache_entry.origin + else: + # Legacy cache entry that does not have origin.json. + # download_info may miss the archive_info.hashes field. + req.download_info = direct_url_from_link( + req.link, link_is_in_wheel_cache=cache_entry.persistent + ) req.link = cache_entry.link - def _get_dist_for(self, req): - # type: (InstallRequirement) -> Distribution + def _get_dist_for(self, req: InstallRequirement) -> BaseDistribution: """Takes a InstallRequirement and returns a single AbstractDist \ representing a prepared variant of the same. """ @@ -351,17 +483,16 @@ class Resolver(BaseResolver): self._set_req_to_reinstall(req) else: logger.info( - "Requirement already satisfied (use --upgrade to upgrade):" " %s", + "Requirement already satisfied (use --upgrade to upgrade): %s", req, ) return dist def _resolve_one( self, - requirement_set, # type: RequirementSet - req_to_install, # type: InstallRequirement - ): - # type: (...) -> List[InstallRequirement] + requirement_set: RequirementSet, + req_to_install: InstallRequirement, + ) -> List[InstallRequirement]: """Prepare a single requirements file. :return: A list of additional InstallRequirements to also install. @@ -384,16 +515,16 @@ class Resolver(BaseResolver): ignore_requires_python=self.ignore_requires_python, ) - more_reqs = [] # type: List[InstallRequirement] + more_reqs: List[InstallRequirement] = [] - def add_req(subreq, extras_requested): - # type: (Distribution, Iterable[str]) -> None - sub_install_req = self._make_install_req( - str(subreq), - req_to_install, - ) + def add_req(subreq: Requirement, extras_requested: Iterable[str]) -> None: + # This idiosyncratically converts the Requirement to str and let + # make_install_req then parse it again into Requirement. But this is + # the legacy resolver so I'm just not going to bother refactoring. + sub_install_req = self._make_install_req(str(subreq), req_to_install) parent_req_name = req_to_install.name - to_scan_again, add_to_parent = requirement_set.add_requirement( + to_scan_again, add_to_parent = self._add_requirement_to_set( + requirement_set, sub_install_req, parent_req_name=parent_req_name, extras_requested=extras_requested, @@ -410,7 +541,9 @@ class Resolver(BaseResolver): # 'unnamed' requirements can only come from being directly # provided by the user. assert req_to_install.user_supplied - requirement_set.add_requirement(req_to_install, parent_req_name=None) + self._add_requirement_to_set( + requirement_set, req_to_install, parent_req_name=None + ) if not self.ignore_dependencies: if req_to_install.extras: @@ -419,21 +552,27 @@ class Resolver(BaseResolver): ",".join(req_to_install.extras), ) missing_requested = sorted( - set(req_to_install.extras) - set(dist.extras) + set(req_to_install.extras) - set(dist.iter_provided_extras()) ) for missing in missing_requested: - logger.warning("%s does not provide the extra '%s'", dist, missing) + logger.warning( + "%s %s does not provide the extra '%s'", + dist.raw_name, + dist.version, + missing, + ) available_requested = sorted( - set(dist.extras) & set(req_to_install.extras) + set(dist.iter_provided_extras()) & set(req_to_install.extras) ) - for subreq in dist.requires(available_requested): + for subreq in dist.iter_dependencies(available_requested): add_req(subreq, extras_requested=available_requested) return more_reqs - def get_installation_order(self, req_set): - # type: (RequirementSet) -> List[InstallRequirement] + def get_installation_order( + self, req_set: RequirementSet + ) -> List[InstallRequirement]: """Create the installation order. The installation order is topological - requirements are installed @@ -444,10 +583,9 @@ class Resolver(BaseResolver): # installs the user specified things in the order given, except when # dependencies must come earlier to achieve topological order. order = [] - ordered_reqs = set() # type: Set[InstallRequirement] + ordered_reqs: Set[InstallRequirement] = set() - def schedule(req): - # type: (InstallRequirement) -> None + def schedule(req: InstallRequirement) -> None: if req.satisfied_by or req in ordered_reqs: return if req.constraint: diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 234cf5ef336c279d8578e747367caa788f389a39..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 235 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<n&4~| z6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux&p>F46_=Njzk7!&O3>lz&5 z8l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0ns#}nloSm4SS{zf5S)d=EnOBlp zl$V&JUzA#$pHo_rnV$z?mZj!oCh5n=XXa&=#K-FuRNmsS$<0qG%}KQbx%4y0M*zqy BK}i4r diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-39.pyc deleted file mode 100644 index 2195c90242273d4b1b46da84ea848ec6fda777fd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6337 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 z%0A$78Ks2@>T|+_R}<38zr|agS&|VCZ69KcD+p$mq!z`eq!y&+rKIL1XQmd<hP#HT zN*c-Y=<28y1h>RN)h;y7VeSNtGtNhHh$6xvI8>A19K7{3xbj?#WVIB+YRrn67p-D0 z@&l!AM4b%EIYpp8dJ(931&-~aP>_-^5P`Fv2Gu-;AUA*pI}r6Ww37qs=zuY(-uBa! zxy4peS&*5RUIa=NMW8CX2-GSo0u2-tfhyQ2g@Viiz4)@!yp;SRJ;<nKW?s4;e4wnj z2s9LROB%bf(vr-a;v&$<26%imN*22^Xi-oE8qF`_2DMTo!3tsHqI$XcDXBTddZ2!B z5h&e)TM1Cp;EIY;3-yXp3t@!-WY|Fp)gZ8g^dMt<Md0x>et0DLfSY)?1mFVDQEu>X zCb(Y+Zs~wq8{irq(r5)YO~3@Gp>&JG2GV)81GRIDr5G3(WSDpu1sDaG1Q>Z3d6+~P Od6+pk_zd`zIoJVliNCb~ diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-39.pyc deleted file mode 100644 index 48b07213ca5ccb95f524a0b1d971c0c3ec33c051..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17917 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 S0`&}%0;U2|0{#N^3@iYh%kN77 diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-39.pyc deleted file mode 100644 index d0361bc53a2b1a578c6e225fc0e00a75e89f34dd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16384 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 diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-39.pyc deleted file mode 100644 index b968b76f13c1684f7cd6acab67d83b19b01b61b8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4683 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 aLHb#^I2dJ^co=z@c$g%ZIfOVwIphJ!l@Cw= diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-39.pyc deleted file mode 100644 index f8278ed7886972a330510fe19f0b8cce6b23f479..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6603 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 Qg^`Dmhlz(tfQdyE0AA}41ONa4 diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-39.pyc deleted file mode 100644 index 882b0e3cb0a8b38c113681c0fae98ce9ee16b304..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3167 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 diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-39.pyc deleted file mode 100644 index 92f11c46100fe5551b474e91a74c25ef37be1b94..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7072 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 Ohe?82KvTd@zyJUOM)q+4 diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-39.pyc deleted file mode 100644 index 86f04fab60a8c8e2d9b97ea9c22243cf2ba26aad..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8079 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 ZcsxuZj66(ij66(y%v{U@^$flodH|#_dUXH* diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py index 26821a1f..b206692a 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py +++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py @@ -12,8 +12,7 @@ CandidateLookup = Tuple[Optional["Candidate"], Optional[InstallRequirement]] CandidateVersion = Union[LegacyVersion, Version] -def format_name(project, extras): - # type: (str, FrozenSet[str]) -> str +def format_name(project: str, extras: FrozenSet[str]) -> str: if not extras: return project canonical_extras = sorted(canonicalize_name(e) for e in extras) @@ -21,33 +20,26 @@ def format_name(project, extras): class Constraint: - def __init__(self, specifier, hashes, links): - # type: (SpecifierSet, Hashes, FrozenSet[Link]) -> None + def __init__( + self, specifier: SpecifierSet, hashes: Hashes, links: FrozenSet[Link] + ) -> None: self.specifier = specifier self.hashes = hashes self.links = links @classmethod - def empty(cls): - # type: () -> Constraint + def empty(cls) -> "Constraint": return Constraint(SpecifierSet(), Hashes(), frozenset()) @classmethod - def from_ireq(cls, ireq): - # type: (InstallRequirement) -> Constraint + def from_ireq(cls, ireq: InstallRequirement) -> "Constraint": links = frozenset([ireq.link]) if ireq.link else frozenset() return Constraint(ireq.specifier, ireq.hashes(trust_internet=False), links) - def __nonzero__(self): - # type: () -> bool + def __bool__(self) -> bool: return bool(self.specifier) or bool(self.hashes) or bool(self.links) - def __bool__(self): - # type: () -> bool - return self.__nonzero__() - - def __and__(self, other): - # type: (InstallRequirement) -> Constraint + def __and__(self, other: InstallRequirement) -> "Constraint": if not isinstance(other, InstallRequirement): return NotImplemented specifier = self.specifier & other.specifier @@ -57,8 +49,7 @@ class Constraint: links = links.union([other.link]) return Constraint(specifier, hashes, links) - def is_satisfied_by(self, candidate): - # type: (Candidate) -> bool + def is_satisfied_by(self, candidate: "Candidate") -> bool: # Reject if there are any mismatched URL constraints on this package. if self.links and not all(_match_link(link, candidate) for link in self.links): return False @@ -70,8 +61,7 @@ class Constraint: class Requirement: @property - def project_name(self): - # type: () -> NormalizedName + def project_name(self) -> NormalizedName: """The "project name" of a requirement. This is different from ``name`` if this requirement contains extras, @@ -81,8 +71,7 @@ class Requirement: raise NotImplementedError("Subclass should override") @property - def name(self): - # type: () -> str + def name(self) -> str: """The name identifying this requirement in the resolver. This is different from ``project_name`` if this requirement contains @@ -90,21 +79,17 @@ class Requirement: """ raise NotImplementedError("Subclass should override") - def is_satisfied_by(self, candidate): - # type: (Candidate) -> bool + def is_satisfied_by(self, candidate: "Candidate") -> bool: return False - def get_candidate_lookup(self): - # type: () -> CandidateLookup + def get_candidate_lookup(self) -> CandidateLookup: raise NotImplementedError("Subclass should override") - def format_for_error(self): - # type: () -> str + def format_for_error(self) -> str: raise NotImplementedError("Subclass should override") -def _match_link(link, candidate): - # type: (Link, Candidate) -> bool +def _match_link(link: Link, candidate: "Candidate") -> bool: if candidate.source_link: return links_equivalent(link, candidate.source_link) return False @@ -112,8 +97,7 @@ def _match_link(link, candidate): class Candidate: @property - def project_name(self): - # type: () -> NormalizedName + def project_name(self) -> NormalizedName: """The "project name" of the candidate. This is different from ``name`` if this candidate contains extras, @@ -123,8 +107,7 @@ class Candidate: raise NotImplementedError("Override in subclass") @property - def name(self): - # type: () -> str + def name(self) -> str: """The name identifying this candidate in the resolver. This is different from ``project_name`` if this candidate contains @@ -133,33 +116,26 @@ class Candidate: raise NotImplementedError("Override in subclass") @property - def version(self): - # type: () -> CandidateVersion + def version(self) -> CandidateVersion: raise NotImplementedError("Override in subclass") @property - def is_installed(self): - # type: () -> bool + def is_installed(self) -> bool: raise NotImplementedError("Override in subclass") @property - def is_editable(self): - # type: () -> bool + def is_editable(self) -> bool: raise NotImplementedError("Override in subclass") @property - def source_link(self): - # type: () -> Optional[Link] + def source_link(self) -> Optional[Link]: raise NotImplementedError("Override in subclass") - def iter_dependencies(self, with_requires): - # type: (bool) -> Iterable[Optional[Requirement]] + def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: raise NotImplementedError("Override in subclass") - def get_install_requirement(self): - # type: () -> Optional[InstallRequirement] + def get_install_requirement(self) -> Optional[InstallRequirement]: raise NotImplementedError("Override in subclass") - def format_for_error(self): - # type: () -> str + def format_for_error(self) -> str: raise NotImplementedError("Subclass should override") diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py index da516ad3..de04e1d7 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py +++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py @@ -2,13 +2,15 @@ import logging import sys from typing import TYPE_CHECKING, Any, FrozenSet, Iterable, Optional, Tuple, Union, cast -from pip._vendor.packaging.specifiers import InvalidSpecifier, SpecifierSet from pip._vendor.packaging.utils import NormalizedName, canonicalize_name from pip._vendor.packaging.version import Version -from pip._vendor.packaging.version import parse as parse_version -from pip._vendor.pkg_resources import Distribution -from pip._internal.exceptions import HashError, MetadataInconsistent +from pip._internal.exceptions import ( + HashError, + InstallationSubprocessError, + MetadataInconsistent, +) +from pip._internal.metadata import BaseDistribution from pip._internal.models.link import Link, links_equivalent from pip._internal.models.wheel import Wheel from pip._internal.req.constructors import ( @@ -16,8 +18,8 @@ from pip._internal.req.constructors import ( install_req_from_line, ) from pip._internal.req.req_install import InstallRequirement -from pip._internal.utils.misc import dist_is_editable, normalize_version_info -from pip._internal.utils.packaging import get_requires_python +from pip._internal.utils.direct_url_helpers import direct_url_from_link +from pip._internal.utils.misc import normalize_version_info from .base import Candidate, CandidateVersion, Requirement, format_name @@ -32,6 +34,9 @@ BaseCandidate = Union[ "LinkCandidate", ] +# Avoid conflicting with the PyPI package "Python". +REQUIRES_PYTHON_IDENTIFIER = cast(NormalizedName, "<Python from Requires-Python>") + def as_base_candidate(candidate: Candidate) -> Optional[BaseCandidate]: """The runtime version of BaseCandidate.""" @@ -45,8 +50,9 @@ def as_base_candidate(candidate: Candidate) -> Optional[BaseCandidate]: return None -def make_install_req_from_link(link, template): - # type: (Link, InstallRequirement) -> InstallRequirement +def make_install_req_from_link( + link: Link, template: InstallRequirement +) -> InstallRequirement: assert not template.editable, "template is editable" if template.req: line = str(template.req) @@ -59,44 +65,45 @@ def make_install_req_from_link(link, template): use_pep517=template.use_pep517, isolated=template.isolated, constraint=template.constraint, - options=dict( - install_options=template.install_options, - global_options=template.global_options, - hashes=template.hash_options, - ), + global_options=template.global_options, + hash_options=template.hash_options, + config_settings=template.config_settings, ) ireq.original_link = template.original_link ireq.link = link + ireq.extras = template.extras return ireq -def make_install_req_from_editable(link, template): - # type: (Link, InstallRequirement) -> InstallRequirement +def make_install_req_from_editable( + link: Link, template: InstallRequirement +) -> InstallRequirement: assert template.editable, "template not editable" - return install_req_from_editable( + ireq = install_req_from_editable( link.url, user_supplied=template.user_supplied, comes_from=template.comes_from, use_pep517=template.use_pep517, isolated=template.isolated, constraint=template.constraint, - options=dict( - install_options=template.install_options, - global_options=template.global_options, - hashes=template.hash_options, - ), + permit_editable_wheels=template.permit_editable_wheels, + global_options=template.global_options, + hash_options=template.hash_options, + config_settings=template.config_settings, ) + ireq.extras = template.extras + return ireq -def make_install_req_from_dist(dist, template): - # type: (Distribution, InstallRequirement) -> InstallRequirement - project_name = canonicalize_name(dist.project_name) +def _make_install_req_from_dist( + dist: BaseDistribution, template: InstallRequirement +) -> InstallRequirement: if template.req: line = str(template.req) elif template.link: - line = f"{project_name} @ {template.link.url}" + line = f"{dist.canonical_name} @ {template.link.url}" else: - line = f"{project_name}=={dist.parsed_version}" + line = f"{dist.canonical_name}=={dist.version}" ireq = install_req_from_line( line, user_supplied=template.user_supplied, @@ -104,11 +111,9 @@ def make_install_req_from_dist(dist, template): use_pep517=template.use_pep517, isolated=template.isolated, constraint=template.constraint, - options=dict( - install_options=template.install_options, - global_options=template.global_options, - hashes=template.hash_options, - ), + global_options=template.global_options, + hash_options=template.hash_options, + config_settings=template.config_settings, ) ireq.satisfied_by = dist return ireq @@ -130,18 +135,18 @@ class _InstallRequirementBackedCandidate(Candidate): found remote link (e.g. from pypi.org). """ + dist: BaseDistribution is_installed = False def __init__( self, - link, # type: Link - source_link, # type: Link - ireq, # type: InstallRequirement - factory, # type: Factory - name=None, # type: Optional[NormalizedName] - version=None, # type: Optional[CandidateVersion] - ): - # type: (...) -> None + link: Link, + source_link: Link, + ireq: InstallRequirement, + factory: "Factory", + name: Optional[NormalizedName] = None, + version: Optional[CandidateVersion] = None, + ) -> None: self._link = link self._source_link = source_link self._factory = factory @@ -150,86 +155,72 @@ class _InstallRequirementBackedCandidate(Candidate): self._version = version self.dist = self._prepare() - def __str__(self): - # type: () -> str + def __str__(self) -> str: return f"{self.name} {self.version}" - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return "{class_name}({link!r})".format( class_name=self.__class__.__name__, link=str(self._link), ) - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash((self.__class__, self._link)) - def __eq__(self, other): - # type: (Any) -> bool + def __eq__(self, other: Any) -> bool: if isinstance(other, self.__class__): return links_equivalent(self._link, other._link) return False @property - def source_link(self): - # type: () -> Optional[Link] + def source_link(self) -> Optional[Link]: return self._source_link @property - def project_name(self): - # type: () -> NormalizedName + def project_name(self) -> NormalizedName: """The normalised name of the project the candidate refers to""" if self._name is None: - self._name = canonicalize_name(self.dist.project_name) + self._name = self.dist.canonical_name return self._name @property - def name(self): - # type: () -> str + def name(self) -> str: return self.project_name @property - def version(self): - # type: () -> CandidateVersion + def version(self) -> CandidateVersion: if self._version is None: - self._version = parse_version(self.dist.version) + self._version = self.dist.version return self._version - def format_for_error(self): - # type: () -> str + def format_for_error(self) -> str: return "{} {} (from {})".format( self.name, self.version, self._link.file_path if self._link.is_file else self._link, ) - def _prepare_distribution(self): - # type: () -> Distribution + def _prepare_distribution(self) -> BaseDistribution: raise NotImplementedError("Override in subclass") - def _check_metadata_consistency(self, dist): - # type: (Distribution) -> None + def _check_metadata_consistency(self, dist: BaseDistribution) -> None: """Check for consistency of project name and version of dist.""" - canonical_name = canonicalize_name(dist.project_name) - if self._name is not None and self._name != canonical_name: + if self._name is not None and self._name != dist.canonical_name: raise MetadataInconsistent( self._ireq, "name", self._name, - dist.project_name, + dist.canonical_name, ) - parsed_version = parse_version(dist.version) - if self._version is not None and self._version != parsed_version: + if self._version is not None and self._version != dist.version: raise MetadataInconsistent( self._ireq, "version", str(self._version), - dist.version, + str(dist.version), ) - def _prepare(self): - # type: () -> Distribution + def _prepare(self) -> BaseDistribution: try: dist = self._prepare_distribution() except HashError as e: @@ -238,31 +229,21 @@ class _InstallRequirementBackedCandidate(Candidate): # offending line to the user. e.req = self._ireq raise + except InstallationSubprocessError as exc: + # The output has been presented already, so don't duplicate it. + exc.context = "See above for output." + raise + self._check_metadata_consistency(dist) return dist - def _get_requires_python_dependency(self): - # type: () -> Optional[Requirement] - requires_python = get_requires_python(self.dist) - if requires_python is None: - return None - try: - spec = SpecifierSet(requires_python) - except InvalidSpecifier as e: - message = "Package %r has an invalid Requires-Python: %s" - logger.warning(message, self.name, e) - return None - return self._factory.make_requires_python_requirement(spec) - - def iter_dependencies(self, with_requires): - # type: (bool) -> Iterable[Optional[Requirement]] - requires = self.dist.requires() if with_requires else () + def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: + requires = self.dist.iter_dependencies() if with_requires else () for r in requires: yield self._factory.make_requirement_from_spec(str(r), self._ireq) - yield self._get_requires_python_dependency() + yield self._factory.make_requires_python_requirement(self.dist.requires_python) - def get_install_requirement(self): - # type: () -> Optional[InstallRequirement] + def get_install_requirement(self) -> Optional[InstallRequirement]: return self._ireq @@ -271,15 +252,14 @@ class LinkCandidate(_InstallRequirementBackedCandidate): def __init__( self, - link, # type: Link - template, # type: InstallRequirement - factory, # type: Factory - name=None, # type: Optional[NormalizedName] - version=None, # type: Optional[CandidateVersion] - ): - # type: (...) -> None + link: Link, + template: InstallRequirement, + factory: "Factory", + name: Optional[NormalizedName] = None, + version: Optional[CandidateVersion] = None, + ) -> None: source_link = link - cache_entry = factory.get_wheel_cache_entry(link, name) + cache_entry = factory.get_wheel_cache_entry(source_link, name) if cache_entry is not None: logger.debug("Using cached wheel link: %s", cache_entry.link) link = cache_entry.link @@ -296,12 +276,19 @@ class LinkCandidate(_InstallRequirementBackedCandidate): version, wheel_version, name ) - if ( - cache_entry is not None - and cache_entry.persistent - and template.link is template.original_link - ): - ireq.original_link_is_in_wheel_cache = True + if cache_entry is not None: + assert ireq.link.is_wheel + assert ireq.link.is_file + if cache_entry.persistent and template.link is template.original_link: + ireq.cached_wheel_source_link = source_link + if cache_entry.origin is not None: + ireq.download_info = cache_entry.origin + else: + # Legacy cache entry that does not have origin.json. + # download_info may miss the archive_info.hashes field. + ireq.download_info = direct_url_from_link( + source_link, link_is_in_wheel_cache=cache_entry.persistent + ) super().__init__( link=link, @@ -312,11 +299,9 @@ class LinkCandidate(_InstallRequirementBackedCandidate): version=version, ) - def _prepare_distribution(self): - # type: () -> Distribution - return self._factory.preparer.prepare_linked_requirement( - self._ireq, parallel_builds=True - ) + def _prepare_distribution(self) -> BaseDistribution: + preparer = self._factory.preparer + return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) class EditableCandidate(_InstallRequirementBackedCandidate): @@ -324,13 +309,12 @@ class EditableCandidate(_InstallRequirementBackedCandidate): def __init__( self, - link, # type: Link - template, # type: InstallRequirement - factory, # type: Factory - name=None, # type: Optional[NormalizedName] - version=None, # type: Optional[CandidateVersion] - ): - # type: (...) -> None + link: Link, + template: InstallRequirement, + factory: "Factory", + name: Optional[NormalizedName] = None, + version: Optional[CandidateVersion] = None, + ) -> None: super().__init__( link=link, source_link=link, @@ -340,8 +324,7 @@ class EditableCandidate(_InstallRequirementBackedCandidate): version=version, ) - def _prepare_distribution(self): - # type: () -> Distribution + def _prepare_distribution(self) -> BaseDistribution: return self._factory.preparer.prepare_editable_requirement(self._ireq) @@ -351,76 +334,67 @@ class AlreadyInstalledCandidate(Candidate): def __init__( self, - dist, # type: Distribution - template, # type: InstallRequirement - factory, # type: Factory - ): - # type: (...) -> None + dist: BaseDistribution, + template: InstallRequirement, + factory: "Factory", + ) -> None: self.dist = dist - self._ireq = make_install_req_from_dist(dist, template) + self._ireq = _make_install_req_from_dist(dist, template) self._factory = factory + self._version = None # This is just logging some messages, so we can do it eagerly. # The returned dist would be exactly the same as self.dist because we - # set satisfied_by in make_install_req_from_dist. + # set satisfied_by in _make_install_req_from_dist. # TODO: Supply reason based on force_reinstall and upgrade_strategy. skip_reason = "already satisfied" factory.preparer.prepare_installed_requirement(self._ireq, skip_reason) - def __str__(self): - # type: () -> str + def __str__(self) -> str: return str(self.dist) - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return "{class_name}({distribution!r})".format( class_name=self.__class__.__name__, distribution=self.dist, ) - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash((self.__class__, self.name, self.version)) - def __eq__(self, other): - # type: (Any) -> bool + def __eq__(self, other: Any) -> bool: if isinstance(other, self.__class__): return self.name == other.name and self.version == other.version return False @property - def project_name(self): - # type: () -> NormalizedName - return canonicalize_name(self.dist.project_name) + def project_name(self) -> NormalizedName: + return self.dist.canonical_name @property - def name(self): - # type: () -> str + def name(self) -> str: return self.project_name @property - def version(self): - # type: () -> CandidateVersion - return parse_version(self.dist.version) + def version(self) -> CandidateVersion: + if self._version is None: + self._version = self.dist.version + return self._version @property - def is_editable(self): - # type: () -> bool - return dist_is_editable(self.dist) + def is_editable(self) -> bool: + return self.dist.editable - def format_for_error(self): - # type: () -> str + def format_for_error(self) -> str: return f"{self.name} {self.version} (Installed)" - def iter_dependencies(self, with_requires): - # type: (bool) -> Iterable[Optional[Requirement]] + def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: if not with_requires: return - for r in self.dist.requires(): + for r in self.dist.iter_dependencies(): yield self._factory.make_requirement_from_spec(str(r), self._ireq) - def get_install_requirement(self): - # type: () -> Optional[InstallRequirement] + def get_install_requirement(self) -> Optional[InstallRequirement]: return None @@ -451,75 +425,62 @@ class ExtrasCandidate(Candidate): def __init__( self, - base, # type: BaseCandidate - extras, # type: FrozenSet[str] - ): - # type: (...) -> None + base: BaseCandidate, + extras: FrozenSet[str], + ) -> None: self.base = base self.extras = extras - def __str__(self): - # type: () -> str + def __str__(self) -> str: name, rest = str(self.base).split(" ", 1) return "{}[{}] {}".format(name, ",".join(self.extras), rest) - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return "{class_name}(base={base!r}, extras={extras!r})".format( class_name=self.__class__.__name__, base=self.base, extras=self.extras, ) - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash((self.base, self.extras)) - def __eq__(self, other): - # type: (Any) -> bool + def __eq__(self, other: Any) -> bool: if isinstance(other, self.__class__): return self.base == other.base and self.extras == other.extras return False @property - def project_name(self): - # type: () -> NormalizedName + def project_name(self) -> NormalizedName: return self.base.project_name @property - def name(self): - # type: () -> str + def name(self) -> str: """The normalised name of the project the candidate refers to""" return format_name(self.base.project_name, self.extras) @property - def version(self): - # type: () -> CandidateVersion + def version(self) -> CandidateVersion: return self.base.version - def format_for_error(self): - # type: () -> str + def format_for_error(self) -> str: return "{} [{}]".format( self.base.format_for_error(), ", ".join(sorted(self.extras)) ) @property - def is_installed(self): - # type: () -> bool + def is_installed(self) -> bool: return self.base.is_installed @property - def is_editable(self): - # type: () -> bool + def is_editable(self) -> bool: return self.base.is_editable @property - def source_link(self): - # type: () -> Optional[Link] + def source_link(self) -> Optional[Link]: return self.base.source_link - def iter_dependencies(self, with_requires): - # type: (bool) -> Iterable[Optional[Requirement]] + def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: factory = self.base._factory # Add a dependency on the exact base @@ -530,8 +491,8 @@ class ExtrasCandidate(Candidate): # The user may have specified extras that the candidate doesn't # support. We ignore any unsupported extras here. - valid_extras = self.extras.intersection(self.base.dist.extras) - invalid_extras = self.extras.difference(self.base.dist.extras) + valid_extras = self.extras.intersection(self.base.dist.iter_provided_extras()) + invalid_extras = self.extras.difference(self.base.dist.iter_provided_extras()) for extra in sorted(invalid_extras): logger.warning( "%s %s does not provide the extra '%s'", @@ -540,15 +501,14 @@ class ExtrasCandidate(Candidate): extra, ) - for r in self.base.dist.requires(valid_extras): + for r in self.base.dist.iter_dependencies(valid_extras): requirement = factory.make_requirement_from_spec( str(r), self.base._ireq, valid_extras ) if requirement: yield requirement - def get_install_requirement(self): - # type: () -> Optional[InstallRequirement] + def get_install_requirement(self) -> Optional[InstallRequirement]: # We don't return anything here, because we always # depend on the base candidate, and we'll get the # install requirement from that. @@ -559,8 +519,7 @@ class RequiresPythonCandidate(Candidate): is_installed = False source_link = None - def __init__(self, py_version_info): - # type: (Optional[Tuple[int, ...]]) -> None + def __init__(self, py_version_info: Optional[Tuple[int, ...]]) -> None: if py_version_info is not None: version_info = normalize_version_info(py_version_info) else: @@ -571,34 +530,26 @@ class RequiresPythonCandidate(Candidate): # only one RequiresPythonCandidate in a resolution, i.e. the host Python. # The built-in object.__eq__() and object.__ne__() do exactly what we want. - def __str__(self): - # type: () -> str + def __str__(self) -> str: return f"Python {self._version}" @property - def project_name(self): - # type: () -> NormalizedName - # Avoid conflicting with the PyPI package "Python". - return cast(NormalizedName, "<Python from Requires-Python>") + def project_name(self) -> NormalizedName: + return REQUIRES_PYTHON_IDENTIFIER @property - def name(self): - # type: () -> str - return self.project_name + def name(self) -> str: + return REQUIRES_PYTHON_IDENTIFIER @property - def version(self): - # type: () -> CandidateVersion + def version(self) -> CandidateVersion: return self._version - def format_for_error(self): - # type: () -> str + def format_for_error(self) -> str: return f"Python {self.version}" - def iter_dependencies(self, with_requires): - # type: (bool) -> Iterable[Optional[Requirement]] + def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]: return () - def get_install_requirement(self): - # type: () -> Optional[InstallRequirement] + def get_install_requirement(self) -> Optional[InstallRequirement]: return None diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py index 5816a0ed..0331297b 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py +++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py @@ -9,6 +9,7 @@ from typing import ( Iterator, List, Mapping, + NamedTuple, Optional, Sequence, Set, @@ -18,35 +19,32 @@ from typing import ( ) from pip._vendor.packaging.requirements import InvalidRequirement -from pip._vendor.packaging.requirements import Requirement as PackagingRequirement from pip._vendor.packaging.specifiers import SpecifierSet from pip._vendor.packaging.utils import NormalizedName, canonicalize_name -from pip._vendor.pkg_resources import Distribution from pip._vendor.resolvelib import ResolutionImpossible from pip._internal.cache import CacheEntry, WheelCache from pip._internal.exceptions import ( DistributionNotFound, InstallationError, - InstallationSubprocessError, MetadataInconsistent, UnsupportedPythonVersion, UnsupportedWheel, ) from pip._internal.index.package_finder import PackageFinder +from pip._internal.metadata import BaseDistribution, get_default_environment from pip._internal.models.link import Link from pip._internal.models.wheel import Wheel from pip._internal.operations.prepare import RequirementPreparer from pip._internal.req.constructors import install_req_from_link_and_ireq -from pip._internal.req.req_install import InstallRequirement +from pip._internal.req.req_install import ( + InstallRequirement, + check_invalid_constraint_type, +) from pip._internal.resolution.base import InstallRequirementProvider from pip._internal.utils.compatibility_tags import get_supported from pip._internal.utils.hashes import Hashes -from pip._internal.utils.misc import ( - dist_in_site_packages, - dist_in_usersite, - get_installed_distributions, -) +from pip._internal.utils.packaging import get_requirement from pip._internal.utils.virtualenv import running_under_virtualenv from .base import Candidate, CandidateVersion, Constraint, Requirement @@ -81,20 +79,25 @@ C = TypeVar("C") Cache = Dict[Link, C] +class CollectedRootRequirements(NamedTuple): + requirements: List[Requirement] + constraints: Dict[str, Constraint] + user_requested: Dict[str, int] + + class Factory: def __init__( self, - finder, # type: PackageFinder - preparer, # type: RequirementPreparer - make_install_req, # type: InstallRequirementProvider - wheel_cache, # type: Optional[WheelCache] - use_user_site, # type: bool - force_reinstall, # type: bool - ignore_installed, # type: bool - ignore_requires_python, # type: bool - py_version_info=None, # type: Optional[Tuple[int, ...]] - ): - # type: (...) -> None + finder: PackageFinder, + preparer: RequirementPreparer, + make_install_req: InstallRequirementProvider, + wheel_cache: Optional[WheelCache], + use_user_site: bool, + force_reinstall: bool, + ignore_installed: bool, + ignore_requires_python: bool, + py_version_info: Optional[Tuple[int, ...]] = None, + ) -> None: self._finder = finder self.preparer = preparer self._wheel_cache = wheel_cache @@ -104,27 +107,25 @@ class Factory: self._force_reinstall = force_reinstall self._ignore_requires_python = ignore_requires_python - self._build_failures = {} # type: Cache[InstallationError] - self._link_candidate_cache = {} # type: Cache[LinkCandidate] - self._editable_candidate_cache = {} # type: Cache[EditableCandidate] - self._installed_candidate_cache = ( - {} - ) # type: Dict[str, AlreadyInstalledCandidate] - self._extras_candidate_cache = ( - {} - ) # type: Dict[Tuple[int, FrozenSet[str]], ExtrasCandidate] + self._build_failures: Cache[InstallationError] = {} + self._link_candidate_cache: Cache[LinkCandidate] = {} + self._editable_candidate_cache: Cache[EditableCandidate] = {} + self._installed_candidate_cache: Dict[str, AlreadyInstalledCandidate] = {} + self._extras_candidate_cache: Dict[ + Tuple[int, FrozenSet[str]], ExtrasCandidate + ] = {} if not ignore_installed: + env = get_default_environment() self._installed_dists = { - canonicalize_name(dist.project_name): dist - for dist in get_installed_distributions(local_only=False) + dist.canonical_name: dist + for dist in env.iter_installed_distributions(local_only=False) } else: self._installed_dists = {} @property - def force_reinstall(self): - # type: () -> bool + def force_reinstall(self) -> bool: return self._force_reinstall def _fail_if_link_is_unsupported_wheel(self, link: Link) -> None: @@ -136,8 +137,9 @@ class Factory: msg = f"{link.filename} is not a supported wheel on this platform." raise UnsupportedWheel(msg) - def _make_extras_candidate(self, base, extras): - # type: (BaseCandidate, FrozenSet[str]) -> ExtrasCandidate + def _make_extras_candidate( + self, base: BaseCandidate, extras: FrozenSet[str] + ) -> ExtrasCandidate: cache_key = (id(base), extras) try: candidate = self._extras_candidate_cache[cache_key] @@ -148,29 +150,27 @@ class Factory: def _make_candidate_from_dist( self, - dist, # type: Distribution - extras, # type: FrozenSet[str] - template, # type: InstallRequirement - ): - # type: (...) -> Candidate + dist: BaseDistribution, + extras: FrozenSet[str], + template: InstallRequirement, + ) -> Candidate: try: - base = self._installed_candidate_cache[dist.key] + base = self._installed_candidate_cache[dist.canonical_name] except KeyError: base = AlreadyInstalledCandidate(dist, template, factory=self) - self._installed_candidate_cache[dist.key] = base + self._installed_candidate_cache[dist.canonical_name] = base if not extras: return base return self._make_extras_candidate(base, extras) def _make_candidate_from_link( self, - link, # type: Link - extras, # type: FrozenSet[str] - template, # type: InstallRequirement - name, # type: Optional[NormalizedName] - version, # type: Optional[CandidateVersion] - ): - # type: (...) -> Optional[Candidate] + link: Link, + extras: FrozenSet[str], + template: InstallRequirement, + name: Optional[NormalizedName], + version: Optional[CandidateVersion], + ) -> Optional[Candidate]: # TODO: Check already installed candidate, and use it if the link and # editable flag match. @@ -189,11 +189,17 @@ class Factory: name=name, version=version, ) - except (InstallationSubprocessError, MetadataInconsistent) as e: - logger.warning("Discarding %s. %s", link, e) + except MetadataInconsistent as e: + logger.info( + "Discarding [blue underline]%s[/]: [yellow]%s[reset]", + link, + e, + extra={"markup": True}, + ) self._build_failures[link] = e return None - base = self._editable_candidate_cache[link] # type: BaseCandidate + + base: BaseCandidate = self._editable_candidate_cache[link] else: if link not in self._link_candidate_cache: try: @@ -204,8 +210,13 @@ class Factory: name=name, version=version, ) - except (InstallationSubprocessError, MetadataInconsistent) as e: - logger.warning("Discarding %s. %s", link, e) + except MetadataInconsistent as e: + logger.info( + "Discarding [blue underline]%s[/]: [yellow]%s[reset]", + link, + e, + extra={"markup": True}, + ) self._build_failures[link] = e return None base = self._link_candidate_cache[link] @@ -233,7 +244,7 @@ class Factory: assert template.req, "Candidates found on index must be PEP 508" name = canonicalize_name(template.req.name) - extras = frozenset() # type: FrozenSet[str] + extras: FrozenSet[str] = frozenset() for ireq in ireqs: assert ireq.req, "Candidates found on index must be PEP 508" specifier &= ireq.req.specifier @@ -259,13 +270,12 @@ class Factory: extras=extras, template=template, ) - # The candidate is a known incompatiblity. Don't use it. + # The candidate is a known incompatibility. Don't use it. if id(candidate) in incompatible_ids: return None return candidate - def iter_index_candidate_infos(): - # type: () -> Iterator[IndexCandidateInfo] + def iter_index_candidate_infos() -> Iterator[IndexCandidateInfo]: result = self._finder.find_best_candidate( project_name=name, specifier=specifier, @@ -273,14 +283,27 @@ class Factory: ) icans = list(result.iter_applicable()) - # PEP 592: Yanked releases must be ignored unless only yanked - # releases can satisfy the version range. So if this is false, - # all yanked icans need to be skipped. + # PEP 592: Yanked releases are ignored unless the specifier + # explicitly pins a version (via '==' or '===') that can be + # solely satisfied by a yanked release. all_yanked = all(ican.link.is_yanked for ican in icans) + def is_pinned(specifier: SpecifierSet) -> bool: + for sp in specifier: + if sp.operator == "===": + return True + if sp.operator != "==": + continue + if sp.version.endswith(".*"): + continue + return True + return False + + pinned = is_pinned(specifier) + # PackageFinder returns earlier versions first, so we reverse. for ican in reversed(icans): - if not all_yanked and ican.link.is_yanked: + if not (all_yanked and pinned) and ican.link.is_yanked: continue func = functools.partial( self._make_candidate_from_link, @@ -347,14 +370,14 @@ class Factory: def find_candidates( self, identifier: str, - requirements: Mapping[str, Iterator[Requirement]], + requirements: Mapping[str, Iterable[Requirement]], incompatibilities: Mapping[str, Iterator[Candidate]], constraint: Constraint, prefers_installed: bool, ) -> Iterable[Candidate]: # Collect basic lookup information from the requirements. - explicit_candidates = set() # type: Set[Candidate] - ireqs = [] # type: List[InstallRequirement] + explicit_candidates: Set[Candidate] = set() + ireqs: List[InstallRequirement] = [] for req in requirements[identifier]: cand, ireq = req.get_candidate_lookup() if cand is not None: @@ -365,7 +388,7 @@ class Factory: # If the current identifier contains extras, add explicit candidates # from entries from extra-less identifier. with contextlib.suppress(InvalidRequirement): - parsed_requirement = PackagingRequirement(identifier) + parsed_requirement = get_requirement(identifier) explicit_candidates.update( self._iter_explicit_candidates_from_base( requirements.get(parsed_requirement.name, ()), @@ -374,7 +397,7 @@ class Factory: ) # Add explicit candidates from constraints. We only do this if there are - # kown ireqs, which represent requirements not already explicit. If + # known ireqs, which represent requirements not already explicit. If # there are no ireqs, we're constraining already-explicit requirements, # which is handled later when we return the explicit candidates. if ireqs: @@ -414,8 +437,9 @@ class Factory: and all(req.is_satisfied_by(c) for req in requirements[identifier]) ) - def make_requirement_from_install_req(self, ireq, requested_extras): - # type: (InstallRequirement, Iterable[str]) -> Optional[Requirement] + def _make_requirement_from_install_req( + self, ireq: InstallRequirement, requested_extras: Iterable[str] + ) -> Optional[Requirement]: if not ireq.match_markers(requested_extras): logger.info( "Ignoring %s: markers '%s' don't match your environment", @@ -445,28 +469,64 @@ class Factory: return UnsatisfiableRequirement(canonicalize_name(ireq.name)) return self.make_requirement_from_candidate(cand) - def make_requirement_from_candidate(self, candidate): - # type: (Candidate) -> ExplicitRequirement + def collect_root_requirements( + self, root_ireqs: List[InstallRequirement] + ) -> CollectedRootRequirements: + collected = CollectedRootRequirements([], {}, {}) + for i, ireq in enumerate(root_ireqs): + if ireq.constraint: + # Ensure we only accept valid constraints + problem = check_invalid_constraint_type(ireq) + if problem: + raise InstallationError(problem) + if not ireq.match_markers(): + continue + assert ireq.name, "Constraint must be named" + name = canonicalize_name(ireq.name) + if name in collected.constraints: + collected.constraints[name] &= ireq + else: + collected.constraints[name] = Constraint.from_ireq(ireq) + else: + req = self._make_requirement_from_install_req( + ireq, + requested_extras=(), + ) + if req is None: + continue + if ireq.user_supplied and req.name not in collected.user_requested: + collected.user_requested[req.name] = i + collected.requirements.append(req) + return collected + + def make_requirement_from_candidate( + self, candidate: Candidate + ) -> ExplicitRequirement: return ExplicitRequirement(candidate) def make_requirement_from_spec( self, - specifier, # type: str - comes_from, # type: InstallRequirement - requested_extras=(), # type: Iterable[str] - ): - # type: (...) -> Optional[Requirement] + specifier: str, + comes_from: Optional[InstallRequirement], + requested_extras: Iterable[str] = (), + ) -> Optional[Requirement]: ireq = self._make_install_req_from_spec(specifier, comes_from) - return self.make_requirement_from_install_req(ireq, requested_extras) + return self._make_requirement_from_install_req(ireq, requested_extras) - def make_requires_python_requirement(self, specifier): - # type: (Optional[SpecifierSet]) -> Optional[Requirement] - if self._ignore_requires_python or specifier is None: + def make_requires_python_requirement( + self, + specifier: SpecifierSet, + ) -> Optional[Requirement]: + if self._ignore_requires_python: + return None + # Don't bother creating a dependency for an empty Requires-Python. + if not str(specifier): return None return RequiresPythonRequirement(specifier, self._python_candidate) - def get_wheel_cache_entry(self, link, name): - # type: (Link, Optional[str]) -> Optional[CacheEntry] + def get_wheel_cache_entry( + self, link: Link, name: Optional[str] + ) -> Optional[CacheEntry]: """Look up the link in the wheel cache. If ``preparer.require_hashes`` is True, don't use the wheel cache, @@ -475,7 +535,7 @@ class Factory: hash mismatches. Furthermore, cached wheels at present have nondeterministic contents due to file modification times. """ - if self._wheel_cache is None or self.preparer.require_hashes: + if self._wheel_cache is None: return None return self._wheel_cache.get_cache_entry( link=link, @@ -483,8 +543,7 @@ class Factory: supported_tags=get_supported(), ) - def get_dist_to_uninstall(self, candidate): - # type: (Candidate) -> Optional[Distribution] + def get_dist_to_uninstall(self, candidate: Candidate) -> Optional[BaseDistribution]: # TODO: Are there more cases this needs to return True? Editable? dist = self._installed_dists.get(candidate.project_name) if dist is None: # Not installed, no uninstallation required. @@ -497,25 +556,24 @@ class Factory: return dist # We're installing into user site. Remove the user site installation. - if dist_in_usersite(dist): + if dist.in_usersite: return dist # We're installing into user site, but the installed incompatible # package is in global site. We can't uninstall that, and would let # the new user installation to "shadow" it. But shadowing won't work # in virtual environments, so we error out. - if running_under_virtualenv() and dist_in_site_packages(dist): - raise InstallationError( - "Will not install to the user site because it will " - "lack sys.path precedence to {} in {}".format( - dist.project_name, - dist.location, - ) + if running_under_virtualenv() and dist.in_site_packages: + message = ( + f"Will not install to the user site because it will lack " + f"sys.path precedence to {dist.raw_name} in {dist.location}" ) + raise InstallationError(message) return None - def _report_requires_python_error(self, causes): - # type: (Sequence[ConflictCause]) -> UnsupportedPythonVersion + def _report_requires_python_error( + self, causes: Sequence["ConflictCause"] + ) -> UnsupportedPythonVersion: assert causes, "Requires-Python error reported with no cause" version = self._python_candidate.version @@ -535,32 +593,45 @@ class Factory: message += f"\n{specifier!r} (required by {package})" return UnsupportedPythonVersion(message) - def _report_single_requirement_conflict(self, req, parent): - # type: (Requirement, Optional[Candidate]) -> DistributionNotFound + def _report_single_requirement_conflict( + self, req: Requirement, parent: Optional[Candidate] + ) -> DistributionNotFound: if parent is None: req_disp = str(req) else: req_disp = f"{req} (from {parent.name})" cands = self._finder.find_all_candidates(req.project_name) + skipped_by_requires_python = self._finder.requires_python_skipped_reasons() versions = [str(v) for v in sorted({c.version for c in cands})] + if skipped_by_requires_python: + logger.critical( + "Ignored the following versions that require a different python " + "version: %s", + "; ".join(skipped_by_requires_python) or "none", + ) logger.critical( "Could not find a version that satisfies the requirement %s " "(from versions: %s)", req_disp, ", ".join(versions) or "none", ) + if str(req) == "requirements.txt": + logger.info( + "HINT: You are attempting to install a package literally " + 'named "requirements.txt" (which cannot exist). Consider ' + "using the '-r' flag to install the packages listed in " + "requirements.txt" + ) return DistributionNotFound(f"No matching distribution found for {req}") def get_installation_error( self, - e, # type: ResolutionImpossible[Requirement, Candidate] - constraints, # type: Dict[str, Constraint] - ): - # type: (...) -> InstallationError - + e: "ResolutionImpossible[Requirement, Candidate]", + constraints: Dict[str, Constraint], + ) -> InstallationError: assert e.causes, "Installation error reported with no cause" # If one of the things we can't solve is "we need Python X.Y", @@ -573,7 +644,7 @@ class Factory: ] if requires_python_causes: # The comprehension above makes sure all Requirement instances are - # RequiresPythonRequirement, so let's cast for convinience. + # RequiresPythonRequirement, so let's cast for convenience. return self._report_requires_python_error( cast("Sequence[ConflictCause]", requires_python_causes), ) @@ -592,15 +663,13 @@ class Factory: # satisfied at once. # A couple of formatting helpers - def text_join(parts): - # type: (List[str]) -> str + def text_join(parts: List[str]) -> str: if len(parts) == 1: return parts[0] return ", ".join(parts[:-1]) + " and " + parts[-1] - def describe_trigger(parent): - # type: (Candidate) -> str + def describe_trigger(parent: Candidate) -> str: ireq = parent.get_install_requirement() if not ireq or not ireq.comes_from: return f"{parent.name}=={parent.version}" @@ -656,6 +725,6 @@ class Factory: return DistributionNotFound( "ResolutionImpossible: for help visit " - "https://pip.pypa.io/en/latest/user_guide/" - "#fixing-conflicting-dependencies" + "https://pip.pypa.io/en/latest/topics/dependency-resolution/" + "#dealing-with-dependency-conflicts" ) diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py index 21fa08ec..8663097b 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py +++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py @@ -9,24 +9,38 @@ something. """ import functools -from typing import Callable, Iterator, Optional, Set, Tuple +from collections.abc import Sequence +from typing import TYPE_CHECKING, Any, Callable, Iterator, Optional, Set, Tuple from pip._vendor.packaging.version import _BaseVersion -from pip._vendor.six.moves import collections_abc # type: ignore from .base import Candidate IndexCandidateInfo = Tuple[_BaseVersion, Callable[[], Optional[Candidate]]] - -def _iter_built(infos): - # type: (Iterator[IndexCandidateInfo]) -> Iterator[Candidate] +if TYPE_CHECKING: + SequenceCandidate = Sequence[Candidate] +else: + # For compatibility: Python before 3.9 does not support using [] on the + # Sequence class. + # + # >>> from collections.abc import Sequence + # >>> Sequence[str] + # Traceback (most recent call last): + # File "<stdin>", line 1, in <module> + # TypeError: 'ABCMeta' object is not subscriptable + # + # TODO: Remove this block after dropping Python 3.8 support. + SequenceCandidate = Sequence + + +def _iter_built(infos: Iterator[IndexCandidateInfo]) -> Iterator[Candidate]: """Iterator for ``FoundCandidates``. This iterator is used when the package is not already installed. Candidates from index come later in their normal ordering. """ - versions_found = set() # type: Set[_BaseVersion] + versions_found: Set[_BaseVersion] = set() for version, func in infos: if version in versions_found: continue @@ -37,8 +51,9 @@ def _iter_built(infos): versions_found.add(version) -def _iter_built_with_prepended(installed, infos): - # type: (Candidate, Iterator[IndexCandidateInfo]) -> Iterator[Candidate] +def _iter_built_with_prepended( + installed: Candidate, infos: Iterator[IndexCandidateInfo] +) -> Iterator[Candidate]: """Iterator for ``FoundCandidates``. This iterator is used when the resolver prefers the already-installed @@ -47,7 +62,7 @@ def _iter_built_with_prepended(installed, infos): normal ordering, except skipped when the version is already installed. """ yield installed - versions_found = {installed.version} # type: Set[_BaseVersion] + versions_found: Set[_BaseVersion] = {installed.version} for version, func in infos: if version in versions_found: continue @@ -58,8 +73,9 @@ def _iter_built_with_prepended(installed, infos): versions_found.add(version) -def _iter_built_with_inserted(installed, infos): - # type: (Candidate, Iterator[IndexCandidateInfo]) -> Iterator[Candidate] +def _iter_built_with_inserted( + installed: Candidate, infos: Iterator[IndexCandidateInfo] +) -> Iterator[Candidate]: """Iterator for ``FoundCandidates``. This iterator is used when the resolver prefers to upgrade an @@ -70,7 +86,7 @@ def _iter_built_with_inserted(installed, infos): the installed candidate exactly once before we start yielding older or equivalent candidates, or after all other candidates if they are all newer. """ - versions_found = set() # type: Set[_BaseVersion] + versions_found: Set[_BaseVersion] = set() for version, func in infos: if version in versions_found: continue @@ -89,7 +105,7 @@ def _iter_built_with_inserted(installed, infos): yield installed -class FoundCandidates(collections_abc.Sequence): +class FoundCandidates(SequenceCandidate): """A lazy sequence to provide candidates to the resolver. The intended usage is to return this from `find_matches()` so the resolver @@ -110,15 +126,13 @@ class FoundCandidates(collections_abc.Sequence): self._prefers_installed = prefers_installed self._incompatible_ids = incompatible_ids - def __getitem__(self, index): - # type: (int) -> Candidate + def __getitem__(self, index: Any) -> Any: # Implemented to satisfy the ABC check. This is not needed by the # resolver, and should not be used by the provider either (for # performance reasons). raise NotImplementedError("don't do this") - def __iter__(self): - # type: () -> Iterator[Candidate] + def __iter__(self) -> Iterator[Candidate]: infos = self._get_infos() if not self._installed: iterator = _iter_built(infos) @@ -128,18 +142,14 @@ class FoundCandidates(collections_abc.Sequence): iterator = _iter_built_with_inserted(self._installed, infos) return (c for c in iterator if id(c) not in self._incompatible_ids) - def __len__(self): - # type: () -> int + def __len__(self) -> int: # Implemented to satisfy the ABC check. This is not needed by the # resolver, and should not be used by the provider either (for # performance reasons). raise NotImplementedError("don't do this") @functools.lru_cache(maxsize=1) - def __bool__(self): - # type: () -> bool + def __bool__(self) -> bool: if self._prefers_installed and self._installed: return True return any(self) - - __nonzero__ = __bool__ # XXX: Python 2. diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py index 0be58fd3..315fb9c8 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py +++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py @@ -1,8 +1,20 @@ -from typing import TYPE_CHECKING, Dict, Iterable, Iterator, Mapping, Sequence, Union +import collections +import math +from typing import ( + TYPE_CHECKING, + Dict, + Iterable, + Iterator, + Mapping, + Sequence, + TypeVar, + Union, +) from pip._vendor.resolvelib.providers import AbstractProvider from .base import Candidate, Constraint, Requirement +from .candidates import REQUIRES_PYTHON_IDENTIFIER from .factory import Factory if TYPE_CHECKING: @@ -34,6 +46,35 @@ else: # services to those objects (access to pip's finder and preparer). +D = TypeVar("D") +V = TypeVar("V") + + +def _get_with_identifier( + mapping: Mapping[str, V], + identifier: str, + default: D, +) -> Union[D, V]: + """Get item from a package name lookup mapping with a resolver identifier. + + This extra logic is needed when the target mapping is keyed by package + name, which cannot be directly looked up with an identifier (which may + contain requested extras). Additional logic is added to also look up a value + by "cleaning up" the extras from the identifier. + """ + if identifier in mapping: + return mapping[identifier] + # HACK: Theoretically we should check whether this identifier is a valid + # "NAME[EXTRAS]" format, and parse out the name part with packaging or + # some regular expression. But since pip's resolver only spits out three + # kinds of identifiers: normalized PEP 503 names, normalized names plus + # extras, and Requires-Python, we can cheat a bit here. + name, open_bracket, _ = identifier.partition("[") + if open_bracket and name in mapping: + return mapping[name] + return default + + class PipProvider(_ProviderBase): """Pip's provider implementation for resolvelib. @@ -47,21 +88,20 @@ class PipProvider(_ProviderBase): def __init__( self, - factory, # type: Factory - constraints, # type: Dict[str, Constraint] - ignore_dependencies, # type: bool - upgrade_strategy, # type: str - user_requested, # type: Dict[str, int] - ): - # type: (...) -> None + factory: Factory, + constraints: Dict[str, Constraint], + ignore_dependencies: bool, + upgrade_strategy: str, + user_requested: Dict[str, int], + ) -> None: self._factory = factory self._constraints = constraints self._ignore_dependencies = ignore_dependencies self._upgrade_strategy = upgrade_strategy self._user_requested = user_requested + self._known_depths: Dict[str, float] = collections.defaultdict(lambda: math.inf) - def identify(self, requirement_or_candidate): - # type: (Union[Requirement, Candidate]) -> str + def identify(self, requirement_or_candidate: Union[Requirement, Candidate]) -> str: return requirement_or_candidate.name def get_preference( @@ -69,69 +109,91 @@ class PipProvider(_ProviderBase): identifier: str, resolutions: Mapping[str, Candidate], candidates: Mapping[str, Iterator[Candidate]], - information: Mapping[str, Iterator["PreferenceInformation"]], + information: Mapping[str, Iterable["PreferenceInformation"]], + backtrack_causes: Sequence["PreferenceInformation"], ) -> "Preference": """Produce a sort key for given requirement based on preference. The lower the return value is, the more preferred this group of arguments is. - Currently pip considers the followings in order: - - * Prefer if any of the known requirements points to an explicit URL. - * If equal, prefer if any requirements contain ``===`` and ``==``. - * If equal, prefer if requirements include version constraints, e.g. - ``>=`` and ``<``. - * If equal, prefer user-specified (non-transitive) requirements, and - order user-specified requirements by the order they are specified. + Currently pip considers the following in order: + + * Prefer if any of the known requirements is "direct", e.g. points to an + explicit URL. + * If equal, prefer if any requirement is "pinned", i.e. contains + operator ``===`` or ``==``. + * If equal, calculate an approximate "depth" and resolve requirements + closer to the user-specified requirements first. If the depth cannot + by determined (eg: due to no matching parents), it is considered + infinite. + * Order user-specified requirements by the order they are specified. + * If equal, prefers "non-free" requirements, i.e. contains at least one + operator, such as ``>=`` or ``<``. * If equal, order alphabetically for consistency (helps debuggability). """ - - def _get_restrictive_rating(requirements): - # type: (Iterable[Requirement]) -> int - """Rate how restrictive a set of requirements are. - - ``Requirement.get_candidate_lookup()`` returns a 2-tuple for - lookup. The first element is ``Optional[Candidate]`` and the - second ``Optional[InstallRequirement]``. - - * If the requirement is an explicit one, the explicitly-required - candidate is returned as the first element. - * If the requirement is based on a PEP 508 specifier, the backing - ``InstallRequirement`` is returned as the second element. - - We use the first element to check whether there is an explicit - requirement, and the second for equality operator. - """ - lookups = (r.get_candidate_lookup() for r in requirements) - cands, ireqs = zip(*lookups) - if any(cand is not None for cand in cands): - return 0 - spec_sets = (ireq.specifier for ireq in ireqs if ireq) - operators = [ - specifier.operator for spec_set in spec_sets for specifier in spec_set - ] - if any(op in ("==", "===") for op in operators): - return 1 - if operators: - return 2 - # A "bare" requirement without any version requirements. - return 3 - - rating = _get_restrictive_rating(r for r, _ in information[identifier]) - order = self._user_requested.get(identifier, float("inf")) - - # HACK: Setuptools have a very long and solid backward compatibility - # track record, and extremely few projects would request a narrow, - # non-recent version range of it since that would break a lot things. - # (Most projects specify it only to request for an installer feature, - # which does not work, but that's another topic.) Intentionally - # delaying Setuptools helps reduce branches the resolver has to check. - # This serves as a temporary fix for issues like "apache-airlfow[all]" - # while we work on "proper" branch pruning techniques. - delay_this = identifier == "setuptools" - - return (delay_this, rating, order, identifier) + try: + next(iter(information[identifier])) + except StopIteration: + # There is no information for this identifier, so there's no known + # candidates. + has_information = False + else: + has_information = True + + if has_information: + lookups = (r.get_candidate_lookup() for r, _ in information[identifier]) + candidate, ireqs = zip(*lookups) + else: + candidate, ireqs = None, () + + operators = [ + specifier.operator + for specifier_set in (ireq.specifier for ireq in ireqs if ireq) + for specifier in specifier_set + ] + + direct = candidate is not None + pinned = any(op[:2] == "==" for op in operators) + unfree = bool(operators) + + try: + requested_order: Union[int, float] = self._user_requested[identifier] + except KeyError: + requested_order = math.inf + if has_information: + parent_depths = ( + self._known_depths[parent.name] if parent is not None else 0.0 + for _, parent in information[identifier] + ) + inferred_depth = min(d for d in parent_depths) + 1.0 + else: + inferred_depth = math.inf + else: + inferred_depth = 1.0 + self._known_depths[identifier] = inferred_depth + + requested_order = self._user_requested.get(identifier, math.inf) + + # Requires-Python has only one candidate and the check is basically + # free, so we always do it first to avoid needless work if it fails. + requires_python = identifier == REQUIRES_PYTHON_IDENTIFIER + + # Prefer the causes of backtracking on the assumption that the problem + # resolving the dependency tree is related to the failures that caused + # the backtracking + backtrack_cause = self.is_backtrack_cause(identifier, backtrack_causes) + + return ( + not requires_python, + not direct, + not pinned, + not backtrack_cause, + inferred_depth, + requested_order, + not unfree, + identifier, + ) def find_matches( self, @@ -139,8 +201,7 @@ class PipProvider(_ProviderBase): requirements: Mapping[str, Iterator[Requirement]], incompatibilities: Mapping[str, Iterator[Candidate]], ) -> Iterable[Candidate]: - def _eligible_for_upgrade(name): - # type: (str) -> bool + def _eligible_for_upgrade(identifier: str) -> bool: """Are upgrades allowed for this project? This checks the upgrade strategy, and whether the project was one @@ -154,22 +215,41 @@ class PipProvider(_ProviderBase): if self._upgrade_strategy == "eager": return True elif self._upgrade_strategy == "only-if-needed": - return name in self._user_requested + user_order = _get_with_identifier( + self._user_requested, + identifier, + default=None, + ) + return user_order is not None return False + constraint = _get_with_identifier( + self._constraints, + identifier, + default=Constraint.empty(), + ) return self._factory.find_candidates( identifier=identifier, requirements=requirements, - constraint=self._constraints.get(identifier, Constraint.empty()), + constraint=constraint, prefers_installed=(not _eligible_for_upgrade(identifier)), incompatibilities=incompatibilities, ) - def is_satisfied_by(self, requirement, candidate): - # type: (Requirement, Candidate) -> bool + def is_satisfied_by(self, requirement: Requirement, candidate: Candidate) -> bool: return requirement.is_satisfied_by(candidate) - def get_dependencies(self, candidate): - # type: (Candidate) -> Sequence[Requirement] + def get_dependencies(self, candidate: Candidate) -> Sequence[Requirement]: with_requires = not self._ignore_dependencies return [r for r in candidate.iter_dependencies(with_requires) if r is not None] + + @staticmethod + def is_backtrack_cause( + identifier: str, backtrack_causes: Sequence["PreferenceInformation"] + ) -> bool: + for backtrack_cause in backtrack_causes: + if identifier == backtrack_cause.requirement.name: + return True + if backtrack_cause.parent and identifier == backtrack_cause.parent.name: + return True + return False diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py index 074583de..12adeff7 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py +++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py @@ -10,69 +10,71 @@ logger = getLogger(__name__) class PipReporter(BaseReporter): - def __init__(self): - # type: () -> None - self.backtracks_by_package = defaultdict(int) # type: DefaultDict[str, int] + def __init__(self) -> None: + self.reject_count_by_package: DefaultDict[str, int] = defaultdict(int) - self._messages_at_backtrack = { + self._messages_at_reject_count = { 1: ( "pip is looking at multiple versions of {package_name} to " "determine which version is compatible with other " "requirements. This could take a while." ), 8: ( - "pip is looking at multiple versions of {package_name} to " + "pip is still looking at multiple versions of {package_name} to " "determine which version is compatible with other " "requirements. This could take a while." ), 13: ( "This is taking longer than usual. You might need to provide " "the dependency resolver with stricter constraints to reduce " - "runtime. If you want to abort this run, you can press " - "Ctrl + C to do so. To improve how pip performs, tell us what " - "happened here: https://pip.pypa.io/surveys/backtracking" + "runtime. See https://pip.pypa.io/warnings/backtracking for " + "guidance. If you want to abort this run, press Ctrl + C." ), } - def backtracking(self, candidate): - # type: (Candidate) -> None - self.backtracks_by_package[candidate.name] += 1 + def rejecting_candidate(self, criterion: Any, candidate: Candidate) -> None: + self.reject_count_by_package[candidate.name] += 1 - count = self.backtracks_by_package[candidate.name] - if count not in self._messages_at_backtrack: + count = self.reject_count_by_package[candidate.name] + if count not in self._messages_at_reject_count: return - message = self._messages_at_backtrack[count] + message = self._messages_at_reject_count[count] logger.info("INFO: %s", message.format(package_name=candidate.name)) + msg = "Will try a different candidate, due to conflict:" + for req_info in criterion.information: + req, parent = req_info.requirement, req_info.parent + # Inspired by Factory.get_installation_error + msg += "\n " + if parent: + msg += f"{parent.name} {parent.version} depends on " + else: + msg += "The user requested " + msg += req.format_for_error() + logger.debug(msg) + class PipDebuggingReporter(BaseReporter): """A reporter that does an info log for every event it sees.""" - def starting(self): - # type: () -> None + def starting(self) -> None: logger.info("Reporter.starting()") - def starting_round(self, index): - # type: (int) -> None + def starting_round(self, index: int) -> None: logger.info("Reporter.starting_round(%r)", index) - def ending_round(self, index, state): - # type: (int, Any) -> None + def ending_round(self, index: int, state: Any) -> None: logger.info("Reporter.ending_round(%r, state)", index) - def ending(self, state): - # type: (Any) -> None + def ending(self, state: Any) -> None: logger.info("Reporter.ending(%r)", state) - def adding_requirement(self, requirement, parent): - # type: (Requirement, Candidate) -> None + def adding_requirement(self, requirement: Requirement, parent: Candidate) -> None: logger.info("Reporter.adding_requirement(%r, %r)", requirement, parent) - def backtracking(self, candidate): - # type: (Candidate) -> None - logger.info("Reporter.backtracking(%r)", candidate) + def rejecting_candidate(self, criterion: Any, candidate: Candidate) -> None: + logger.info("Reporter.rejecting_candidate(%r, %r)", criterion, candidate) - def pinning(self, candidate): - # type: (Candidate) -> None + def pinning(self, candidate: Candidate) -> None: logger.info("Reporter.pinning(%r)", candidate) diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py index a7fcdd1e..06addc0d 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py +++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py @@ -7,78 +7,63 @@ from .base import Candidate, CandidateLookup, Requirement, format_name class ExplicitRequirement(Requirement): - def __init__(self, candidate): - # type: (Candidate) -> None + def __init__(self, candidate: Candidate) -> None: self.candidate = candidate - def __str__(self): - # type: () -> str + def __str__(self) -> str: return str(self.candidate) - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return "{class_name}({candidate!r})".format( class_name=self.__class__.__name__, candidate=self.candidate, ) @property - def project_name(self): - # type: () -> NormalizedName - # No need to canonicalise - the candidate did this + def project_name(self) -> NormalizedName: + # No need to canonicalize - the candidate did this return self.candidate.project_name @property - def name(self): - # type: () -> str - # No need to canonicalise - the candidate did this + def name(self) -> str: + # No need to canonicalize - the candidate did this return self.candidate.name - def format_for_error(self): - # type: () -> str + def format_for_error(self) -> str: return self.candidate.format_for_error() - def get_candidate_lookup(self): - # type: () -> CandidateLookup + def get_candidate_lookup(self) -> CandidateLookup: return self.candidate, None - def is_satisfied_by(self, candidate): - # type: (Candidate) -> bool + def is_satisfied_by(self, candidate: Candidate) -> bool: return candidate == self.candidate class SpecifierRequirement(Requirement): - def __init__(self, ireq): - # type: (InstallRequirement) -> None + def __init__(self, ireq: InstallRequirement) -> None: assert ireq.link is None, "This is a link, not a specifier" self._ireq = ireq self._extras = frozenset(ireq.extras) - def __str__(self): - # type: () -> str + def __str__(self) -> str: return str(self._ireq.req) - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return "{class_name}({requirement!r})".format( class_name=self.__class__.__name__, requirement=str(self._ireq.req), ) @property - def project_name(self): - # type: () -> NormalizedName + def project_name(self) -> NormalizedName: assert self._ireq.req, "Specifier-backed ireq is always PEP 508" return canonicalize_name(self._ireq.req.name) @property - def name(self): - # type: () -> str + def name(self) -> str: return format_name(self.project_name, self._extras) - def format_for_error(self): - # type: () -> str - + def format_for_error(self) -> str: # Convert comma-separated specifiers into "A, B, ..., F and G" # This makes the specifier a bit more "human readable", without # risking a change in meaning. (Hopefully! Not all edge cases have @@ -91,12 +76,10 @@ class SpecifierRequirement(Requirement): return ", ".join(parts[:-1]) + " and " + parts[-1] - def get_candidate_lookup(self): - # type: () -> CandidateLookup + def get_candidate_lookup(self) -> CandidateLookup: return None, self._ireq - def is_satisfied_by(self, candidate): - # type: (Candidate) -> bool + def is_satisfied_by(self, candidate: Candidate) -> bool: assert candidate.name == self.name, ( f"Internal issue: Candidate is not for this requirement " f"{candidate.name} vs {self.name}" @@ -112,44 +95,36 @@ class SpecifierRequirement(Requirement): class RequiresPythonRequirement(Requirement): """A requirement representing Requires-Python metadata.""" - def __init__(self, specifier, match): - # type: (SpecifierSet, Candidate) -> None + def __init__(self, specifier: SpecifierSet, match: Candidate) -> None: self.specifier = specifier self._candidate = match - def __str__(self): - # type: () -> str + def __str__(self) -> str: return f"Python {self.specifier}" - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return "{class_name}({specifier!r})".format( class_name=self.__class__.__name__, specifier=str(self.specifier), ) @property - def project_name(self): - # type: () -> NormalizedName + def project_name(self) -> NormalizedName: return self._candidate.project_name @property - def name(self): - # type: () -> str + def name(self) -> str: return self._candidate.name - def format_for_error(self): - # type: () -> str + def format_for_error(self) -> str: return str(self) - def get_candidate_lookup(self): - # type: () -> CandidateLookup + def get_candidate_lookup(self) -> CandidateLookup: if self.specifier.contains(self._candidate.version, prereleases=True): return self._candidate, None return None, None - def is_satisfied_by(self, candidate): - # type: (Candidate) -> bool + def is_satisfied_by(self, candidate: Candidate) -> bool: assert candidate.name == self._candidate.name, "Not Python candidate" # We can safely always allow prereleases here since PackageFinder # already implements the prerelease logic, and would have filtered out @@ -160,39 +135,31 @@ class RequiresPythonRequirement(Requirement): class UnsatisfiableRequirement(Requirement): """A requirement that cannot be satisfied.""" - def __init__(self, name): - # type: (NormalizedName) -> None + def __init__(self, name: NormalizedName) -> None: self._name = name - def __str__(self): - # type: () -> str + def __str__(self) -> str: return f"{self._name} (unavailable)" - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return "{class_name}({name!r})".format( class_name=self.__class__.__name__, name=str(self._name), ) @property - def project_name(self): - # type: () -> NormalizedName + def project_name(self) -> NormalizedName: return self._name @property - def name(self): - # type: () -> str + def name(self) -> str: return self._name - def format_for_error(self): - # type: () -> str + def format_for_error(self) -> str: return str(self) - def get_candidate_lookup(self): - # type: () -> CandidateLookup + def get_candidate_lookup(self) -> CandidateLookup: return None, None - def is_satisfied_by(self, candidate): - # type: (Candidate) -> bool + def is_satisfied_by(self, candidate: Candidate) -> bool: return False diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py index b90f82cf..d5b23860 100644 --- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py +++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py @@ -4,19 +4,14 @@ import os from typing import TYPE_CHECKING, Dict, List, Optional, Set, Tuple, cast from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.packaging.version import parse as parse_version from pip._vendor.resolvelib import BaseReporter, ResolutionImpossible from pip._vendor.resolvelib import Resolver as RLResolver from pip._vendor.resolvelib.structs import DirectedGraph from pip._internal.cache import WheelCache -from pip._internal.exceptions import InstallationError from pip._internal.index.package_finder import PackageFinder from pip._internal.operations.prepare import RequirementPreparer -from pip._internal.req.req_install import ( - InstallRequirement, - check_invalid_constraint_type, -) +from pip._internal.req.req_install import InstallRequirement from pip._internal.req.req_set import RequirementSet from pip._internal.resolution.base import BaseResolver, InstallRequirementProvider from pip._internal.resolution.resolvelib.provider import PipProvider @@ -24,11 +19,8 @@ from pip._internal.resolution.resolvelib.reporter import ( PipDebuggingReporter, PipReporter, ) -from pip._internal.utils.deprecation import deprecated -from pip._internal.utils.filetypes import is_archive_file -from pip._internal.utils.misc import dist_is_editable -from .base import Candidate, Constraint, Requirement +from .base import Candidate, Requirement from .factory import Factory if TYPE_CHECKING: @@ -45,17 +37,17 @@ class Resolver(BaseResolver): def __init__( self, - preparer, # type: RequirementPreparer - finder, # type: PackageFinder - wheel_cache, # type: Optional[WheelCache] - make_install_req, # type: InstallRequirementProvider - use_user_site, # type: bool - ignore_dependencies, # type: bool - ignore_installed, # type: bool - ignore_requires_python, # type: bool - force_reinstall, # type: bool - upgrade_strategy, # type: str - py_version_info=None, # type: Optional[Tuple[int, ...]] + preparer: RequirementPreparer, + finder: PackageFinder, + wheel_cache: Optional[WheelCache], + make_install_req: InstallRequirementProvider, + use_user_site: bool, + ignore_dependencies: bool, + ignore_installed: bool, + ignore_requires_python: bool, + force_reinstall: bool, + upgrade_strategy: str, + py_version_info: Optional[Tuple[int, ...]] = None, ): super().__init__() assert upgrade_strategy in self._allowed_strategies @@ -73,65 +65,38 @@ class Resolver(BaseResolver): ) self.ignore_dependencies = ignore_dependencies self.upgrade_strategy = upgrade_strategy - self._result = None # type: Optional[Result] - - def resolve(self, root_reqs, check_supported_wheels): - # type: (List[InstallRequirement], bool) -> RequirementSet - - constraints = {} # type: Dict[str, Constraint] - user_requested = {} # type: Dict[str, int] - requirements = [] - for i, req in enumerate(root_reqs): - if req.constraint: - # Ensure we only accept valid constraints - problem = check_invalid_constraint_type(req) - if problem: - raise InstallationError(problem) - if not req.match_markers(): - continue - assert req.name, "Constraint must be named" - name = canonicalize_name(req.name) - if name in constraints: - constraints[name] &= req - else: - constraints[name] = Constraint.from_ireq(req) - else: - if req.user_supplied and req.name: - canonical_name = canonicalize_name(req.name) - if canonical_name not in user_requested: - user_requested[canonical_name] = i - r = self.factory.make_requirement_from_install_req( - req, requested_extras=() - ) - if r is not None: - requirements.append(r) + self._result: Optional[Result] = None + def resolve( + self, root_reqs: List[InstallRequirement], check_supported_wheels: bool + ) -> RequirementSet: + collected = self.factory.collect_root_requirements(root_reqs) provider = PipProvider( factory=self.factory, - constraints=constraints, + constraints=collected.constraints, ignore_dependencies=self.ignore_dependencies, upgrade_strategy=self.upgrade_strategy, - user_requested=user_requested, + user_requested=collected.user_requested, ) if "PIP_RESOLVER_DEBUG" in os.environ: - reporter = PipDebuggingReporter() # type: BaseReporter + reporter: BaseReporter = PipDebuggingReporter() else: reporter = PipReporter() - resolver = RLResolver( + resolver: RLResolver[Requirement, Candidate, str] = RLResolver( provider, reporter, - ) # type: RLResolver[Requirement, Candidate, str] + ) try: - try_to_avoid_resolution_too_deep = 2000000 + limit_how_complex_resolution_can_be = 200000 result = self._result = resolver.resolve( - requirements, max_rounds=try_to_avoid_resolution_too_deep + collected.requirements, max_rounds=limit_how_complex_resolution_can_be ) except ResolutionImpossible as e: error = self.factory.get_installation_error( cast("ResolutionImpossible[Requirement, Candidate]", e), - constraints, + collected.constraints, ) raise error from e @@ -150,10 +115,10 @@ class Resolver(BaseResolver): elif self.factory.force_reinstall: # The --force-reinstall flag is set -- reinstall. ireq.should_reinstall = True - elif parse_version(installed_dist.version) != candidate.version: + elif installed_dist.version != candidate.version: # The installation is different in version -- reinstall. ireq.should_reinstall = True - elif candidate.is_editable or dist_is_editable(installed_dist): + elif candidate.is_editable or installed_dist.editable: # The incoming distribution is editable, or different in # editable-ness to installation -- reinstall. ireq.should_reinstall = True @@ -169,25 +134,6 @@ class Resolver(BaseResolver): ) continue - looks_like_sdist = ( - is_archive_file(candidate.source_link.file_path) - and candidate.source_link.ext != ".zip" - ) - if looks_like_sdist: - # is a local sdist -- show a deprecation warning! - reason = ( - "Source distribution is being reinstalled despite an " - "installed package having the same name and version as " - "the installed package." - ) - replacement = "use --force-reinstall" - deprecated( - reason=reason, - replacement=replacement, - gone_in="21.2", - issue=8711, - ) - # is a local sdist or path -- reinstall ireq.should_reinstall = True else: @@ -213,10 +159,14 @@ class Resolver(BaseResolver): reqs = req_set.all_requirements self.factory.preparer.prepare_linked_requirements_more(reqs) + for req in reqs: + req.prepared = True + req.needs_more_preparation = False return req_set - def get_installation_order(self, req_set): - # type: (RequirementSet) -> List[InstallRequirement] + def get_installation_order( + self, req_set: RequirementSet + ) -> List[InstallRequirement]: """Get order for installation of requirements in RequirementSet. The returned list contains a requirement before another that depends on @@ -224,17 +174,19 @@ class Resolver(BaseResolver): get installed one-by-one. The current implementation creates a topological ordering of the - dependency graph, while breaking any cycles in the graph at arbitrary - points. We make no guarantees about where the cycle would be broken, - other than they would be broken. + dependency graph, giving more weight to packages with less + or no dependencies, while breaking any cycles in the graph at + arbitrary points. We make no guarantees about where the cycle + would be broken, other than it *would* be broken. """ assert self._result is not None, "must call resolve() first" + if not req_set.requirements: + # Nothing is left to install, so we do not need an order. + return [] + graph = self._result.graph - weights = get_topological_weights( - graph, - expected_node_count=len(self._result.mapping) + 1, - ) + weights = get_topological_weights(graph, set(req_set.requirements.keys())) sorted_items = sorted( req_set.requirements.items(), @@ -244,29 +196,38 @@ class Resolver(BaseResolver): return [ireq for _, ireq in sorted_items] -def get_topological_weights(graph, expected_node_count): - # type: (DirectedGraph[Optional[str]], int) -> Dict[Optional[str], int] +def get_topological_weights( + graph: "DirectedGraph[Optional[str]]", requirement_keys: Set[str] +) -> Dict[Optional[str], int]: """Assign weights to each node based on how "deep" they are. This implementation may change at any point in the future without prior notice. - We take the length for the longest path to any node from root, ignoring any - paths that contain a single node twice (i.e. cycles). This is done through - a depth-first search through the graph, while keeping track of the path to - the node. + We first simplify the dependency graph by pruning any leaves and giving them + the highest weight: a package without any dependencies should be installed + first. This is done again and again in the same way, giving ever less weight + to the newly found leaves. The loop stops when no leaves are left: all + remaining packages have at least one dependency left in the graph. + + Then we continue with the remaining graph, by taking the length for the + longest path to any node from root, ignoring any paths that contain a single + node twice (i.e. cycles). This is done through a depth-first search through + the graph, while keeping track of the path to the node. Cycles in the graph result would result in node being revisited while also - being it's own path. In this case, take no action. This helps ensure we + being on its own path. In this case, take no action. This helps ensure we don't get stuck in a cycle. When assigning weight, the longer path (i.e. larger length) is preferred. + + We are only interested in the weights of packages that are in the + requirement_keys. """ - path = set() # type: Set[Optional[str]] - weights = {} # type: Dict[Optional[str], int] + path: Set[Optional[str]] = set() + weights: Dict[Optional[str], int] = {} - def visit(node): - # type: (Optional[str]) -> None + def visit(node: Optional[str]) -> None: if node in path: # We hit a cycle, so we'll break it here. return @@ -277,24 +238,57 @@ def get_topological_weights(graph, expected_node_count): visit(child) path.remove(node) + if node not in requirement_keys: + return + last_known_parent_count = weights.get(node, 0) weights[node] = max(last_known_parent_count, len(path)) + # Simplify the graph, pruning leaves that have no dependencies. + # This is needed for large graphs (say over 200 packages) because the + # `visit` function is exponentially slower then, taking minutes. + # See https://github.com/pypa/pip/issues/10557 + # We will loop until we explicitly break the loop. + while True: + leaves = set() + for key in graph: + if key is None: + continue + for _child in graph.iter_children(key): + # This means we have at least one child + break + else: + # No child. + leaves.add(key) + if not leaves: + # We are done simplifying. + break + # Calculate the weight for the leaves. + weight = len(graph) - 1 + for leaf in leaves: + if leaf not in requirement_keys: + continue + weights[leaf] = weight + # Remove the leaves from the graph, making it simpler. + for leaf in leaves: + graph.remove(leaf) + + # Visit the remaining graph. # `None` is guaranteed to be the root node by resolvelib. visit(None) - # Sanity checks - assert weights[None] == 0 - assert len(weights) == expected_node_count + # Sanity check: all requirement keys should be in the weights, + # and no other keys should be in the weights. + difference = set(weights.keys()).difference(requirement_keys) + assert not difference, difference return weights def _req_set_item_sorter( - item, # type: Tuple[str, InstallRequirement] - weights, # type: Dict[Optional[str], int] -): - # type: (...) -> Tuple[int, str] + item: Tuple[str, InstallRequirement], + weights: Dict[Optional[str], int], +) -> Tuple[int, str]: """Key function used to sort install requirements for installation. Based on the "weight" mapping calculated in ``get_installation_order()``. diff --git a/env/Lib/site-packages/pip/_internal/self_outdated_check.py b/env/Lib/site-packages/pip/_internal/self_outdated_check.py index 6b24965b..41cc42c5 100644 --- a/env/Lib/site-packages/pip/_internal/self_outdated_check.py +++ b/env/Lib/site-packages/pip/_internal/self_outdated_check.py @@ -1,97 +1,149 @@ import datetime +import functools import hashlib import json import logging import optparse import os.path import sys -from typing import Any, Dict +from dataclasses import dataclass +from typing import Any, Callable, Dict, Optional from pip._vendor.packaging.version import parse as parse_version +from pip._vendor.rich.console import Group +from pip._vendor.rich.markup import escape +from pip._vendor.rich.text import Text from pip._internal.index.collector import LinkCollector from pip._internal.index.package_finder import PackageFinder from pip._internal.metadata import get_default_environment +from pip._internal.metadata.base import DistributionVersion from pip._internal.models.selection_prefs import SelectionPreferences from pip._internal.network.session import PipSession +from pip._internal.utils.compat import WINDOWS +from pip._internal.utils.entrypoints import ( + get_best_invocation_for_this_pip, + get_best_invocation_for_this_python, +) from pip._internal.utils.filesystem import adjacent_tmp_file, check_path_owner, replace from pip._internal.utils.misc import ensure_dir -SELFCHECK_DATE_FMT = "%Y-%m-%dT%H:%M:%SZ" +_DATE_FMT = "%Y-%m-%dT%H:%M:%SZ" logger = logging.getLogger(__name__) -def _get_statefile_name(key): - # type: (str) -> str +def _get_statefile_name(key: str) -> str: key_bytes = key.encode() name = hashlib.sha224(key_bytes).hexdigest() return name class SelfCheckState: - def __init__(self, cache_dir): - # type: (str) -> None - self.state = {} # type: Dict[str, Any] - self.statefile_path = None + def __init__(self, cache_dir: str) -> None: + self._state: Dict[str, Any] = {} + self._statefile_path = None # Try to load the existing state if cache_dir: - self.statefile_path = os.path.join( + self._statefile_path = os.path.join( cache_dir, "selfcheck", _get_statefile_name(self.key) ) try: - with open(self.statefile_path, encoding="utf-8") as statefile: - self.state = json.load(statefile) + with open(self._statefile_path, encoding="utf-8") as statefile: + self._state = json.load(statefile) except (OSError, ValueError, KeyError): # Explicitly suppressing exceptions, since we don't want to # error out if the cache file is invalid. pass @property - def key(self): - # type: () -> str + def key(self) -> str: return sys.prefix - def save(self, pypi_version, current_time): - # type: (str, datetime.datetime) -> None + def get(self, current_time: datetime.datetime) -> Optional[str]: + """Check if we have a not-outdated version loaded already.""" + if not self._state: + return None + + if "last_check" not in self._state: + return None + + if "pypi_version" not in self._state: + return None + + seven_days_in_seconds = 7 * 24 * 60 * 60 + + # Determine if we need to refresh the state + last_check = datetime.datetime.strptime(self._state["last_check"], _DATE_FMT) + seconds_since_last_check = (current_time - last_check).total_seconds() + if seconds_since_last_check > seven_days_in_seconds: + return None + + return self._state["pypi_version"] + + def set(self, pypi_version: str, current_time: datetime.datetime) -> None: # If we do not have a path to cache in, don't bother saving. - if not self.statefile_path: + if not self._statefile_path: return # Check to make sure that we own the directory - if not check_path_owner(os.path.dirname(self.statefile_path)): + if not check_path_owner(os.path.dirname(self._statefile_path)): return # Now that we've ensured the directory is owned by this user, we'll go # ahead and make sure that all our directories are created. - ensure_dir(os.path.dirname(self.statefile_path)) + ensure_dir(os.path.dirname(self._statefile_path)) state = { # Include the key so it's easy to tell which pip wrote the # file. "key": self.key, - "last_check": current_time.strftime(SELFCHECK_DATE_FMT), + "last_check": current_time.strftime(_DATE_FMT), "pypi_version": pypi_version, } text = json.dumps(state, sort_keys=True, separators=(",", ":")) - with adjacent_tmp_file(self.statefile_path) as f: + with adjacent_tmp_file(self._statefile_path) as f: f.write(text.encode()) try: # Since we have a prefix-specific state file, we can just # overwrite whatever is there, no need to check. - replace(f.name, self.statefile_path) + replace(f.name, self._statefile_path) except OSError: # Best effort. pass -def was_installed_by_pip(pkg): - # type: (str) -> bool +@dataclass +class UpgradePrompt: + old: str + new: str + + def __rich__(self) -> Group: + if WINDOWS: + pip_cmd = f"{get_best_invocation_for_this_python()} -m pip" + else: + pip_cmd = get_best_invocation_for_this_pip() + + notice = "[bold][[reset][blue]notice[reset][bold]][reset]" + return Group( + Text(), + Text.from_markup( + f"{notice} A new release of pip is available: " + f"[red]{self.old}[reset] -> [green]{self.new}[reset]" + ), + Text.from_markup( + f"{notice} To update, run: " + f"[green]{escape(pip_cmd)} install --upgrade pip" + ), + ) + + +def was_installed_by_pip(pkg: str) -> bool: """Checks whether pkg was installed by pip This is used not to display the upgrade message when pip is in fact @@ -101,8 +153,69 @@ def was_installed_by_pip(pkg): return dist is not None and "pip" == dist.installer -def pip_self_version_check(session, options): - # type: (PipSession, optparse.Values) -> None +def _get_current_remote_pip_version( + session: PipSession, options: optparse.Values +) -> Optional[str]: + # Lets use PackageFinder to see what the latest pip version is + link_collector = LinkCollector.create( + session, + options=options, + suppress_no_index=True, + ) + + # Pass allow_yanked=False so we don't suggest upgrading to a + # yanked version. + selection_prefs = SelectionPreferences( + allow_yanked=False, + allow_all_prereleases=False, # Explicitly set to False + ) + + finder = PackageFinder.create( + link_collector=link_collector, + selection_prefs=selection_prefs, + ) + best_candidate = finder.find_best_candidate("pip").best_candidate + if best_candidate is None: + return None + + return str(best_candidate.version) + + +def _self_version_check_logic( + *, + state: SelfCheckState, + current_time: datetime.datetime, + local_version: DistributionVersion, + get_remote_version: Callable[[], Optional[str]], +) -> Optional[UpgradePrompt]: + remote_version_str = state.get(current_time) + if remote_version_str is None: + remote_version_str = get_remote_version() + if remote_version_str is None: + logger.debug("No remote pip version found") + return None + state.set(remote_version_str, current_time) + + remote_version = parse_version(remote_version_str) + logger.debug("Remote version of pip: %s", remote_version) + logger.debug("Local version of pip: %s", local_version) + + pip_installed_by_pip = was_installed_by_pip("pip") + logger.debug("Was pip installed by pip? %s", pip_installed_by_pip) + if not pip_installed_by_pip: + return None # Only suggest upgrade if pip is installed by pip. + + local_version_is_older = ( + local_version < remote_version + and local_version.base_version != remote_version.base_version + ) + if local_version_is_older: + return UpgradePrompt(old=str(local_version), new=remote_version_str) + + return None + + +def pip_self_version_check(session: PipSession, options: optparse.Values) -> None: """Check for an update for pip. Limit the frequency of checks to once per week. State is stored either in @@ -113,75 +226,17 @@ def pip_self_version_check(session, options): if not installed_dist: return - pip_version = installed_dist.version - pypi_version = None - try: - state = SelfCheckState(cache_dir=options.cache_dir) - - current_time = datetime.datetime.utcnow() - # Determine if we need to refresh the state - if "last_check" in state.state and "pypi_version" in state.state: - last_check = datetime.datetime.strptime( - state.state["last_check"], - SELFCHECK_DATE_FMT - ) - if (current_time - last_check).total_seconds() < 7 * 24 * 60 * 60: - pypi_version = state.state["pypi_version"] - - # Refresh the version if we need to or just see if we need to warn - if pypi_version is None: - # Lets use PackageFinder to see what the latest pip version is - link_collector = LinkCollector.create( - session, - options=options, - suppress_no_index=True, - ) - - # Pass allow_yanked=False so we don't suggest upgrading to a - # yanked version. - selection_prefs = SelectionPreferences( - allow_yanked=False, - allow_all_prereleases=False, # Explicitly set to False - ) - - finder = PackageFinder.create( - link_collector=link_collector, - selection_prefs=selection_prefs, - ) - best_candidate = finder.find_best_candidate("pip").best_candidate - if best_candidate is None: - return - pypi_version = str(best_candidate.version) - - # save that we've performed a check - state.save(pypi_version, current_time) - - remote_version = parse_version(pypi_version) - - local_version_is_older = ( - pip_version < remote_version and - pip_version.base_version != remote_version.base_version and - was_installed_by_pip('pip') - ) - - # Determine if our pypi_version is older - if not local_version_is_older: - return - - # We cannot tell how the current pip is available in the current - # command context, so be pragmatic here and suggest the command - # that's always available. This does not accommodate spaces in - # `sys.executable`. - pip_cmd = f"{sys.executable} -m pip" - logger.warning( - "You are using pip version %s; however, version %s is " - "available.\nYou should consider upgrading via the " - "'%s install --upgrade pip' command.", - pip_version, pypi_version, pip_cmd + upgrade_prompt = _self_version_check_logic( + state=SelfCheckState(cache_dir=options.cache_dir), + current_time=datetime.datetime.utcnow(), + local_version=installed_dist.version, + get_remote_version=functools.partial( + _get_current_remote_pip_version, session, options + ), ) + if upgrade_prompt is not None: + logger.warning("[present-rich] %s", upgrade_prompt) except Exception: - logger.debug( - "There was an error checking the latest version of pip", - exc_info=True, - ) + logger.warning("There was an error checking the latest version of pip.") + logger.debug("See below for error", exc_info=True) diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 2997301191e1b1b23f4222c74ddc7258de73b129..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 219 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<YH+rS z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP p%1g}AFD=Q;Db|mV&&<m#iI3MSsJz8tlbfGXnv-e=a@l8)4*;c^I<No$ diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-39.pyc deleted file mode 100644 index fa92e190af6935c1655f39a0ffe775e7213df4c5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1284 zcmYe~<>g{vU|^UdaWM553j@Pr5C<7EGcYhXFfcF_J25aYq%cG=q%fv1<uFDurZA>3 z=P>0mM=>*k#8`4za#^F;7#UJnQ`lM<qS#Y-QaDmLTNtA_Qn*sMTNt7^Q<#DoG<mCj za)o4M7Aqv@r=%*B7bO-HE0koUDwL(>rQ{c-rYIy96r^Mp6)WWCr<CTTDwO0a6z79g z6s4Aw7Ue0FCFYc-7AqtcrE(?b=N2TEWG3aLDx~EXffXf}78RxDl_(Ts7C>xBN-R#* z<Kha*NL9$pD@n~O$;{7F$Sek#Ta;Q}lv$Fh0Mk=ioS2?ktdL%mm{OXUlT)dqke!-Z zkeQbbHn}9VxTIL2AhEbuhbu8JMIp5;HLnD$P9dczzd)e`<f+88lGGxF#GD)js9}jk zsS3#%iFxU%DSBKlK>_Qh$#{#!C$qRjlkpZi)U(NqAQ>nIu~`@x7@R?&&d0#OP{NSK zSOW@Ure078GW)q{GT!1$EGS4UEy>6)(qy{D5f3%!7GG&`YEgW0Vsb`md`e~!)Q-Hw z+|-o}MH~za48Q7~tztrpQ;UjYQgc!=i(>rqQeBEN%Tg6|6+-<y!(4-cJwqIW6+Hc1 z{QX>mJso3$U431HLtKLt%whrpd}0z!baV34GmA?yvtv^8%3^#nlVXZ9OHy?U5|gt* z0T@$|S)d;e3hbi1#2o$7lFXc9eW?5N3Mz}(7#JA%L4IQbd6)^z4@m}dKmrU544^c} z3JU=bq!6fKOkwI}u4O7=$YM%i&SoldDPhiHS-@Juw2-kF!e&chS;$z+RKoz3W3OSV zVOYpi%TxmjJ61n8O{OAH=-y&4%1_MA%uBz;mXcUho|#w0Rj03)oS&DLnXa$NQ3SI8 z7C$63!GfURyv0^rSzMBudy6T*_!dh+VoAm=*39CR%%WRdsTBo@c_|?Ew^*|BGxIc= zi`W?$7>Yo-s|e&>aOgt_PLKo-0|SEyC>THt1||VUF-9In7DhhCB9H(|iU5TT$UWc` zVT2SODNHHMz09?Y;P7B6V=U6CVO+pm!ji?hkTHcdol%@2n4yL-oiUg}lg-a91m<<l z+|rzqOpx<6nQpO`XXY6j6>&2#FjTSVr<NpZvOzr$iq&{Xh=4p_#LK|IaErCLASbh= z2$U{wv4e~#PA$-60{itATS{h8Sz->vlc2;_1oG)E0W^b(6+qqw$%DMj#U#X7B+0<Q zpvf4b$#si8K0YNsIX)g@16xTYC<7LOLf{s6L1uwoJfxr~0;LhKJHhD(9A;oskSqt; g0C53_O)j`Ju><9;Vo><9aBwj4F!3;RuyXML0Ae>xK>z>% diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/compat.cpython-39.pyc deleted file mode 100644 index 00817bf20d6db4842b9ce3ba876a0945676173be..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1486 zcmYe~<>g{vU|^UdaWJ)loq^#oh=Yuo85kHG7#J9evlti{QW&BbQW#U1au}l+!8B78 z6PRX>VoqmBVP3=-#gfXnfHjqEA!8JK3QG!W3quq~3R?<$3qurV215$RV#X-0ROT%1 z1w1L73mFSiK<pH*Y^MB_RHiK66z*)MD83Y?U<OT|D(~Qu(zG;%l8nR>g_O*+wA7+v zh0HuCGc~V7A)vA(BR@}}EVZaOGe56bAu%sSp&%!*BrU%vmn$W+xTGjEsk8(nrS}r# zB|lB(TRiEhCGiD`B^mLhnJKrpi%U{+GLzy9veS!iv4?y5x%h_%Cxg_&FcSj<0|x^G zgEJ@yj2IXgs`yeEQy6j>Y8k>AKn`VLC}FHrU}ONnNQOKn15f}l=P>0m*D^9P)G!7! zXtMYfF)}bPglIC};_(cQ4~X;+aP<og_R(ay#S&j!oO6rYGq)hWsKm9XD8J~IL_ubO zUVK?<UP^wEUTINIPG*v^UTH~YP7x~u1A``05gP*o1DL&%p@@@#f#Fx3vsFxJacWU< zOlnR_W>JiPUaCt`W?8C&u0p7vXP9eHuxE&4umZ?;ey+iujxoWmzOKO`u0aZBF#!QS zF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylBsk#M;$=QkNsl_n`nFadsnRz9tMR|!i`XI*? z>nG>u79^JF6;$40&qyqeFUcw91BDTYU|?cm<X~cB<Y8oE;$bS{W?*1Q2894DP(f)5 z<QZ_FCNVHDlrWSqrZ6@$6`7SVE?}x*C}GTEE@8}Kabj4=RLfYxxPY~WaUo+CTP;%w z;{tXNn~@<;ql7VwV*zIk!$QX5fD*<9Tp$)mO&(tfcMZdAh7_i`OwEi<j5VP2#GI(f z$iTp*prD`-lv+|+l&1hn1?t5LrI{&uTwrmR{M2HFy!;Y{wEUc${Bnij%G{jHyzF8t zuq;StMoCFQv6a4ldS*#RX_8)Yey)B&WkI4oD0~V^b8_@8jZKwPGK-T-i$O^;zR1+r zz}&#V7-D`vPGWLuib6?7X0bwAX<jlYX@XKTBqSA5N>dd|^5N+_Iki|JKTpBYGXj*b z!A|f3CwLu5mMG51FU?6&NG(gvD=AIP$*ELG&sRt+PppLc#;PbWvpBU_!9N(BuB;To zGg2X*R>&+?NQC)LA-_l=IWbSYL?J0vp(r&mMGtJ%EiV6fKYurWA0PklDt#0k)(YX7 zIXU2fDuRS$X=aK-T7D7C$YM<%aGFRgDJi<elwW*{CBGmw?-qxDe2|O3pHE~F4+8_k zE!MQ+lEji*Y{ezutjL<2lV6;Aiv<)bx7ad^K_P#O1+0V}>IF^aA`y^IrnHn>9BG+3 zsUVHuEC3-u1z8a&!^(gXq5vqh@p3VWF!C_+F!M0+G4nBkW$i%8?-qM`ae8J^YT7N1 z#G>?q#G>NVTWkg3@V&)co|$)xIXNfu7E@k{CjTw=`1q9k<oNho>^b@A>6v-yMW94} zi@CV67$ldNlM^3*i!(j7#3w&JJ+<f-M|^x<Vs2`D{4F++hSVZ(4glL-1h$(4R!ZIC zDlSPZDk(0{EXlaV0@75(0?OT>Yz^@fm<96KEe@O9{FKt1R69^kDi&g3U|?b9VB}!r QVB%orV&>rEP~>0%0G4^4O#lD@ diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/compatibility_tags.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/compatibility_tags.cpython-39.pyc deleted file mode 100644 index e8b73ef46e18441ca00f37a2447dde87cd82b284..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3862 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 WVB-+w5aZzC5aQtA;$mO~!#@D|tH;s+ diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-39.pyc deleted file mode 100644 index 5ae87dd241b31dc256f46cf157006f7374700288..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 490 zcmYe~<>g{vU|^UdaWM5i0|Ucj5C<7EF)%PVFfcF_OE54nq%cG=q%fv1<uFDurZA_l zv@k?5r7#6EXtGx6x#brrlxL*oDHLQDD3mAWl@u$K<SQg+q$X!8lw_nTq$HN4D&!X_ zlw{_n>T$gU+2NPW45FZzm4Sf)gq=aQDKIcFlrUs5E?`>7P|IAxuz<0Kp@y-BX(4kh zOAT`kOEya|gC?V&Ci5*0kij5BZ?S+_w^&Q^QxYpRS#PmarY08MV$IFZE6KRUoRU~s z#KOS9aEmoPvn(}lB|{M>0|Uda24}07(Bjmh;+WK&l+2<S|GZR}qRg^X1zm+uKhH4N zpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>AO*9SfB>JEL=)Yd{PfJ?lFaOw)V#77pUk9~ z;>?m%-GapA?8Nlc;+TTW0{!^Rypq(Syu=*+(vr-aVttT9K~B~ysJtZ%c5i%UaePi< zNorAiNk(EGJ17X)K;go~#mL80#Ld9KpvioTJw84qKRG_W2oxz`L9i!~2vA(!;;_lh TPbtkwwPOSs1M)NrGY2yO5JP{Q diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-39.pyc deleted file mode 100644 index f87f203a1a780bafa8cdf38ab185f83a93683611..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2785 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 I66N3l0JTL9Q~&?~ diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-39.pyc deleted file mode 100644 index d624dbad272b2a43a6082a5bbef9d23c32568e4a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2539 zcmYe~<>g{vU|^UdaWFNWpMl{qh=Yuo85kHG7#J9eI~W)kQW#Pga~Pr^G-DKF3PTE0 z4pT036f+}8j5&uTmo<tN%x1}9%Vm#Z&*g~X$mNXU%;k#W%H@vY&gF^X0n4-I@aFPG z@qyWFIsCZ-Q38w%sf-H*Q-u~XMhT~|r*O0|M2V#ErEsNiw=hPDrtqZjwlGAAr7#9F zX!5@VxzSIP@fL@FK}lwQUSf_W<1HSS%;J)w%%oC~h$h=D2^Y^GSLcxU&>)|9U)K;v z7sn9Cct1y9*IV3<MadbNWvQNdY5BJ}T{4SOlS@L2a&Ae$nPG`JnJI}NgItS>@{4Y< zyJQxDRkMdB7lRm@jJH^PGV`)E8E-L{B^M_%fm{T|EDQ_`Yzzzx&Y*zX#=yW(!?1v1 zAp;{r4Py$UI72N{IzugU31baI7E=jxGgFaW4O0r!0u~TIi?xO!iw(?TU&w6EP|K9( z0aeM-%v6+9!vvBCiG$T}7PZwdFW`c(7cw$3<VitQb2l>;*LX2BF{0?;DVhUPpTb<j zki{d;0Mb#zT(qf%DTO74bpdY;^Fl^(2C(T&!3>&gRR+%ad1a|ZB?^fO@SssB$yZ2J zD99{OC`v6X%`8gIP0cG&0EK*Bx?UBtf`dX8M|G`sb*)2nZ53~EX;KO}eDjMcZGSN; z|6)|r<h#XD1_|HPTU?pNnR&$}iFwJXw^%as((;Qq85kIDv8Ck~<tCOCaf3L_rA0Zn zIFs{pb2CfgGgFFKL4qt9iNzVW*b)m0Qu9)ZI6y)?$d=t=$;!{n(`32D1+hOKWC%-M zVs7d!ZX}1_;!G<_Ob2<PcqK!T3<CqhuP$e+n9$<XqT-m;oRrL>82`Lfm!izFR0Umy zP(RNw*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!klnAE(o z7@y3fnBvTmRNaEa<m|-s)Z&<e%mV%R%)FA+qP)Z${nC=moML^1E8{a#a|%+6iuDRA zZ>b^)Cl<#Sq!yT%7{o&bi&E24i&FEFQ$;}uO$C(tm^m0Z7+Dy37}*#F{&O(%Fmf?+ zFbXgUFmi!J7+DyF7>nc>7#Q4=K{*?w1B5|k06Q$f9s(!WEQX?-62=9f<i@;^v6i`p zxmXIEoS4B0m31Lw40A0@Eo&`X4JZM#7F&R2S!>zzglZUz-M~EN1#C5p3mI$KOW12z zN;qnmvp8$mYgkhldqD}1D}||-IT(~VxEC@Mb(FBzFl4co@H8{jFl0gHQW$DEY8bM3 zYdLE;i<Z@J&Sn57UB1~2bD3*7pgQ<#I8s=8LD>neE0{r()lZWdoP3IeL1{w>6z8eM zC8;U#MX6<(#hLken#@H)3=9lK0w6*R6!VO>nv6vv3=9mK0=L*Qi{s0Zi@`?R5=&1l ziBC#Q&Q8rsiBHQfiZ4#iNX<>X#RjECK=P$UIUuv+6Z2By6H7}nZi#?I$}>wc@=HtN zVae<k4@fP{4Mm`G0-WTFBtgy;MNYy9J^Y!)@u?M{B$byAihW3W=LBVecu<lCI~trX zG`ViE<YeY$-{LCHFD*(=1*yIz1`>(SERN62i!aYeP0fi<PE5{7y~SOYTnzITBrN1X zj$n)jhZ)3BO;G57@&!0^6v=`Vh(Hq{$bV@?`ML2R^L0Uq&<&KFnAjM3z{!y1KNkxN z8wVpBD+ePNBNG_1fXKfrtSmp-I5`-Z7+FB@FB=;RBO4<NqX1ZhgOTNLkv;<hLoy@C zJSYYgv7nR+E>_dPsdNED3FAV>Vm?r<P$g8tw1ByWVF3$BY$0PfLofpiLkVjMTNZl> zM;dcw0wY5$BO^nVLJ8*rt`sJ4LCIaixR8aBA)FzSA%(G)v5paB5`<;IV88(4X);%> z@=q#B%*;b61wsA>m4n&o@kObSu+~Gafb_Vy6ciK`f>KLLi}H#U{POcs6*AKlN-|Ov zQjqE?g^a{vg}i))1VoVPWfkY=B`D;kmL#SmmL%$c&B-qU>Bdx*S*(zm2QE$Z!0P;} zq`@_oLP26tab{k+f@-lsT7Hp&YO$4qYOyBIEuM_T;&_<ZMWCt*oCZPVV18~q$ZALm zg)0FS47XUo68v7l{(dg0$@wX%U`uWZh2~{~c*tUGIr-`7sYSQg%M*+8GV{`J@e~y0 zXQd{WfK#d_(=8T||8Fs-LJ|}>X@OIfFi1Qelsgb%5f4gK3ZMkQ&cz5yIzpi217iK< zVFmF)35e+r3tN#jDBCjmxoL_Q8H3U&JIEOz>)A>w3o`T4i$KZemSjO@fnI!BYF<iy zkzN5(+!Ysr3dCFTV0l>4te2aglA2Sjhj0%hz(5rcIMj+jfdkHr;5-a99$h;qcNBqA z?kz!7<Kg8CXL@Rh4<y();=$n*A75k!%6Xu|8k`lt9z+T<M7VL-<mRW8=A_zzGD|V2 Y_ySb|JWM=H3LHF)JWO2791>hc00|_#m;e9( diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/distutils_args.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/distutils_args.cpython-39.pyc deleted file mode 100644 index 22d93b2e905cf9ed1b6af5e7835d5f69efdfd641..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1084 zcmYe~<>g{vU|^UdaWM5A3j@Pr5C<7EF)%PVFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0 zxy(__U^a6OOD<~^Yc5+98zVzHLki0x#whkw=2Z4(#wd;y))clDhA7Sy_Fx80j+Y?w zH5qRSx?~oYl$K=X6gw8ByA~DY7iluy;&w~SORjWJEy*t^(PX;C;*yzMa*M?$v$#Z) zN0YgVC$%CqS+}4lH7&Ek*6$XBCUX^QMt*LptzQuv0|SW5o0(T!l9-dDo0M3LO*kd7 zBoU!n0H!)4H8CZ%s2Cx`1Cz<gOhSml)feO>mf(;nElR~MQ=D9sSx|yx2RqCoFvqhN z<>!~cZM(%%TAW%0@mVq>DAb^sm4ShQlYxQ385A)d3=9mJ47H3k3@!|@R<%r3VkHb& zj5SQ@j46!0j4@2L%(X1x40%E<3?)pJCX5Uq7|Bq`VZczsxPZBaC5vStBO^m0M-5{z zgC<i|T|i<{ajHT=QGQuwN@|KiVo`c&Zfaghv5rDfYDsBPUS?jpLSmjmeo|Iya*0Ao zMq-IVMq;r-Nk%G{f`WoVZemGt2C_aqF0i;`UZp~5UUpu7c^<+{g~Xy%h0OH4{G!wp zJ+LxO##=0jMd`(wthWT?Q(y@sJ{_DOZm~h=B2cQl#a3F7l30>@iz7ZhB{R7sK3<cx zh=YNF;TBs_YH?{!$t~u@qV!vg@wZsPZd%DuB*?(P@T<+)DkiizwWv5IH76yrD8@f8 z)ukx2ELA~QA=J+^%rz+3GsH1i!PC#h-_JGJ(=jI4)z>vR#5G94EG8hpCnnKEHzz+m zv$!NPJ0>-+EXF4@DW*8HBvrQ{F*!RiJ+(NdAhSR}J~OW*wJ0w!M<1NR^$}hH`A)B( z@|H*eD4>!22$GNl#i#%%n%P+xIT)E3#Ta>5*qHbji-Z{%82mK3ZVA9m(n|&9nPNy_ zh#`d2Ksg8+Vnxj004b>~$jnPGVqsulC;}y(TO9HE1tppJdBsJbbObgW96CsZ5J)G7 cO>TZlX-=vgDESqGiV7Y^9!3Es4nYoP0D@{N<^TWy diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-39.pyc deleted file mode 100644 index 5f905df6bc2cc5f1a6aca28c3698c201a885b9fa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1249 zcmYe~<>g{vU|^UdaWHim3j@Pr5C<7^FfcGUFfcF_H!(0Uq%fo~<}gG-XvQc;FrO)k z2~0CbF{d!3Fy*l1vPQAyvPH2mGNdwOv8OPnF{LtOaip+-Y0eZ@FwK?12Bx`F*ugYU z3I~|xP2o&qN@tJaOJ!QXpTf0}F-jnXJB6o(AxbcXF_=M<_a(@6ews|TSbQ>zOK!1- zlosTqR<V|rr0H5zv4JQ<vnoyqt(%kzXXd0rWQ~m=LdHgLSz{yJoYZ151_p-Y{FKbR z^k^&F*qCB1jcDDNa=ln>&16Q9olwlmz`y{)&Y(cq#K6E%!r;OXs}sXi%UH`)!?1v{ zhH)Wd5lan22~!PYGh+&4E0ZL{0_GZ~g^WxLj10jHg)B7;3s_Q^7BZ$VrZ9tKT^M3R zYME=8Q&>`1LHrc9Y^EZY64nK5HOvbc5v*F48kQ8sQpVy6FNP+@8kPm@3mH;aK&Gd# zFND~RY>!I~!vf|Kjs=`4919r>)|GHA;9khE5EO`<Rb9>*sma+2i3&-TC8@;<#U(|V zdFcvi`9%te3QqpM3MKgp$@xV^smUcdl?o}TC8^0J3MCn-3aNRJAmZXuP*6~COU%hh zN=(iMDbLAIPRvQwOHVB+C`wIBEh<V)fhpE-OUx-w)l|sI%uZFvFG$VP&{W9JQwXRm z$;i($_WKM9Uapr+3=9lKAm&RD0Txug#hO^0oSEsS$#aXv$=^5l7FTgeVo^zPd1gt* zE#{omyjyH3smb{%skc~*3vx0`ZgIQ%Is3bK`nkskx!z(cPE9OI&bY;vUX)*2P<)FG z;>KGd*c^F_xwx|UmQZ?XNlI#3VrfnZ%=MbAw^&jVOA>D}C*|kf;(!U?V#&$OOTEQb zlv-SxQ?inwNQ!}h;a7vRRZM7cYEf}aYEDXKQH+0Hs!LI3S*n7rLa3i-m}^k5XNY64 zf~TL0zn^Qcr(;a8tFLQth-;97Sxi8HPfVhTZccuBW^qYoc1&tsS&UC+QcQ7XNvdu^ zVsdt3dTMb@L1uw|d}dxrYEfQdj(%xLW=^p_%uRX)mAAMPOH1<OA)z7yN~02>gv-jq z$i*nbB*rMk$i>LRD8wkh$igV_zet9Gfk9K~78@uGlZ%T485kIDF%_j234<7HC6xu4 zdFe&qm|+Hqa5(w<#)pQuS={1;vJA~`@xYn!POiv2A6K|CV<WhPu@SN|W21N<*CI}k z;q1xzxdoXysYQIClmK!WI82cUX^=7wo80`A(wtN~P%<e7DdS*-Kmle54JCiFaB(pM E03ae(Jpcdz diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-39.pyc deleted file mode 100644 index 07ab05c6c17ce26a339cb64faf1c02702f886321..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1288 zcmYe~<>g{vU|^UdaWGYjg@NHQh=Yuo85kHG7#J9ejTjghQW#Pga~PsPG*b>^E>jd! zE^`z!BZ$wO!;;Gy#mdN#!j{64!rH<Z#g@Vt%%I8s5@ed6CetkzpUmQtTO9rcC7Jno zi8-2#w^(u$GxL%eK?<N4#0J^u46;##fq|ifA&YSVQwrlkMn;Ab<{E}(keN)0pBNb! zoKy2kiV|}a%8L>U3Q~&{((;QG5_57C@^exYKvI<j`I&ho#d=&^3JMAe9+|}@`9+z@ zi8(oy3I&-33K@yT3K@wh3dN~qsUTyJv?!#cre)@(rsyd+r6wnq7N;uYrzvC>7ni0M zgUw1T$}G;zOIJuM%Fk5@a18O#Q7En~)+<OX$<R^AEzK#(EXYY!2&gQ{$j>X*Q7Fks z%`8&L%qvMPN=ycMzF0>gF)u|SH@~<9Y+imENKLLnMq(Mr*hH}VGV_W{5_57=Q*;zc zi&Kk=6^cvK(o%~QK+dgHD9OxCRY=T3@~A?3Y6--7x%p+ODNt{R<b%Q_wJbBSBvqj# zBePhcATcu!Vt+wVepzNpszRbdZfbHyVqRu(E;ta&6N~ad?toaEn3n=}WJ+dHYH|rk zyd)zvSD_>yWPM^mK~a7|5!m#CoW$f*umKsVIR!cj<*5pJ`Q^~C1i3;XKMibBerXYU zBq<~o!{V_RY(z;$szP#UQBi7Mi9&u}svcNlq6{MgL%3s*pQoR@6(o>~6_QdxZpzFn z%g;_tQAnx;ISZ5oij#{n3rb+7>M4YPJYSxflcSK9n3<!HnWvDbkXBk!T9m3#mReMt znV$!W<$}xtJ+6S9)WqUch2qpyg^ZGtf?_Lu{q)R|jM5~%<osOyg35wK{esK_eMpMX zH#N1i1iLvgr7SZ!RUto5AuY24<S39QO7l`ui*hPKT(EjQE>M(|<!7cqqoXK4DJL~o zp)$WzAvrNm0pby8;!!BiEXhz%*UbfaR$T#<BvKPoK<+Fm%>%~~C?!K;CZ|%5OOxdm zb8%(yEw<v4l+>c4Tdd_pnI)-3EDQ_`pzM}dlwQ1&p@@@#f#FxPvsFweC|$**=A>j6 z#rWr?x)f!Wr7Gwug!*}gxdsJ$hByW*c>1~c`?&^tI>rRM`nm>(xCSYh#RLTS#3Y*N z=H#bm7MEmZ$E4<!#rR|<#S~|jr0NzVCTAz6rxwS6f+!xG>hltF^h--JbBgtmGMQdM z<t>hQXy#=H<#!HHA;8PV$n>9uqlg>qW<O2#B31?lhFfeUl?9o3=|xNo3=Bn}65^H^ yD5~J*>m}!8>Vb+AuxG)#!Tv-dK;_&m4x8Nkl+v73J4TR=Yzzzx9E<`?Jj?*@L5w~C diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-39.pyc deleted file mode 100644 index 0ab897ae70df52b983fb6e87b317b6445830dcd5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4958 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 Na&U8SaIkW40RW%Y)Uf~n diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-39.pyc deleted file mode 100644 index ff347931b644fbe420976179505f5db66e2c23ce..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 831 zcmYe~<>g{vU|^UdaWM5K69dCz5C<7EF)%PVFfcF_2QV-&q%cG=q%fv1<uK+lMKLjg z*vvW1xhzpEj0`C(QLHJfQEVw}QS2$~sjO*CQ5-28QJkq9schm5shr{rsqEqmQCumU zDO@cKQQRrq!3>%_Rbp<LIjJR;1*r;|d1?7Yxrrs2`FVO=FF|h5WW2>1Qd*Fcs>yhZ zqqra^vm~{mq>4qaJR?Vwsft6dB(X>@smiE|MXw~ON|UvU9V}8&1rmUeIaN@>oT@5L zuxw6MZekUSUR7p+CNoqn9jpODCKe?#f~<yOkncg*859Bv3=9k<3^feRj46zg3=0?+ zGSo8GFqSZtF%-$9Fa<NDFb6YevQ$|HrIwTy<tc;|m8L3WrYR)kCFZ6kC}b8ZBq}85 z=M`tBq!y*7C?pmuB<3k37A0q7mZd7BW#**ny#!eu;-<-5#LU3JaEmo3zdW_*mXKqR zvxjGxYrJbjh^t?)r@vpYCetkzkg2zrQ!7eVG8Az#FfjaTbhe5KElw>ej!Df)$t;TT z&r5YF0-3F=5bEa{<{A|28R8hM;OXb$@8=rq=@=92>gyUD;u@r2784NQ6O(A7o0FfO zSzMBt9g~_@7UPqd6jPj8lB!#fn4F!Mo?0AJkXfJ~pP5&ZT9lWVqhDH*nNzF}ayTgZ ziuDRAZ}Ddq$3uM-50VfA1sew_ESUuuIT%?Oi?|sW82mJOZn4M5r{pKc$KPTrsVvCM zOD_V2@-2yi%mO{Q4SHZ3^l~$clOX}ZAMWAm>VpV}TYOGYMhI^3E#8PIWG-KnX8;O6 z#4!koU&O}1zyNj;H~^6dP?osGVUwGmQks)$2a1(qAqEBp7G@qM9wrt>7Dg6!kZ%N- E0sWBQEC2ui diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-39.pyc deleted file mode 100644 index 0a28d4e950dc2685cac33be4673a963912f0001e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1641 zcmYe~<>g{vU|^UdaWFNBhk@ZSh=Yuo7#J8F7#J9eT^JY`QW#Pga~Pr^G-DKF3PTE0 z4pT036mu?16bmCm3Udle3qurZ3Tp~m3qurJ3VRAi3qurp3TFye3quq~3S%&XCihE_ z`F@&Aw>bO@N;32F5_4{`hLjfMq$YzTkTD|z1A{ZjavlZ-h7yKmh61h<#%6|K22I8) z%b?Vf(xSX#h4h@vq-2G%)S}|d{5*x?lA_GKbRC8KA_c$vyi|qEG=;qU5{1&@%)E4n zQaw$kTQXox@lZ|i5KZyP`FUx@B}KQSvCEcJ7Ni!hWGG@|V1N+6YMrfOLW@(2iepl9 zQZkET{PR*>iZaVm6?7Fs{XD~5gMvLn9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u z5>0e-^3yYmOER-#QuE4Ud@_?_iZe@6bqf-cvlG)(i(?8h3-seN^GZ^S@)C3OOG`3y ziuJ*+(<`XFB?4xl`GOM^UZ7ZGU@qcdU|>KARFF6*zQKVCiqR5=EXEYZY^EZ<6sBN? zDzOr#1<WbT3mF%%EM$mbs%5BU3}?ubVqqv@EnzERPh+mMV`KoqNCuF41BMz<jIvZY z1QccFCKgpHWabv+q~@mPl_Y{<Rv|wP66R=bghoexu^u$Y^=`42XXY6j`P~wB4vu&C z3yt^jbaIXdhoHZoCdV!2;>zM%90fUvC29FZxwn||i*K<*_1<DFF38C&xy9#LQc{$e zR9ceiT2z!@bc@|T7{cHROUx;S2x>CjVvN7V4vlw2Oct?&;*^Dffq@?se0-op$j-&c z!pOuV#wf(Z!B_;6LkUWd04RLHL0QDWz);1L!kEI8!%)i*&X6a<!cf9ksQ?NpMh19b zF)Uz8VOq#o%UH!#!<fZf%LG-)Qt5@RGK;l_DW0u{shOdcxrDujxrC#csW`8Oc>yOV zdTN<#n1dNKS*mQ^5_58r5|gt@3;ASlTGlH9WiY>6tck_RnVFhgx7Z-!x41oX3-XIf zAi>At?Be5dOC&w7G(J7GBp#I8V9{A5z`($8iz7KcIU}(szTg&nQED;B<Xc>s#hH1< zC5d^-skfLxS&A(sH90>eRg<Mi45US{peR2%wYWGwFEKZ@xF9h(wMY^q&JB$jP>w{8 z9aaVg21QWp$be#pg^7`ek%y6kjf;_qk&BUsnS+^wk&TIqk&CGaq!J~rK;8r;eQ;dK zLCca_h8l(x#!`kNAy86IVXk3FV+v*f7f~!#lS7Is6-x3IQc_D&i*hsbQWZ)vQXy#> zR@88DDJUo?z)GP+g%VH^21@ae(xg~HBPTOS2c}w6p*$lqIYS{OH7&6;rvzknYHmSE zCA7dQ1{;={r;waj46!RGKR>&)Kp`zLGpAS&EDI_!8HzwbaEle3^EDa4Ib4(R7B83& zj}~|d1y0wuIAC!W2ns$>qGe!bW8`3DVJcE#U|`VXEaC+ve{N6=u$5F6Wagz8fr6`u z86*r+4^IBza0Tl?iW;z0pxkqd!zMRBr8Fni4wN&BK_xZ^BL|}ZGY1=o5QhN()l{ov diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-39.pyc deleted file mode 100644 index 3726aca5e49fe4ee8a7d88b91f16c686416a02d1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5023 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 diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-39.pyc deleted file mode 100644 index e405e417c5547dc3244fcd9e8dfd977847221041..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 992 zcmYe~<>g{vU|^UdaWGYjnStRkh=Yuo7#J8F7#J9e<ro+kQW&BbQW#U1au}l+Q<zg& zS{S03Qkj|=7#UKSf*CYf6LlFG7#tNcQgaGYixhJ6Q%ZAE6-qJ^OB6EmvQm>viWP!W zlS_+ILy8jfiVO0KN^}(R^As|3K}<a^u8@pWC`X|<Bfm5!MIk9wAtgUARUxrhAvLim zrxL^{$S*F=Ov*{sQ7Fk*NX;uQElO2L%*jzGN-Zo+EiNfmNX$#&Do!mf&dkp%R?x^V zQYg<zEJ-a(Ez(p-EJ{^KE=o--Nlj5mOe;w(f;ucSFCE=!dR$z7`6W>2m!~S^=jBu? zq~t4<fE)?-O=f-`$oaX6$^OAQ3gsE8d0@$$%)IQ>6b1i+)V$zeABD_fg_8VyuKb)7 zkb5%{^HOqB6+(Q1%MA65^tfJv!rCtxM8YsA#5oxl7@R?&Uc$h@P{NSKn8KLNT*Q~c z5X?};lfsn3ki%5V5YCV%!opC(T&c&%0D_SWAbA6Z8ip*E6y|K!B0CVjN+5+Pg(ZhI zm#vnO5u`@~q^E>Ejj1vXq>GUOu8(m6$3jqCGJxXJ?-pB1Vo`Z!UJ)Y$14Aai0E2)g z<1PMTa0HgXB2bg_7ISfB@hy&moWzo}{G!}j%*Dkyx41pQaq3!BlwWj9%s;@@FF4pI zKFl>J*wf!H-Y?YG$u;PfbU|i;UVK?<UP^wEUTINIPG*v^UUGh3Nl|7}5i<h=!!36I zV2BaIkn|IunOBk@4^^tkRK&)>zyMaclA(x)fq~&ypR-j=XmM&$aZGAXN@h`ve_pCf zQD#}Hg04cSpC{P<5XWEzPd^ubKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!kl znAE(o7@y3fnBvTmRNaEa<m|-s)Z&<e%mRIoGg6E45_9xROEPnc^`VYK3mUzG%3EUC zrFcP6D+P*hW-dk+CMHH6Mjl2EC|iJ0fRTf#h>wARL6i9wdwhIKesX+#5evw#AVIKC ckqD4sw>WHa!MV*26j{ZfaAD!(VCE190E5dGEdT%j diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/logging.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/logging.cpython-39.pyc deleted file mode 100644 index 275dd1841a21a89dadec9ec5c1bd5fe84a62fc85..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8943 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 diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/misc.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/misc.cpython-39.pyc deleted file mode 100644 index d1d9cdd1045a77c3c7b91383a41f1d60575fea34..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21547 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 diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-39.pyc deleted file mode 100644 index 7e5658947d4e56549e61b81f2f7b8fcd5e0c8104..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1923 zcmYe~<>g{vU|^UdaWK`8m4V?gh=Yuo85kHG7#J9ejTjghQW&BbQW#U1au}l+Qy5d2 zbC`0OqnLA9qF8cSqgWXk+!<0>QdnCUQdparqS#WHf*CZ~s^mgTGIKIZGE<8c((;QG zQc}}0^D^_&6>{@aQge#AUV?1%(`3HI?3h=1i^DlFCnqr}C-oLfNM%84GDs2`Gr^n_ z!N9<f$`Hkv!Vtxj!WhMz!j!_C&J@K0aX=Jn3R?<$3qurJ3P%cO3qurp3Renu3quq~ z3Qr1e3qurV3SSC;3qurFia?5B3qurlicpGh3qur7ibybnrsypZ@6<}C#NyNx=ltA) z#G+K+%!<ssD)WG%{IblH)MABXuyAH^ex5>dVnJdO%!efzi6sh|#R^Fvy$bnx3W*BY zsg<{Q;vpJR<3T+Bcvv9BC+8#<7bk-P8Rkn68{|u81_p*=0R{$!8paxic!nCL8ishr z6oz1im5hFxOhs%A3=Bo=3=9mK%(qyIQ*+X8F@uceLp6CNLlF-H1H-R6XRDad;?$zz znADt<%%T|oyi}K>%(7GkU4>9T&oI}ZV9yZ8U<FS<7k@w3U{A-GU{_z);1Jg!1+$od z0H2sd6WyHr^vvRt%<P!dys{Xd%%qs&%#u{yg2d$P#PrnSn1aj#{rJqhlGLKS#2o$7 zlFXc9eMk)J6;$5hh>y?A%PfhH=LPwS1>{#IHpVJhY@w_NQ=7~PQU}E#Hau8BNw$Qc zh9QfwnK785hyxT1Ot)Av5{omy0i(%S#0d%?kl(=pPz16U<O-0I_;?|ZD?p|(FyV9q zL}fBq71RwNHpuPZsNn-e4Z{M48paaFET)A_Fn2KD;($f=Esp$x)S|?a{GwZI@$oq& z@$oB}zz(~`nqQKUS_E+#*pVRj6$vviFo+>JO&Uk=fJ`F8VMT(VFah};?3~p2_#zRI z2-pE&0_+Nq3#5o~MQVIJ#jZ#%!Ql#V1_lN>B3uD7fO1#h3JVDa1_mW!TtSVnNG-$> z7Lp7M3~EHU0%QP2Spq6gzzG%<nkC@UB#W_`saT+dDHvR;WHHw;W-&Lz6EMpyuFT@h zyyB9?yyR4H5p#>rFTcbyw;(4qH#M&$H3gE#n88W8NR)wr;TBtNYDq?Z3VMPDB{(gR z!$GAL0}~G;3(ouoEg$_fc|qAUFEKYYKK>S0e0*+xN@)&=%@ZGASelpvm0^#MPsvY? zkH5tkA77l4Us4<&Uj)jLMW7NBoRNw^>9`1#jEX?9SOf}0NDcrebp!!U^sEdF44`79 z7?dM87+IJ&m^fHDSP-xXq(YOuNCA{%AbF^yvLG`ry$Dn)6oEpy2vjzJ)ggrg*dCA- Xw>WGdez5};WyPQnVPWQA6k!GcOKzja diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-39.pyc deleted file mode 100644 index 41412e51b9b6baac7b12fd70ad64f779ecf6b91f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2547 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 Q!^p$L#mphbA;TdE0F#%^f&c&j diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/parallel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/parallel.cpython-39.pyc deleted file mode 100644 index 5ca6316e8195e4b8d041e10039cbaf0c7b5fba0b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3064 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 diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/pkg_resources.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/pkg_resources.cpython-39.pyc deleted file mode 100644 index aab84fd75089bce6cde33da7db8cc0353125457d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1745 zcmYe~<>g{vU|^UdaWFNAg@NHQh=Yuo85kHG7#J9ejTjghQW#Pga~N_NqZo6UqL^}- zqnH^%VoW(KxvWvFj12A!Da<J>Eet6v%}h~jDXhT^nrtsYrfD+YVsXh#F1f|wS&~|m zn3R)xi^V6ixI~lj7I$T4YEDXgPG(+eaWY6PGG>C=?!myokjfCnn8Fanl)@OroWhjC z+`<sWlERY0+QJaUn!=XC-og;Ymco(3*}@RTp2C&F-NF#Xk;0S0+rkjVnZlRC-@*{Z zl_C(#pecBZ2jm#v)RM%M#FE4+J5LxhpeVmAGbOc1p(G=*M4>1(F{M}`7phDlEi)&z zSRt(_KUX19Atf`pBr`uRv8Yln8RSZst3hlKb_RtRC}?XKYZ&4gQW%06Rx<jnWW2>0 z4>M4c=@v_IYEIfM4w%SFh9VvY28Lg)&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCw zo?)&*!JZ+G!3v&!F8+S5!JdvW!LGip!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^ znMpClnI);Z1&PVoiRr1uF$I|g`tg~0C8<Sui8=bEC7C(J`UTnP@kOb{`K3k4sl|E) zmA5$J<1_OzOXA}>L7oBmih-$06glYhU@8cQK^8+9Loh=TI|Bnl5eEYU!%C(iQ1IMh z$xF;l1$!Gp@G>wk+~UbdEQW^@NTe8QyCjP3$f{6W07|tW)4{P2#K6E%B~ZhV#Zbd2 z$*_QNAwxJrFarxi2~(vHBSS3{BSV!+4HFAP7IO+?4dZNv6sEb%<_t^>@ytyO;S7-s zDGaqtbxe6&5ZZvj034f|%zjlY3YmEdRjlBYp~+GN3Z`3ZDXGc%DXF)FLh~{~3>Prh zwWuh+=oVX1YGQGIo+dNc>qP<}uQFnKK0UPr?s-8_(1X0fz{JETz{tlW##n_K2*|2Y z0s$0cEDQ_`;6UJGU|=X=s9{*ZSi`uGv6&GX6`D*%te_YX0}=cn0+axeVnPVnct|dl z0yzm}I0I9aJW70Es>N^+Bg{b{m!&WUGiWmTxk2p1W<4J)Ys6<3r(_n%Az3YrVl}Ed z{MM$!6C&8N*z6U6o0pSWT#}Mmq=aO%EOwirDw9Ep4^|w2*r;Acu^XBaZgCeU7iAWd z#Dns}Elv<wT#%TIkutc7O7r3&O4X3uBaY%8gc?6hZcrWu85bXaiz_}pH$SB`CpA9) z7EgS9VQFFxRE9l1J|#anKE4Q)NQyuyt_YkS#6jsn0z^oH2pJFo4lx7)%9}-O3=9k) zTntLk9E>bX94s6x9Gqa11uW~Q$$pEiq_QA0FTDtqa*9CVQUpo@w<HTP3-sd4Qu9*s ii}X;6AV|st84O7usJ7nXuz`5T4ivt{AhSf6c$fiFAdSKR diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-39.pyc deleted file mode 100644 index 365c4f76fac72090814c87536d41df6dc9fed473..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2989 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 diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-39.pyc deleted file mode 100644 index 2c6dc2f6699ca24d2cdb0ee868bed92452d0451a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5712 zcmYe~<>g{vU|^UdaWK_Hoq^#oh=YtlvJMOk48?~S7#LC*QW$d>q98P56eF0=6vYIl znWLCf7*d#WSaMmTSaaE;*mBvU*mF6eIC43oICHt8xN^CpxEVounR9q@d82r9`J(v1 ze3l&kT!AP7Fq<_;Fjpu_2+U^75zZBf5@BRW<w)gD6-^aMW0GW$WQY<=VUH3|;Yi_Z zVTh7Q;Y#6dVTh7U;Ys0bVTh7S;Y;CfVTh7W5l<0L5ouwJl1ULw5o=+Hl1*U@X3&&) z3G$tvCi^XB$Gpm09L|Y3If+R*skb;hOHzx#EEb>4;*wkJzKI0|nR)5AIQ$DrGV}8i zb8fMQ=4IyRX)@gs2rkIX%S$ct%qvMPN=r;my~UGXkeU}?3=!63yd~|KS6l)z8l*M2 zG^wB{KRLCy*tMuAzetnumS8blC_X1YJv|j9$mNlll9HMil3GzxrJ+kCNCtTahM5@{ z7+4q>7~DY-X2ih2kj_xcSi|7L5UWzlRKifhRKnQIRHRhHxPYmKX(1ycLm@{E;{s*` zJD5R}u}Y0gK|w*mxhOTUBvm0%!8t!SH!&~8u_(P*AwMZAHMv9&tU#0H7FT9*Cdi+8 z$*H$kazLTRmReDgnwN5mEwP{=H7`Yz`4&rJQF`$$o@9tA@n9ZvVo~}^h9Xf028Lfv z&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW!LGip z!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g`tg~d zsLD&s(Jw8@%qiAKguh-v<t?7v#O%~~s1t=ifyV<1QdSm54rVS!9%de<B5?)=hGa&N zC=`R(ps;oZDHj1{4#ouxDNHHMEexO#Z)RKwN^UGw`ryEF%P-1JEKz`3p^#XVUYeVl zS5mBymS3chl384klUNA})?bVYDE2ThFfg!!>;Pc{1_p*2hFFbS#uA1aMsRG(l`t(} zE@7!*1lgF!0pis#E@TX2U}Pv{N?`!SsGlZl5g!8sLlG|n1H&!W;*6Zsid(FOrTHbP zx0s7didHh+V$w4x0(k-)ClEpmq?pqtJvA@2qM*o54`e^c!z@fp|Etu}z#f8y88}+? zY;y9G6LX5~^x&E_8E>&<<!9!tWGn&&E5u+>v=@O*7sg_W3dkNdP#|-0F){rsQp6VU zpg;i!Jjh!qj44d8Ko4fnWUjIW2YFCxNoi4@LP<s{QgCO21u}~iiW19p6iV}oQd1I> zOHxxn@sJCN0IZ=O404qMI7ihm#7ZEAzeEjV7E>Nm4dX<nLY81iqSj<a3U9XJ)a0Vn zk|G&U41oO(Ccpu}Wdq7J$@#ejc9skb44*;Xu2L^bElW+z!4<Y}9gxrjISRr;7%Pm$ z1QU=CK;g!~TBHgJQ&3!j>;qwT1_lNW1_lOjn1T{n2}2D-Gh;1F3gZGsQ1MX9n!=RD zRKr}uQo~rnT*K7NSi@SvlEU1}R?Aky7R;c@Qnef$>ab!XFGZmU5do>7a!(;QwYWGj zJyoG3U!k-ZOy%UKD<mo)GNS@mA=seu%#sXve#tK_DJU(`;{wZA6(klV<|^c5=A{-} zDL5*C0z@G{4I-eUkeZmBp^%!Fl9`vT05&91AuqKYq#6>xw-~DCL(4RXb*U)|`K2Wg zwW$@EB?`qQi6y1Q3e_M^JcLtg#RYSWl|nT%8^=R4ZY|hZ3d!XuAi44sgt&8lZb43J zNh-*Kg3=NNjcSlP;*;}B^Ga$V4%W2ds)l&4wmK!VEHfpws8*Bh7B`aRxA@U4yv3c2 zu;msP!pvK25TkCfLygj81!tflc~E9%gJic`%sHufx43=$-Q!(6!#rJFgEZN1aU|!a zfOGLJ=H&8}TdW{6i;L7j+SsAC7ioid%(=zs=;=)cTz(>=F&^TIcyMgmfD)br0|NsC zF9$OhE7Kn)P9{bWWCM|(*aV7985kJcZm||6W)`Q0By)q5LNO@MfLb8nba{!1fuV*a zg|U>Oh$o$)mZgRr%$7)JsAaEVEYd1r$YQMJE@8@IuI0(&DPhQB0rOaEc}f@-uq|Y$ z;mKyK<*ni6VaWHZ;YeXDWvu0^VFjC!P{IyQ@2oZ4DNHr2%}k68B^+6t3%C|C)biJ` z6*blHFW|0W167$d>@Ezk0<{7){0n$$1X36mGBGj~wpAIF@MiIq@PkY#;mr~N;To>u zZ6&-}f_W@p9#ai}3UdleFMF+EI76Nl3qy&}1jb4xMuu7;MusYd8qT6OB@7FMQ&?++ zYFHOCGcq(Wgfm1kq%hVB)d}TsL1+U815l+dT*Ebiv3OsNV3x=P#$qWih9<@u!7R}U zjKyj&_5!hm42%pQ6$``{GSrIHfK<9nU@WYw5m_Js77<<`StF9dCe8r%7k7<FGb1BI z4c`RDB7+)^35>->V6!+DNP$e6z*uNdC08T3KpMmg2b(;Bv1k+62C!XuA|Unz#-a@% z8e+czLkjx>nHu4RjJ2Y9AvJ;vWEV2TFx86Hir0uOkXs09n()<1)Nt2Gfb5>YSa_)h z<SH?+i^Sn7Bx|^9B%vz4fK`ZtRfyG!)(B?FPhiSd0?{=rWsJ2_HGC78iUMjlCNLG7 zfPEk}fvL!?hGT(33I|A69v7I+31ZiP<j&PFr*LI6O<*dTR>M1iskozta{^OQM~Pw$ zLk&}nFv#Q-?p~H!=@NzoN;T3TeI?2uQBX>0V$8FsVNT%z>)%qsus|h+w}urg%e0V% zks(j2hB<`~EPEi2uS7M4zlM1>(_E%z#wNxZ(O?EmfyA>+3=H5R1k}c|0<#npiZk-d z<BLmD@=Hss6f)BkN{UKTb-?AOr=OcYs0;-ao}k(dk?+)t6^ctzQj3Zd67y1^<|u%K zK;>I;Nl|KIZn2(%f`3UyYEgM+G1NR4SEo>SJp~1q)U?FXoRVUY*=~tB#i@|;Qb8fL zqNFG>K0iAiQlcm4r+^CH#5{#eXp<RK`hpr*>8VAqQXi~Hp(G=*L?N*#74DYA<mA+X z5>PW+M<Fv$Au%N-6VyTmS!tk$;sU??yi^^9@{G*n429g(#JpmK=vbJ8O7n_SOX5@W z$})@c^Q;umTmlsbwXYP)5{oiHwkhN#=B9#u2G$FAPeD;;ei6v_<iwmDP>q2IOuYb5 zn_fc`W@%1-dVE@9W=?8Kd~$9II8M?)p`@b#5rx$c#UKwW<mHzrfLrz{ItuxDIh6|F z(k%sM7$jojK{8;IAh8PxUx<2$3LS;ioZ?hipeE&)Waue`XQbvqk^|fuAe%t0&reeT zsewg#VqOY}2}%(8$;qWf#R}zMy&0*<b#6vtG2Eb%)S}$Xyu^~!6sXN`lOg&Oi;;Cg zig|_1VugaD{FKt<RH*;_s)T|{^YTD0g4P`hs>Qbik`j}%i*pi-Gm26RauSnMHQ8>l z7MG-C=G|h0_!dm378Mm4f@_-8ys}$t;5wwZN*UaBQcwkXAu}gcA+;hkxwHh$21c$T zHIPnLu%=rqDfxM+MP>{P44N!OpjHjo+#*oN2vW1LlqVMDRjI&Q14^pJN(vc?DUfD? z0w@WCEX>RUxt=XEJukl~wMy1AuPiYqGew~+F{d=uN+CZFDO=cTsuh8{4!2k`^V0Hf zu|q@e77HlP-eOHjO)5>l#R|@Fw*=EuOI*{^Qj<$E%Tj$(%TjZSKyBSyO!>vP*r93o z7E5w|LFFyB(t?ykP-DFyzu*=ZB8lE&1*cJPd+ruXfM<Z~Ew<ng7yr<ZTb!;Hpq!SO zpLdHRxhS(FGdVG*2-L<bvH*ura!!76>Mf3<)Wj4}Rey`EsJNskv!F;2B+CNo$lhWp zPs}WVv>doW(O8<7nGA9TS8+j3W(i1F@hz?*a3c>CRJYjDGV?NvGr-k(ksYYD3#!U* zv4a8`)RE>21BDnk9yMidF(>Dy+~P(m<-n11ix(w4Z;4<ldl0?Jl+@znTf7i8upr|F z=Wtl*aEl$}m%P-XTYRV)_!c)L&4KeEL=q`rxk`&uQ{r<#v2sfY<jBmt^mrtB?$Y8^ zSa-k38XRVz66O{QsH1<2Ikh7B7FS|U4zwWz>Kx~#LfcRIr6sqRQ;Ujjapael#DjwI z7DsAP5roAD(jT9Zm;z}#6@gmq=&db&P+5iKm;_J*YY(W!B+bFd!pOnMBEZ7L#>m0K z#>mFZ!@|eJ!N|eH#mL3T!pOzQ!N|wR#0ZjSVPpZbnHZUVaB&GRg7~0j8Pi`DRtZKH zMm9zsMjl2kW-dlHu&I2^987GCT#P)7OpIJi9E?2wIY25{c$mQIKx~j5OhSwxRcwqr zOdy@0?lag_kgb2%*ti(^K&n7ZKSmZtCa?$-6CYzy8K_SJ>QsX~0>Yra3aF0)8q_ET z^&V4L+8NRq!Ch?5TE-es_nNipPC!vUsL_nljfgKQ1r5(Ysvl776@#Q9gEO#R2(&W+ z8p6p-fph@DwJW&G0P2+&q!ySOnyVKp1b`VH`T5z-i8(o`MS2P$8KuQK;GQMaB3Kcc zn5W<v;0dueH?br+BNbF$C6=fcE2LHwq=I{zNtKu;B2pIA>5zKDFB#-{P+)*CC@?^s zG+|JDgId)k3>^&3jQt9=%q5I93^j~3Of}3YjJ+(34B-qZ3@i*R49(1p40!^E48?i| z42)nH$p9K!3ue${^3!AnXSpKK5K>VpsFY+X0yVb5QK89F6bH(}ppqD&VkP4(c4#jS zk}AQyST;x~a5FM66oWeC3~XHB_yx!NpDJyLbUY|zVR<GVY6@b^0HR2f$<GgLvL;he z1<3wN5CQJlmV;Pe`=lXiu^Pw>as()p7`PZ18UFI|6;*+J#^vS*t_b`<AjC~mt_akn zDDnWADG4HcL3x<1q!KjbR|HCWMWCQB0)=@IX!xZFG$c_3>L(Y0Our>nkXfJyA63#z z&dJn+7Bt00oFD^1A$dyzRaGjiOfD`07md=W(%_*fJ!qW)sYlQZfT+mLEKUZG<rGPS zT+I!wzd)_WB7KnEpus9|Wdg1lAO$ige}TgS9K1*bI7m5ca`RJ4b5iX<Ij|U1WpXe= kpbC=!IBWAT2{5xTa|m$=aBy&_fzuKsMZw6gT=fhp0B1Kh2LJ#7 diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-39.pyc deleted file mode 100644 index 16fa511a9a099511408c14826654b5c322810b34..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6863 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∾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 diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-39.pyc deleted file mode 100644 index ca9359c8b90c0d2c0a3c74be2ba1572204c44d52..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6484 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 X=HTGq<q+WD;o#)p;L_&^W%vsKr`W+g diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/urls.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/urls.cpython-39.pyc deleted file mode 100644 index d14a48542989483ea7bfef2df4d02bf1cfb60b95..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1375 zcmYe~<>g{vU|^UdaWM4-3j@Pr5C<7EF)%PVFfcF_doVCCq%fo~<}gG-XvQc;FrO)k z8BDW)X{H?3T(&4SMursT6qXi-DE1WA6t)(ID2^2N6pj{#D9#kdU<OUjmmoX*G#PJk z_!pF9=I15mBr}49pcuqvVPIfz2HC6tvYD}lp^UMJCxs!Hp@v}rLkeRG(?X^cW=Vzx zj0+ip88lh^elc3T1nDaR5t>Z5Sc?mCGD~i;=H!>B7HKlxVlFMpS;<hu!N9=qtH#+X zCbT%Us5mAyCnd8e#y>CBr6{v3RY6xF)Xy`_H7M9K#4%XG)6d1<&o$W7F(%m6*EKlA zHAulMCLq8kCecJUCqF&2xFj<>CN-}t#wRl=rZ}@CRkt89IXf{uwK%3Avp_#SGp{7I zC@(QbzqBMXr&zzVD5qGjpz;=9dTL30X;DsmadJj#ZYsz{#cUv-GjTAoFcyI#1SK>; zaR8DBhlU;l149Wz7UKdYFv(oQu#j;fV=Y4oOBU+_wiLz^mMr!K9AHtVTE-esXfsu1 za49G#C^+Zmm8BMyC?qNrB$i|-l;kTUDx_uRq*^J22KneID1>CBLS)J_b8-}tQWbI& zQ&JTYlZx|mN=s4|67y0NG7`&D!Dbbf=9i?VK$I6G7L^q1frWpuf(_K<yv3AXe2WES z&n=F;{Gwbii#;)^7|dWREy~HsOuEHdkXTfldW*fZC?_jFGw&9AQEFjnYH`Ue9+0xU z#N1S)(xMzqrXpSj28JSb5CIA;a3mISGB7aQ;sz;<FUbdmCqF2)fC7qvO@vX5u}GAG zfdM5TK}m`gmaHlm7@$dMA!D(W7efkD4a01v6y~|i&5TWqC5%~23&4RJ!&=K&%T&u; z%UH`;!&GEb!<533%~a%+!dlCervwW26t--pqOcV98YXduTBba{61Ef$kXdt?peBJL zgsFyEoM9njEprVsC<9b!fWr$BCE#!aMFb>XK;D7`X%ROA14ETzWPYhaa$=rBeqK(c zLP=>+9yIDeiAo_euOuJL2L)NNf<|6`iNY^N&0Cx~`N@en8TrK}w-|1*mS^S}8&xsI z#8g@2<>%>w<-ocWLW4Yu6%vb56+jw`OA89}i$JlPpQligky)%zkds)FmS2=>rJ%`q zi>tT<6yN2UB^gBmpcoMZ#RCV(9pDVdTwGavivy<R7FSqePHC!ZQBi(TkuXRlPiaw( z5y*QWw`#J0WAzqe{4KV;)RLV1WJpw_$1*6ll;p>Qv`K+tSq_w4SXmgE{<AT0{bOMf zW8z_AW8`AuVq#+C_|L*3z*wZjz`&r%Rm1~wq72O9oXjLWaGC=<{T3f29qPf79a~9d yL1tch5h%xj^C375fsKNsIW%{1*yQG?l;)(`fy$g>J_ZH`4n_#%Vdh}x;06G@A7nKE diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-39.pyc deleted file mode 100644 index ece4546e838972f31df095ab232dbdca09b6d9e2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3242 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 diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-39.pyc deleted file mode 100644 index 1eeb051528b73b8f799f6df72632f70577d7db4b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5993 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 SfGCFqhcJf{2N#D3hadn%(m}xh diff --git a/env/Lib/site-packages/pip/_internal/utils/appdirs.py b/env/Lib/site-packages/pip/_internal/utils/appdirs.py index db974dad..16933bf8 100644 --- a/env/Lib/site-packages/pip/_internal/utils/appdirs.py +++ b/env/Lib/site-packages/pip/_internal/utils/appdirs.py @@ -7,32 +7,46 @@ and eventually drop this after all usages are changed. """ import os +import sys from typing import List -from pip._vendor import appdirs as _appdirs +from pip._vendor import platformdirs as _appdirs -def user_cache_dir(appname): - # type: (str) -> str +def user_cache_dir(appname: str) -> str: return _appdirs.user_cache_dir(appname, appauthor=False) -def user_config_dir(appname, roaming=True): - # type: (str, bool) -> str - path = _appdirs.user_config_dir(appname, appauthor=False, roaming=roaming) - if _appdirs.system == "darwin" and not os.path.isdir(path): - path = os.path.expanduser("~/.config/") - if appname: - path = os.path.join(path, appname) - return path +def _macos_user_config_dir(appname: str, roaming: bool = True) -> str: + # Use ~/Application Support/pip, if the directory exists. + path = _appdirs.user_data_dir(appname, appauthor=False, roaming=roaming) + if os.path.isdir(path): + return path + + # Use a Linux-like ~/.config/pip, by default. + linux_like_path = "~/.config/" + if appname: + linux_like_path = os.path.join(linux_like_path, appname) + + return os.path.expanduser(linux_like_path) + + +def user_config_dir(appname: str, roaming: bool = True) -> str: + if sys.platform == "darwin": + return _macos_user_config_dir(appname, roaming) + + return _appdirs.user_config_dir(appname, appauthor=False, roaming=roaming) # for the discussion regarding site_config_dir locations # see <https://github.com/pypa/pip/issues/1733> -def site_config_dirs(appname): - # type: (str) -> List[str] +def site_config_dirs(appname: str) -> List[str]: + if sys.platform == "darwin": + return [_appdirs.site_data_dir(appname, appauthor=False, multipath=True)] + dirval = _appdirs.site_config_dir(appname, appauthor=False, multipath=True) - if _appdirs.system not in ["win32", "darwin"]: - # always look in /etc directly as well - return dirval.split(os.pathsep) + ["/etc"] - return [dirval] + if sys.platform == "win32": + return [dirval] + + # Unix-y system. Look in /etc as well. + return dirval.split(os.pathsep) + ["/etc"] diff --git a/env/Lib/site-packages/pip/_internal/utils/compat.py b/env/Lib/site-packages/pip/_internal/utils/compat.py index 1fb2dc72..3f4d300c 100644 --- a/env/Lib/site-packages/pip/_internal/utils/compat.py +++ b/env/Lib/site-packages/pip/_internal/utils/compat.py @@ -11,8 +11,7 @@ __all__ = ["get_path_uid", "stdlib_pkgs", "WINDOWS"] logger = logging.getLogger(__name__) -def has_tls(): - # type: () -> bool +def has_tls() -> bool: try: import _ssl # noqa: F401 # ignore unused @@ -25,8 +24,7 @@ def has_tls(): return IS_PYOPENSSL -def get_path_uid(path): - # type: (str) -> int +def get_path_uid(path: str) -> int: """ Return path's uid. diff --git a/env/Lib/site-packages/pip/_internal/utils/compatibility_tags.py b/env/Lib/site-packages/pip/_internal/utils/compatibility_tags.py index 14fe51c1..b6ed9a78 100644 --- a/env/Lib/site-packages/pip/_internal/utils/compatibility_tags.py +++ b/env/Lib/site-packages/pip/_internal/utils/compatibility_tags.py @@ -2,9 +2,10 @@ """ import re -from typing import TYPE_CHECKING, List, Optional, Tuple +from typing import List, Optional, Tuple from pip._vendor.packaging.tags import ( + PythonVersion, Tag, compatible_tags, cpython_tags, @@ -14,21 +15,15 @@ from pip._vendor.packaging.tags import ( mac_platforms, ) -if TYPE_CHECKING: - from pip._vendor.packaging.tags import PythonVersion - - _osx_arch_pat = re.compile(r"(.+)_(\d+)_(\d+)_(.+)") -def version_info_to_nodot(version_info): - # type: (Tuple[int, ...]) -> str +def version_info_to_nodot(version_info: Tuple[int, ...]) -> str: # Only use up to the first two numbers. return "".join(map(str, version_info[:2])) -def _mac_platforms(arch): - # type: (str) -> List[str] +def _mac_platforms(arch: str) -> List[str]: match = _osx_arch_pat.match(arch) if match: name, major, minor, actual_arch = match.groups() @@ -48,8 +43,7 @@ def _mac_platforms(arch): return arches -def _custom_manylinux_platforms(arch): - # type: (str) -> List[str] +def _custom_manylinux_platforms(arch: str) -> List[str]: arches = [arch] arch_prefix, arch_sep, arch_suffix = arch.partition("_") if arch_prefix == "manylinux2014": @@ -70,8 +64,7 @@ def _custom_manylinux_platforms(arch): return arches -def _get_custom_platforms(arch): - # type: (str) -> List[str] +def _get_custom_platforms(arch: str) -> List[str]: arch_prefix, arch_sep, arch_suffix = arch.partition("_") if arch.startswith("macosx"): arches = _mac_platforms(arch) @@ -82,8 +75,7 @@ def _get_custom_platforms(arch): return arches -def _expand_allowed_platforms(platforms): - # type: (Optional[List[str]]) -> Optional[List[str]] +def _expand_allowed_platforms(platforms: Optional[List[str]]) -> Optional[List[str]]: if not platforms: return None @@ -100,16 +92,16 @@ def _expand_allowed_platforms(platforms): return result -def _get_python_version(version): - # type: (str) -> PythonVersion +def _get_python_version(version: str) -> PythonVersion: if len(version) > 1: return int(version[0]), int(version[1:]) else: return (int(version[0]),) -def _get_custom_interpreter(implementation=None, version=None): - # type: (Optional[str], Optional[str]) -> str +def _get_custom_interpreter( + implementation: Optional[str] = None, version: Optional[str] = None +) -> str: if implementation is None: implementation = interpreter_name() if version is None: @@ -118,12 +110,11 @@ def _get_custom_interpreter(implementation=None, version=None): def get_supported( - version=None, # type: Optional[str] - platforms=None, # type: Optional[List[str]] - impl=None, # type: Optional[str] - abis=None, # type: Optional[List[str]] -): - # type: (...) -> List[Tag] + version: Optional[str] = None, + platforms: Optional[List[str]] = None, + impl: Optional[str] = None, + abis: Optional[List[str]] = None, +) -> List[Tag]: """Return a list of supported tags for each version specified in `versions`. @@ -136,9 +127,9 @@ def get_supported( :param abis: specify a list of abis you want valid tags for, or None. If None, use the local interpreter abi. """ - supported = [] # type: List[Tag] + supported: List[Tag] = [] - python_version = None # type: Optional[PythonVersion] + python_version: Optional[PythonVersion] = None if version is not None: python_version = _get_python_version(version) diff --git a/env/Lib/site-packages/pip/_internal/utils/datetime.py b/env/Lib/site-packages/pip/_internal/utils/datetime.py index b638646c..8668b3b0 100644 --- a/env/Lib/site-packages/pip/_internal/utils/datetime.py +++ b/env/Lib/site-packages/pip/_internal/utils/datetime.py @@ -4,8 +4,7 @@ import datetime -def today_is_later_than(year, month, day): - # type: (int, int, int) -> bool +def today_is_later_than(year: int, month: int, day: int) -> bool: today = datetime.date.today() given = datetime.date(year, month, day) diff --git a/env/Lib/site-packages/pip/_internal/utils/deprecation.py b/env/Lib/site-packages/pip/_internal/utils/deprecation.py index b62b3fb6..72bd6f25 100644 --- a/env/Lib/site-packages/pip/_internal/utils/deprecation.py +++ b/env/Lib/site-packages/pip/_internal/utils/deprecation.py @@ -8,7 +8,7 @@ from typing import Any, Optional, TextIO, Type, Union from pip._vendor.packaging.version import parse -from pip import __version__ as current_version +from pip import __version__ as current_version # NOTE: tests patch this name. DEPRECATION_MSG_PREFIX = "DEPRECATION: " @@ -17,19 +17,18 @@ class PipDeprecationWarning(Warning): pass -_original_showwarning = None # type: Any +_original_showwarning: Any = None # Warnings <-> Logging Integration def _showwarning( - message, # type: Union[Warning, str] - category, # type: Type[Warning] - filename, # type: str - lineno, # type: int - file=None, # type: Optional[TextIO] - line=None, # type: Optional[str] -): - # type: (...) -> None + message: Union[Warning, str], + category: Type[Warning], + filename: str, + lineno: int, + file: Optional[TextIO] = None, + line: Optional[str] = None, +) -> None: if file is not None: if _original_showwarning is not None: _original_showwarning(message, category, filename, lineno, file, line) @@ -42,8 +41,7 @@ def _showwarning( _original_showwarning(message, category, filename, lineno, file, line) -def install_warning_logger(): - # type: () -> None +def install_warning_logger() -> None: # Enable our Deprecation Warnings warnings.simplefilter("default", PipDeprecationWarning, append=True) @@ -54,49 +52,69 @@ def install_warning_logger(): warnings.showwarning = _showwarning -def deprecated(reason, replacement, gone_in, issue=None): - # type: (str, Optional[str], Optional[str], Optional[int]) -> None +def deprecated( + *, + reason: str, + replacement: Optional[str], + gone_in: Optional[str], + feature_flag: Optional[str] = None, + issue: Optional[int] = None, +) -> None: """Helper to deprecate existing functionality. reason: Textual reason shown to the user about why this functionality has - been deprecated. + been deprecated. Should be a complete sentence. replacement: Textual suggestion shown to the user about what alternative functionality they can use. gone_in: The version of pip does this functionality should get removed in. - Raises errors if pip's current version is greater than or equal to + Raises an error if pip's current version is greater than or equal to this. + feature_flag: + Command-line flag of the form --use-feature={feature_flag} for testing + upcoming functionality. issue: Issue number on the tracker that would serve as a useful place for users to find related discussion and provide feedback. - - Always pass replacement, gone_in and issue as keyword arguments for clarity - at the call site. """ - # Construct a nice message. - # This is eagerly formatted as we want it to get logged as if someone - # typed this entire message out. - sentences = [ - (reason, DEPRECATION_MSG_PREFIX + "{}"), - (gone_in, "pip {} will remove support for this functionality."), - (replacement, "A possible replacement is {}."), + # Determine whether or not the feature is already gone in this version. + is_gone = gone_in is not None and parse(current_version) >= parse(gone_in) + + message_parts = [ + (reason, f"{DEPRECATION_MSG_PREFIX}{{}}"), + ( + gone_in, + "pip {} will enforce this behaviour change." + if not is_gone + else "Since pip {}, this is no longer supported.", + ), + ( + replacement, + "A possible replacement is {}.", + ), + ( + feature_flag, + "You can use the flag --use-feature={} to test the upcoming behaviour." + if not is_gone + else None, + ), ( issue, - ( - "You can find discussion regarding this at " - "https://github.com/pypa/pip/issues/{}." - ), + "Discussion can be found at https://github.com/pypa/pip/issues/{}", ), ] + message = " ".join( - template.format(val) for val, template in sentences if val is not None + format_str.format(value) + for value, format_str in message_parts + if format_str is not None and value is not None ) - # Raise as an error if it has to be removed. - if gone_in is not None and parse(current_version) >= parse(gone_in): + # Raise as an error if this behaviour is deprecated. + if is_gone: raise PipDeprecationWarning(message) warnings.warn(message, category=PipDeprecationWarning, stacklevel=2) diff --git a/env/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py b/env/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py index eb50ac42..0e8e5e16 100644 --- a/env/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py +++ b/env/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py @@ -1,25 +1,12 @@ -import json -import logging from typing import Optional -from pip._vendor.pkg_resources import Distribution - -from pip._internal.models.direct_url import ( - DIRECT_URL_METADATA_NAME, - ArchiveInfo, - DirectUrl, - DirectUrlValidationError, - DirInfo, - VcsInfo, -) +from pip._internal.models.direct_url import ArchiveInfo, DirectUrl, DirInfo, VcsInfo from pip._internal.models.link import Link +from pip._internal.utils.urls import path_to_url from pip._internal.vcs import vcs -logger = logging.getLogger(__name__) - -def direct_url_as_pep440_direct_reference(direct_url, name): - # type: (DirectUrl, str) -> str +def direct_url_as_pep440_direct_reference(direct_url: DirectUrl, name: str) -> str: """Convert a DirectUrl to a pip requirement string.""" direct_url.validate() # if invalid, this is a pip bug requirement = name + " @ " @@ -42,8 +29,16 @@ def direct_url_as_pep440_direct_reference(direct_url, name): return requirement -def direct_url_from_link(link, source_dir=None, link_is_in_wheel_cache=False): - # type: (Link, Optional[str], bool) -> DirectUrl +def direct_url_for_editable(source_dir: str) -> DirectUrl: + return DirectUrl( + url=path_to_url(source_dir), + info=DirInfo(editable=True), + ) + + +def direct_url_from_link( + link: Link, source_dir: Optional[str] = None, link_is_in_wheel_cache: bool = False +) -> DirectUrl: if link.is_vcs: vcs_backend = vcs.get_backend_for_scheme(link.scheme) assert vcs_backend @@ -90,28 +85,3 @@ def direct_url_from_link(link, source_dir=None, link_is_in_wheel_cache=False): info=ArchiveInfo(hash=hash), subdirectory=link.subdirectory_fragment, ) - - -def dist_get_direct_url(dist): - # type: (Distribution) -> Optional[DirectUrl] - """Obtain a DirectUrl from a pkg_resource.Distribution. - - Returns None if the distribution has no `direct_url.json` metadata, - or if `direct_url.json` is invalid. - """ - if not dist.has_metadata(DIRECT_URL_METADATA_NAME): - return None - try: - return DirectUrl.from_json(dist.get_metadata(DIRECT_URL_METADATA_NAME)) - except ( - DirectUrlValidationError, - json.JSONDecodeError, - UnicodeDecodeError, - ) as e: - logger.warning( - "Error parsing %s for %s: %s", - DIRECT_URL_METADATA_NAME, - dist.project_name, - e, - ) - return None diff --git a/env/Lib/site-packages/pip/_internal/utils/distutils_args.py b/env/Lib/site-packages/pip/_internal/utils/distutils_args.py deleted file mode 100644 index e886c888..00000000 --- a/env/Lib/site-packages/pip/_internal/utils/distutils_args.py +++ /dev/null @@ -1,43 +0,0 @@ -from distutils.errors import DistutilsArgError -from distutils.fancy_getopt import FancyGetopt -from typing import Dict, List - -_options = [ - ("exec-prefix=", None, ""), - ("home=", None, ""), - ("install-base=", None, ""), - ("install-data=", None, ""), - ("install-headers=", None, ""), - ("install-lib=", None, ""), - ("install-platlib=", None, ""), - ("install-purelib=", None, ""), - ("install-scripts=", None, ""), - ("prefix=", None, ""), - ("root=", None, ""), - ("user", None, ""), -] - - -# typeshed doesn't permit Tuple[str, None, str], see python/typeshed#3469. -_distutils_getopt = FancyGetopt(_options) # type: ignore - - -def parse_distutils_args(args): - # type: (List[str]) -> Dict[str, str] - """Parse provided arguments, returning an object that has the - matched arguments. - - Any unknown arguments are ignored. - """ - result = {} - for arg in args: - try: - _, match = _distutils_getopt.getopt(args=[arg]) - except DistutilsArgError: - # We don't care about any other options, which here may be - # considered unrecognized since our option list is not - # exhaustive. - pass - else: - result.update(match.__dict__) - return result diff --git a/env/Lib/site-packages/pip/_internal/utils/encoding.py b/env/Lib/site-packages/pip/_internal/utils/encoding.py index 7c8893d5..008f06a7 100644 --- a/env/Lib/site-packages/pip/_internal/utils/encoding.py +++ b/env/Lib/site-packages/pip/_internal/utils/encoding.py @@ -4,7 +4,7 @@ import re import sys from typing import List, Tuple -BOMS = [ +BOMS: List[Tuple[bytes, str]] = [ (codecs.BOM_UTF8, "utf-8"), (codecs.BOM_UTF16, "utf-16"), (codecs.BOM_UTF16_BE, "utf-16-be"), @@ -12,13 +12,12 @@ BOMS = [ (codecs.BOM_UTF32, "utf-32"), (codecs.BOM_UTF32_BE, "utf-32-be"), (codecs.BOM_UTF32_LE, "utf-32-le"), -] # type: List[Tuple[bytes, str]] +] -ENCODING_RE = re.compile(br"coding[:=]\s*([-\w.]+)") +ENCODING_RE = re.compile(rb"coding[:=]\s*([-\w.]+)") -def auto_decode(data): - # type: (bytes) -> str +def auto_decode(data: bytes) -> str: """Check a bytes string for a BOM to correctly detect the encoding Fallback to locale.getpreferredencoding(False) like open() on Python3""" diff --git a/env/Lib/site-packages/pip/_internal/utils/entrypoints.py b/env/Lib/site-packages/pip/_internal/utils/entrypoints.py index 879bf21a..15013693 100644 --- a/env/Lib/site-packages/pip/_internal/utils/entrypoints.py +++ b/env/Lib/site-packages/pip/_internal/utils/entrypoints.py @@ -1,11 +1,26 @@ +import itertools +import os +import shutil import sys from typing import List, Optional from pip._internal.cli.main import main +from pip._internal.utils.compat import WINDOWS +_EXECUTABLE_NAMES = [ + "pip", + f"pip{sys.version_info.major}", + f"pip{sys.version_info.major}.{sys.version_info.minor}", +] +if WINDOWS: + _allowed_extensions = {"", ".exe"} + _EXECUTABLE_NAMES = [ + "".join(parts) + for parts in itertools.product(_EXECUTABLE_NAMES, _allowed_extensions) + ] -def _wrapper(args=None): - # type: (Optional[List[str]]) -> int + +def _wrapper(args: Optional[List[str]] = None) -> int: """Central wrapper for all old entrypoints. Historically pip has had several entrypoints defined. Because of issues @@ -26,3 +41,44 @@ def _wrapper(args=None): "running pip directly.\n" ) return main(args) + + +def get_best_invocation_for_this_pip() -> str: + """Try to figure out the best way to invoke pip in the current environment.""" + binary_directory = "Scripts" if WINDOWS else "bin" + binary_prefix = os.path.join(sys.prefix, binary_directory) + + # Try to use pip[X[.Y]] names, if those executables for this environment are + # the first on PATH with that name. + path_parts = os.path.normcase(os.environ.get("PATH", "")).split(os.pathsep) + exe_are_in_PATH = os.path.normcase(binary_prefix) in path_parts + if exe_are_in_PATH: + for exe_name in _EXECUTABLE_NAMES: + found_executable = shutil.which(exe_name) + binary_executable = os.path.join(binary_prefix, exe_name) + if ( + found_executable + and os.path.exists(binary_executable) + and os.path.samefile( + found_executable, + binary_executable, + ) + ): + return exe_name + + # Use the `-m` invocation, if there's no "nice" invocation. + return f"{get_best_invocation_for_this_python()} -m pip" + + +def get_best_invocation_for_this_python() -> str: + """Try to figure out the best way to invoke the current Python.""" + exe = sys.executable + exe_name = os.path.basename(exe) + + # Try to use the basename, if it's the first executable. + found_executable = shutil.which(exe_name) + if found_executable and os.path.samefile(found_executable, exe): + return exe_name + + # Use the full executable name, because we couldn't find something simpler. + return exe diff --git a/env/Lib/site-packages/pip/_internal/utils/filesystem.py b/env/Lib/site-packages/pip/_internal/utils/filesystem.py index 3db97dc4..83c2df75 100644 --- a/env/Lib/site-packages/pip/_internal/utils/filesystem.py +++ b/env/Lib/site-packages/pip/_internal/utils/filesystem.py @@ -2,12 +2,10 @@ import fnmatch import os import os.path import random -import shutil -import stat import sys from contextlib import contextmanager from tempfile import NamedTemporaryFile -from typing import Any, BinaryIO, Iterator, List, Union, cast +from typing import Any, BinaryIO, Generator, List, Union, cast from pip._vendor.tenacity import retry, stop_after_delay, wait_fixed @@ -15,8 +13,7 @@ from pip._internal.utils.compat import get_path_uid from pip._internal.utils.misc import format_size -def check_path_owner(path): - # type: (str) -> bool +def check_path_owner(path: str) -> bool: # If we don't have a way to check the effective uid of this process, then # we'll just assume that we own the directory. if sys.platform == "win32" or not hasattr(os, "geteuid"): @@ -43,38 +40,8 @@ def check_path_owner(path): return False # assume we don't own the path -def copy2_fixed(src, dest): - # type: (str, str) -> None - """Wrap shutil.copy2() but map errors copying socket files to - SpecialFileError as expected. - - See also https://bugs.python.org/issue37700. - """ - try: - shutil.copy2(src, dest) - except OSError: - for f in [src, dest]: - try: - is_socket_file = is_socket(f) - except OSError: - # An error has already occurred. Another error here is not - # a problem and we can ignore it. - pass - else: - if is_socket_file: - raise shutil.SpecialFileError(f"`{f}` is a socket") - - raise - - -def is_socket(path): - # type: (str) -> bool - return stat.S_ISSOCK(os.lstat(path).st_mode) - - @contextmanager -def adjacent_tmp_file(path, **kwargs): - # type: (str, **Any) -> Iterator[BinaryIO] +def adjacent_tmp_file(path: str, **kwargs: Any) -> Generator[BinaryIO, None, None]: """Return a file-like object pointing to a tmp file next to path. The file is created securely and is ensured to be written to disk @@ -98,7 +65,7 @@ def adjacent_tmp_file(path, **kwargs): os.fsync(result.fileno()) -# Tenacity raises RetryError by default, explictly raise the original exception +# Tenacity raises RetryError by default, explicitly raise the original exception _replace_retry = retry(reraise=True, stop=stop_after_delay(1), wait=wait_fixed(0.25)) replace = _replace_retry(os.replace) @@ -106,8 +73,7 @@ replace = _replace_retry(os.replace) # test_writable_dir and _test_writable_dir_win are copied from Flit, # with the author's agreement to also place them under pip's license. -def test_writable_dir(path): - # type: (str) -> bool +def test_writable_dir(path: str) -> bool: """Check if a directory is writable. Uses os.access() on POSIX, tries creating files on Windows. @@ -125,8 +91,7 @@ def test_writable_dir(path): return _test_writable_dir_win(path) -def _test_writable_dir_win(path): - # type: (str) -> bool +def _test_writable_dir_win(path: str) -> bool: # os.access doesn't work on Windows: http://bugs.python.org/issue2528 # and we can't use tempfile: http://bugs.python.org/issue22107 basename = "accesstest_deleteme_fishfingers_custard_" @@ -154,32 +119,28 @@ def _test_writable_dir_win(path): raise OSError("Unexpected condition testing for writable directory") -def find_files(path, pattern): - # type: (str, str) -> List[str] +def find_files(path: str, pattern: str) -> List[str]: """Returns a list of absolute paths of files beneath path, recursively, with filenames which match the UNIX-style shell glob pattern.""" - result = [] # type: List[str] + result: List[str] = [] for root, _, files in os.walk(path): matches = fnmatch.filter(files, pattern) result.extend(os.path.join(root, f) for f in matches) return result -def file_size(path): - # type: (str) -> Union[int, float] +def file_size(path: str) -> Union[int, float]: # If it's a symlink, return 0. if os.path.islink(path): return 0 return os.path.getsize(path) -def format_file_size(path): - # type: (str) -> str +def format_file_size(path: str) -> str: return format_size(file_size(path)) -def directory_size(path): - # type: (str) -> Union[int, float] +def directory_size(path: str) -> Union[int, float]: size = 0.0 for root, _dirs, files in os.walk(path): for filename in files: @@ -188,6 +149,5 @@ def directory_size(path): return size -def format_directory_size(path): - # type: (str) -> str +def format_directory_size(path: str) -> str: return format_size(directory_size(path)) diff --git a/env/Lib/site-packages/pip/_internal/utils/filetypes.py b/env/Lib/site-packages/pip/_internal/utils/filetypes.py index da935846..59485701 100644 --- a/env/Lib/site-packages/pip/_internal/utils/filetypes.py +++ b/env/Lib/site-packages/pip/_internal/utils/filetypes.py @@ -6,21 +6,20 @@ from typing import Tuple from pip._internal.utils.misc import splitext WHEEL_EXTENSION = ".whl" -BZ2_EXTENSIONS = (".tar.bz2", ".tbz") # type: Tuple[str, ...] -XZ_EXTENSIONS = ( +BZ2_EXTENSIONS: Tuple[str, ...] = (".tar.bz2", ".tbz") +XZ_EXTENSIONS: Tuple[str, ...] = ( ".tar.xz", ".txz", ".tlz", ".tar.lz", ".tar.lzma", -) # type: Tuple[str, ...] -ZIP_EXTENSIONS = (".zip", WHEEL_EXTENSION) # type: Tuple[str, ...] -TAR_EXTENSIONS = (".tar.gz", ".tgz", ".tar") # type: Tuple[str, ...] +) +ZIP_EXTENSIONS: Tuple[str, ...] = (".zip", WHEEL_EXTENSION) +TAR_EXTENSIONS: Tuple[str, ...] = (".tar.gz", ".tgz", ".tar") ARCHIVE_EXTENSIONS = ZIP_EXTENSIONS + BZ2_EXTENSIONS + TAR_EXTENSIONS + XZ_EXTENSIONS -def is_archive_file(name): - # type: (str) -> bool +def is_archive_file(name: str) -> bool: """Return True if `name` is a considered as an archive file.""" ext = splitext(name)[1].lower() if ext in ARCHIVE_EXTENSIONS: diff --git a/env/Lib/site-packages/pip/_internal/utils/glibc.py b/env/Lib/site-packages/pip/_internal/utils/glibc.py index 1c9ff354..81342afa 100644 --- a/env/Lib/site-packages/pip/_internal/utils/glibc.py +++ b/env/Lib/site-packages/pip/_internal/utils/glibc.py @@ -1,19 +1,14 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - import os import sys from typing import Optional, Tuple -def glibc_version_string(): - # type: () -> Optional[str] +def glibc_version_string() -> Optional[str]: "Returns glibc version string, or None if not using glibc." return glibc_version_string_confstr() or glibc_version_string_ctypes() -def glibc_version_string_confstr(): - # type: () -> Optional[str] +def glibc_version_string_confstr() -> Optional[str]: "Primary implementation of glibc_version_string using os.confstr." # os.confstr is quite a bit faster than ctypes.DLL. It's also less likely # to be broken or missing. This strategy is used in the standard library @@ -22,16 +17,18 @@ def glibc_version_string_confstr(): if sys.platform == "win32": return None try: + gnu_libc_version = os.confstr("CS_GNU_LIBC_VERSION") + if gnu_libc_version is None: + return None # os.confstr("CS_GNU_LIBC_VERSION") returns a string like "glibc 2.17": - _, version = os.confstr("CS_GNU_LIBC_VERSION").split() + _, version = gnu_libc_version.split() except (AttributeError, OSError, ValueError): # os.confstr() or CS_GNU_LIBC_VERSION not available (or a bad value)... return None return version -def glibc_version_string_ctypes(): - # type: () -> Optional[str] +def glibc_version_string_ctypes() -> Optional[str]: "Fallback implementation of glibc_version_string using ctypes." try: @@ -78,8 +75,7 @@ def glibc_version_string_ctypes(): # versions that was generated by pip 8.1.2 and earlier is useless and # misleading. Solution: instead of using platform, use our code that actually # works. -def libc_ver(): - # type: () -> Tuple[str, str] +def libc_ver() -> Tuple[str, str]: """Try to determine the glibc version Returns a tuple of strings (lib, version) which default to empty strings diff --git a/env/Lib/site-packages/pip/_internal/utils/hashes.py b/env/Lib/site-packages/pip/_internal/utils/hashes.py index 3d20b8d0..843cffc6 100644 --- a/env/Lib/site-packages/pip/_internal/utils/hashes.py +++ b/env/Lib/site-packages/pip/_internal/utils/hashes.py @@ -1,5 +1,5 @@ import hashlib -from typing import TYPE_CHECKING, BinaryIO, Dict, Iterator, List +from typing import TYPE_CHECKING, BinaryIO, Dict, Iterable, List, Optional from pip._internal.exceptions import HashMismatch, HashMissing, InstallationError from pip._internal.utils.misc import read_chunks @@ -28,8 +28,7 @@ class Hashes: """ - def __init__(self, hashes=None): - # type: (Dict[str, List[str]]) -> None + def __init__(self, hashes: Optional[Dict[str, List[str]]] = None) -> None: """ :param hashes: A dict of algorithm names pointing to lists of allowed hex digests @@ -41,8 +40,7 @@ class Hashes: allowed[alg] = sorted(keys) self._allowed = allowed - def __and__(self, other): - # type: (Hashes) -> Hashes + def __and__(self, other: "Hashes") -> "Hashes": if not isinstance(other, Hashes): return NotImplemented @@ -62,21 +60,14 @@ class Hashes: return Hashes(new) @property - def digest_count(self): - # type: () -> int + def digest_count(self) -> int: return sum(len(digests) for digests in self._allowed.values()) - def is_hash_allowed( - self, - hash_name, # type: str - hex_digest, # type: str - ): - # type: (...) -> bool + def is_hash_allowed(self, hash_name: str, hex_digest: str) -> bool: """Return whether the given hex digest is allowed.""" return hex_digest in self._allowed.get(hash_name, []) - def check_against_chunks(self, chunks): - # type: (Iterator[bytes]) -> None + def check_against_chunks(self, chunks: Iterable[bytes]) -> None: """Check good hashes against ones built from iterable of chunks of data. @@ -99,12 +90,10 @@ class Hashes: return self._raise(gots) - def _raise(self, gots): - # type: (Dict[str, _Hash]) -> NoReturn + def _raise(self, gots: Dict[str, "_Hash"]) -> "NoReturn": raise HashMismatch(self._allowed, gots) - def check_against_file(self, file): - # type: (BinaryIO) -> None + def check_against_file(self, file: BinaryIO) -> None: """Check good hashes against a file-like object Raise HashMismatch if none match. @@ -112,28 +101,27 @@ class Hashes: """ return self.check_against_chunks(read_chunks(file)) - def check_against_path(self, path): - # type: (str) -> None + def check_against_path(self, path: str) -> None: with open(path, "rb") as file: return self.check_against_file(file) - def __nonzero__(self): - # type: () -> bool + def has_one_of(self, hashes: Dict[str, str]) -> bool: + """Return whether any of the given hashes are allowed.""" + for hash_name, hex_digest in hashes.items(): + if self.is_hash_allowed(hash_name, hex_digest): + return True + return False + + def __bool__(self) -> bool: """Return whether I know any known-good hashes.""" return bool(self._allowed) - def __bool__(self): - # type: () -> bool - return self.__nonzero__() - - def __eq__(self, other): - # type: (object) -> bool + def __eq__(self, other: object) -> bool: if not isinstance(other, Hashes): return NotImplemented return self._allowed == other._allowed - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash( ",".join( sorted( @@ -153,13 +141,11 @@ class MissingHashes(Hashes): """ - def __init__(self): - # type: () -> None + def __init__(self) -> None: """Don't offer the ``hashes`` kwarg.""" # Pass our favorite hash in to generate a "gotten hash". With the # empty list, it will never match, so an error will always raise. super().__init__(hashes={FAVORITE_HASH: []}) - def _raise(self, gots): - # type: (Dict[str, _Hash]) -> NoReturn + def _raise(self, gots: Dict[str, "_Hash"]) -> "NoReturn": raise HashMissing(gots[FAVORITE_HASH].hexdigest()) diff --git a/env/Lib/site-packages/pip/_internal/utils/inject_securetransport.py b/env/Lib/site-packages/pip/_internal/utils/inject_securetransport.py index b6863d93..276aa79b 100644 --- a/env/Lib/site-packages/pip/_internal/utils/inject_securetransport.py +++ b/env/Lib/site-packages/pip/_internal/utils/inject_securetransport.py @@ -10,8 +10,7 @@ old to handle TLSv1.2. import sys -def inject_securetransport(): - # type: () -> None +def inject_securetransport() -> None: # Only relevant on macOS if sys.platform != "darwin": return diff --git a/env/Lib/site-packages/pip/_internal/utils/logging.py b/env/Lib/site-packages/pip/_internal/utils/logging.py index 45798d54..c10e1f4c 100644 --- a/env/Lib/site-packages/pip/_internal/utils/logging.py +++ b/env/Lib/site-packages/pip/_internal/utils/logging.py @@ -4,27 +4,30 @@ import logging import logging.handlers import os import sys -from logging import Filter, getLogger -from typing import IO, Any, Callable, Iterator, Optional, TextIO, Type, cast - +import threading +from dataclasses import dataclass +from io import TextIOWrapper +from logging import Filter +from typing import Any, ClassVar, Generator, List, Optional, TextIO, Type + +from pip._vendor.rich.console import ( + Console, + ConsoleOptions, + ConsoleRenderable, + RenderableType, + RenderResult, + RichCast, +) +from pip._vendor.rich.highlighter import NullHighlighter +from pip._vendor.rich.logging import RichHandler +from pip._vendor.rich.segment import Segment +from pip._vendor.rich.style import Style + +from pip._internal.utils._log import VERBOSE, getLogger from pip._internal.utils.compat import WINDOWS from pip._internal.utils.deprecation import DEPRECATION_MSG_PREFIX from pip._internal.utils.misc import ensure_dir -try: - import threading -except ImportError: - import dummy_threading as threading # type: ignore - - -try: - from pip._vendor import colorama -# Lots of different errors can come from this, including SystemError and -# ImportError. -except Exception: - colorama = None - - _log_state = threading.local() subprocess_logger = getLogger("pip.subprocessor") @@ -34,39 +37,22 @@ class BrokenStdoutLoggingError(Exception): Raised if BrokenPipeError occurs for the stdout stream while logging. """ - pass +def _is_broken_pipe_error(exc_class: Type[BaseException], exc: BaseException) -> bool: + if exc_class is BrokenPipeError: + return True -# BrokenPipeError manifests differently in Windows and non-Windows. -if WINDOWS: - # In Windows, a broken pipe can show up as EINVAL rather than EPIPE: + # On Windows, a broken pipe can show up as EINVAL rather than EPIPE: # https://bugs.python.org/issue19612 # https://bugs.python.org/issue30418 - def _is_broken_pipe_error(exc_class, exc): - # type: (Type[BaseException], BaseException) -> bool - """See the docstring for non-Windows below.""" - return (exc_class is BrokenPipeError) or ( - isinstance(exc, OSError) and exc.errno in (errno.EINVAL, errno.EPIPE) - ) - - -else: - # Then we are in the non-Windows case. - def _is_broken_pipe_error(exc_class, exc): - # type: (Type[BaseException], BaseException) -> bool - """ - Return whether an exception is a broken pipe error. + if not WINDOWS: + return False - Args: - exc_class: an exception class. - exc: an exception instance. - """ - return exc_class is BrokenPipeError + return isinstance(exc, OSError) and exc.errno in (errno.EINVAL, errno.EPIPE) @contextlib.contextmanager -def indent_log(num=2): - # type: (int) -> Iterator[None] +def indent_log(num: int = 2) -> Generator[None, None, None]: """ A context manager which will cause the log output to be indented for any log messages emitted inside it. @@ -80,8 +66,7 @@ def indent_log(num=2): _log_state.indentation -= num -def get_indentation(): - # type: () -> int +def get_indentation() -> int: return getattr(_log_state, "indentation", 0) @@ -90,11 +75,10 @@ class IndentingFormatter(logging.Formatter): def __init__( self, - *args, # type: Any - add_timestamp=False, # type: bool - **kwargs, # type: Any - ): - # type: (...) -> None + *args: Any, + add_timestamp: bool = False, + **kwargs: Any, + ) -> None: """ A logging.Formatter that obeys the indent_log() context manager. @@ -104,8 +88,7 @@ class IndentingFormatter(logging.Formatter): self.add_timestamp = add_timestamp super().__init__(*args, **kwargs) - def get_message_start(self, formatted, levelno): - # type: (str, int) -> str + def get_message_start(self, formatted: str, levelno: int) -> str: """ Return the start of the formatted log message (not counting the prefix to add to each line). @@ -121,8 +104,7 @@ class IndentingFormatter(logging.Formatter): return "ERROR: " - def format(self, record): - # type: (logging.LogRecord) -> str + def format(self, record: logging.LogRecord) -> str: """ Calls the standard formatter, but will indent all of the log message lines by our current indentation level. @@ -139,85 +121,66 @@ class IndentingFormatter(logging.Formatter): return formatted -def _color_wrap(*colors): - # type: (*str) -> Callable[[str], str] - def wrapped(inp): - # type: (str) -> str - return "".join(list(colors) + [inp, colorama.Style.RESET_ALL]) - - return wrapped - - -class ColorizedStreamHandler(logging.StreamHandler): - - # Don't build up a list of colors if we don't have colorama - if colorama: - COLORS = [ - # This needs to be in order from highest logging level to lowest. - (logging.ERROR, _color_wrap(colorama.Fore.RED)), - (logging.WARNING, _color_wrap(colorama.Fore.YELLOW)), - ] - else: - COLORS = [] - - def __init__(self, stream=None, no_color=None): - # type: (Optional[TextIO], bool) -> None - super().__init__(stream) - self._no_color = no_color - - if WINDOWS and colorama: - self.stream = colorama.AnsiToWin32(self.stream) - - def _using_stdout(self): - # type: () -> bool - """ - Return whether the handler is using sys.stdout. - """ - if WINDOWS and colorama: - # Then self.stream is an AnsiToWin32 object. - stream = cast(colorama.AnsiToWin32, self.stream) - return stream.wrapped is sys.stdout - - return self.stream is sys.stdout - - def should_color(self): - # type: () -> bool - # Don't colorize things if we do not have colorama or if told not to - if not colorama or self._no_color: - return False - - real_stream = ( - self.stream - if not isinstance(self.stream, colorama.AnsiToWin32) - else self.stream.wrapped +@dataclass +class IndentedRenderable: + renderable: RenderableType + indent: int + + def __rich_console__( + self, console: Console, options: ConsoleOptions + ) -> RenderResult: + segments = console.render(self.renderable, options) + lines = Segment.split_lines(segments) + for line in lines: + yield Segment(" " * self.indent) + yield from line + yield Segment("\n") + + +class RichPipStreamHandler(RichHandler): + KEYWORDS: ClassVar[Optional[List[str]]] = [] + + def __init__(self, stream: Optional[TextIO], no_color: bool) -> None: + super().__init__( + console=Console(file=stream, no_color=no_color, soft_wrap=True), + show_time=False, + show_level=False, + show_path=False, + highlighter=NullHighlighter(), ) - # If the stream is a tty we should color it - if hasattr(real_stream, "isatty") and real_stream.isatty(): - return True - - # If we have an ANSI term we should color it - if os.environ.get("TERM") == "ANSI": - return True + # Our custom override on Rich's logger, to make things work as we need them to. + def emit(self, record: logging.LogRecord) -> None: + style: Optional[Style] = None + + # If we are given a diagnostic error to present, present it with indentation. + assert isinstance(record.args, tuple) + if record.msg == "[present-rich] %s" and len(record.args) == 1: + rich_renderable = record.args[0] + assert isinstance( + rich_renderable, (ConsoleRenderable, RichCast, str) + ), f"{rich_renderable} is not rich-console-renderable" + + renderable: RenderableType = IndentedRenderable( + rich_renderable, indent=get_indentation() + ) + else: + message = self.format(record) + renderable = self.render_message(record, message) + if record.levelno is not None: + if record.levelno >= logging.ERROR: + style = Style(color="red") + elif record.levelno >= logging.WARNING: + style = Style(color="yellow") + + try: + self.console.print(renderable, overflow="ignore", crop=False, style=style) + except Exception: + self.handleError(record) + + def handleError(self, record: logging.LogRecord) -> None: + """Called when logging is unable to log some output.""" - # If anything else we should not color it - return False - - def format(self, record): - # type: (logging.LogRecord) -> str - msg = super().format(record) - - if self.should_color(): - for level, color in self.COLORS: - if record.levelno >= level: - msg = color(msg) - break - - return msg - - # The logging module says handleError() can be customized. - def handleError(self, record): - # type: (logging.LogRecord) -> None exc_class, exc = sys.exc_info()[:2] # If a broken pipe occurred while calling write() or flush() on the # stdout stream in logging's Handler.emit(), then raise our special @@ -226,7 +189,7 @@ class ColorizedStreamHandler(logging.StreamHandler): if ( exc_class and exc - and self._using_stdout() + and self.console.file is sys.stdout and _is_broken_pipe_error(exc_class, exc) ): raise BrokenStdoutLoggingError() @@ -235,19 +198,16 @@ class ColorizedStreamHandler(logging.StreamHandler): class BetterRotatingFileHandler(logging.handlers.RotatingFileHandler): - def _open(self): - # type: () -> IO[Any] + def _open(self) -> TextIOWrapper: ensure_dir(os.path.dirname(self.baseFilename)) return super()._open() class MaxLevelFilter(Filter): - def __init__(self, level): - # type: (int) -> None + def __init__(self, level: int) -> None: self.level = level - def filter(self, record): - # type: (logging.LogRecord) -> bool + def filter(self, record: logging.LogRecord) -> bool: return record.levelno < self.level @@ -257,33 +217,33 @@ class ExcludeLoggerFilter(Filter): A logging Filter that excludes records from a logger (or its children). """ - def filter(self, record): - # type: (logging.LogRecord) -> bool + def filter(self, record: logging.LogRecord) -> bool: # The base Filter class allows only records from a logger (or its # children). return not super().filter(record) -def setup_logging(verbosity, no_color, user_log_file): - # type: (int, bool, Optional[str]) -> int +def setup_logging(verbosity: int, no_color: bool, user_log_file: Optional[str]) -> int: """Configures and sets up all of the logging Returns the requested logging level, as its integer value. """ # Determine the level to be logging at. - if verbosity >= 1: - level = "DEBUG" + if verbosity >= 2: + level_number = logging.DEBUG + elif verbosity == 1: + level_number = VERBOSE elif verbosity == -1: - level = "WARNING" + level_number = logging.WARNING elif verbosity == -2: - level = "ERROR" + level_number = logging.ERROR elif verbosity <= -3: - level = "CRITICAL" + level_number = logging.CRITICAL else: - level = "INFO" + level_number = logging.INFO - level_number = getattr(logging, level) + level = logging.getLevelName(level_number) # The "root" logger should match the "console" level *unless* we also need # to log to a user log file. @@ -305,7 +265,7 @@ def setup_logging(verbosity, no_color, user_log_file): "stderr": "ext://sys.stderr", } handler_classes = { - "stream": "pip._internal.utils.logging.ColorizedStreamHandler", + "stream": "pip._internal.utils.logging.RichPipStreamHandler", "file": "pip._internal.utils.logging.BetterRotatingFileHandler", } handlers = ["console", "console_errors", "console_subprocess"] + ( @@ -363,8 +323,8 @@ def setup_logging(verbosity, no_color, user_log_file): "console_subprocess": { "level": level, "class": handler_classes["stream"], - "no_color": no_color, "stream": log_streams["stderr"], + "no_color": no_color, "filters": ["restrict_to_subprocess"], "formatter": "indent", }, @@ -372,6 +332,7 @@ def setup_logging(verbosity, no_color, user_log_file): "level": "DEBUG", "class": handler_classes["file"], "filename": additional_log_file, + "encoding": "utf-8", "delay": True, "formatter": "indent_with_timestamp", }, diff --git a/env/Lib/site-packages/pip/_internal/utils/misc.py b/env/Lib/site-packages/pip/_internal/utils/misc.py index a4ad35be..bd191c4e 100644 --- a/env/Lib/site-packages/pip/_internal/utils/misc.py +++ b/env/Lib/site-packages/pip/_internal/utils/misc.py @@ -1,6 +1,3 @@ -# The following comment should be removed at some point in the future. -# mypy: strict-optional=False - import contextlib import errno import getpass @@ -12,17 +9,18 @@ import posixpath import shutil import stat import sys +import sysconfig import urllib.parse from io import StringIO from itertools import filterfalse, tee, zip_longest from types import TracebackType from typing import ( Any, - AnyStr, BinaryIO, Callable, - Container, ContextManager, + Dict, + Generator, Iterable, Iterator, List, @@ -31,20 +29,18 @@ from typing import ( Tuple, Type, TypeVar, + Union, cast, ) -from pip._vendor.pkg_resources import Distribution +from pip._vendor.pyproject_hooks import BuildBackendHookCaller from pip._vendor.tenacity import retry, stop_after_delay, wait_fixed from pip import __version__ -from pip._internal.exceptions import CommandError -from pip._internal.locations import get_major_minor_version, site_packages, user_site -from pip._internal.utils.compat import WINDOWS, stdlib_pkgs -from pip._internal.utils.virtualenv import ( - running_under_virtualenv, - virtualenv_no_global, -) +from pip._internal.exceptions import CommandError, ExternallyManagedEnvironment +from pip._internal.locations import get_major_minor_version +from pip._internal.utils.compat import WINDOWS +from pip._internal.utils.virtualenv import running_under_virtualenv __all__ = [ "rmtree", @@ -60,9 +56,10 @@ __all__ = [ "captured_stdout", "ensure_dir", "remove_auth_from_url", + "check_externally_managed", + "ConfiguredBuildBackendHookCaller", ] - logger = logging.getLogger(__name__) T = TypeVar("T") @@ -71,8 +68,7 @@ VersionInfo = Tuple[int, int, int] NetlocTuple = Tuple[str, Tuple[Optional[str], Optional[str]]] -def get_pip_version(): - # type: () -> str +def get_pip_version() -> str: pip_pkg_dir = os.path.join(os.path.dirname(__file__), "..", "..") pip_pkg_dir = os.path.abspath(pip_pkg_dir) @@ -83,8 +79,7 @@ def get_pip_version(): ) -def normalize_version_info(py_version_info): - # type: (Tuple[int, ...]) -> Tuple[int, int, int] +def normalize_version_info(py_version_info: Tuple[int, ...]) -> Tuple[int, int, int]: """ Convert a tuple of ints representing a Python version to one of length three. @@ -103,8 +98,7 @@ def normalize_version_info(py_version_info): return cast("VersionInfo", py_version_info) -def ensure_dir(path): - # type: (AnyStr) -> None +def ensure_dir(path: str) -> None: """os.path.makedirs without EEXIST.""" try: os.makedirs(path) @@ -114,8 +108,7 @@ def ensure_dir(path): raise -def get_prog(): - # type: () -> str +def get_prog() -> str: try: prog = os.path.basename(sys.argv[0]) if prog in ("__main__.py", "-c"): @@ -128,15 +121,18 @@ def get_prog(): # Retry every half second for up to 3 seconds -# Tenacity raises RetryError by default, explictly raise the original exception +# Tenacity raises RetryError by default, explicitly raise the original exception @retry(reraise=True, stop=stop_after_delay(3), wait=wait_fixed(0.5)) -def rmtree(dir, ignore_errors=False): - # type: (AnyStr, bool) -> None - shutil.rmtree(dir, ignore_errors=ignore_errors, onerror=rmtree_errorhandler) +def rmtree(dir: str, ignore_errors: bool = False) -> None: + if sys.version_info >= (3, 12): + shutil.rmtree(dir, ignore_errors=ignore_errors, onexc=rmtree_errorhandler) + else: + shutil.rmtree(dir, ignore_errors=ignore_errors, onerror=rmtree_errorhandler) -def rmtree_errorhandler(func, path, exc_info): - # type: (Callable[..., Any], str, ExcInfo) -> None +def rmtree_errorhandler( + func: Callable[..., Any], path: str, exc_info: Union[ExcInfo, BaseException] +) -> None: """On Windows, the files in .svn are read-only, so when rmtree() tries to remove them, an exception is thrown. We catch that here, remove the read-only attribute, and hopefully continue without problems.""" @@ -156,8 +152,7 @@ def rmtree_errorhandler(func, path, exc_info): raise -def display_path(path): - # type: (str) -> str +def display_path(path: str) -> str: """Gives the display value for a given path, making it relative to cwd if possible.""" path = os.path.normcase(os.path.abspath(path)) @@ -166,8 +161,7 @@ def display_path(path): return path -def backup_dir(dir, ext=".bak"): - # type: (str, str) -> str +def backup_dir(dir: str, ext: str = ".bak") -> str: """Figure out the name of a directory to back up the given dir to (adding .bak, .bak2, etc)""" n = 1 @@ -178,16 +172,14 @@ def backup_dir(dir, ext=".bak"): return dir + extension -def ask_path_exists(message, options): - # type: (str, Iterable[str]) -> str +def ask_path_exists(message: str, options: Iterable[str]) -> str: for action in os.environ.get("PIP_EXISTS_ACTION", "").split(): if action in options: return action return ask(message, options) -def _check_no_input(message): - # type: (str) -> None +def _check_no_input(message: str) -> None: """Raise an error if no input is allowed.""" if os.environ.get("PIP_NO_INPUT"): raise Exception( @@ -195,8 +187,7 @@ def _check_no_input(message): ) -def ask(message, options): - # type: (str, Iterable[str]) -> str +def ask(message: str, options: Iterable[str]) -> str: """Ask the message interactively, with the given possible responses""" while 1: _check_no_input(message) @@ -211,22 +202,19 @@ def ask(message, options): return response -def ask_input(message): - # type: (str) -> str +def ask_input(message: str) -> str: """Ask for input interactively.""" _check_no_input(message) return input(message) -def ask_password(message): - # type: (str) -> str +def ask_password(message: str) -> str: """Ask for a password interactively.""" _check_no_input(message) return getpass.getpass(message) -def strtobool(val): - # type: (str) -> int +def strtobool(val: str) -> int: """Convert a string representation of truth to true (1) or false (0). True values are 'y', 'yes', 't', 'true', 'on', and '1'; false values @@ -242,8 +230,7 @@ def strtobool(val): raise ValueError(f"invalid truth value {val!r}") -def format_size(bytes): - # type: (float) -> str +def format_size(bytes: float) -> str: if bytes > 1000 * 1000: return "{:.1f} MB".format(bytes / 1000.0 / 1000) elif bytes > 10 * 1000: @@ -254,8 +241,7 @@ def format_size(bytes): return "{} bytes".format(int(bytes)) -def tabulate(rows): - # type: (Iterable[Iterable[Any]]) -> Tuple[List[str], List[int]] +def tabulate(rows: Iterable[Iterable[Any]]) -> Tuple[List[str], List[int]]: """Return a list of formatted rows and a list of column sizes. For example:: @@ -270,17 +256,25 @@ def tabulate(rows): def is_installable_dir(path: str) -> bool: - """Is path is a directory containing pyproject.toml, setup.cfg or setup.py?""" + """Is path is a directory containing pyproject.toml or setup.py? + + If pyproject.toml exists, this is a PEP 517 project. Otherwise we look for + a legacy setuptools layout by identifying setup.py. We don't check for the + setup.cfg because using it without setup.py is only available for PEP 517 + projects, which are already covered by the pyproject.toml check. + """ if not os.path.isdir(path): return False - return any( - os.path.isfile(os.path.join(path, signifier)) - for signifier in ("pyproject.toml", "setup.cfg", "setup.py") - ) + if os.path.isfile(os.path.join(path, "pyproject.toml")): + return True + if os.path.isfile(os.path.join(path, "setup.py")): + return True + return False -def read_chunks(file, size=io.DEFAULT_BUFFER_SIZE): - # type: (BinaryIO, int) -> Iterator[bytes] +def read_chunks( + file: BinaryIO, size: int = io.DEFAULT_BUFFER_SIZE +) -> Generator[bytes, None, None]: """Yield pieces of data from a file-like object until EOF.""" while True: chunk = file.read(size) @@ -289,8 +283,7 @@ def read_chunks(file, size=io.DEFAULT_BUFFER_SIZE): yield chunk -def normalize_path(path, resolve_symlinks=True): - # type: (str, bool) -> str +def normalize_path(path: str, resolve_symlinks: bool = True) -> str: """ Convert a path to its canonical, case-normalized, absolute version. @@ -303,8 +296,7 @@ def normalize_path(path, resolve_symlinks=True): return os.path.normcase(path) -def splitext(path): - # type: (str) -> Tuple[str, str] +def splitext(path: str) -> Tuple[str, str]: """Like os.path.splitext, but take off .tar too""" base, ext = posixpath.splitext(path) if base.lower().endswith(".tar"): @@ -313,8 +305,7 @@ def splitext(path): return base, ext -def renames(old, new): - # type: (str, str) -> None +def renames(old: str, new: str) -> None: """Like os.renames(), but handles renaming across devices.""" # Implementation borrowed from os.renames(). head, tail = os.path.split(new) @@ -331,8 +322,7 @@ def renames(old, new): pass -def is_local(path): - # type: (str) -> bool +def is_local(path: str) -> bool: """ Return True if path is within sys.prefix, if we're running in a virtualenv. @@ -346,171 +336,28 @@ def is_local(path): return path.startswith(normalize_path(sys.prefix)) -def dist_is_local(dist): - # type: (Distribution) -> bool - """ - Return True if given Distribution object is installed locally - (i.e. within current virtualenv). - - Always True if we're not in a virtualenv. - - """ - return is_local(dist_location(dist)) - - -def dist_in_usersite(dist): - # type: (Distribution) -> bool - """ - Return True if given Distribution is installed in user site. - """ - return dist_location(dist).startswith(normalize_path(user_site)) - - -def dist_in_site_packages(dist): - # type: (Distribution) -> bool - """ - Return True if given Distribution is installed in - sysconfig.get_python_lib(). - """ - return dist_location(dist).startswith(normalize_path(site_packages)) - - -def dist_is_editable(dist): - # type: (Distribution) -> bool - """ - Return True if given Distribution is an editable install. - """ - for path_item in sys.path: - egg_link = os.path.join(path_item, dist.project_name + ".egg-link") - if os.path.isfile(egg_link): - return True - return False - - -def get_installed_distributions( - local_only=True, # type: bool - skip=stdlib_pkgs, # type: Container[str] - include_editables=True, # type: bool - editables_only=False, # type: bool - user_only=False, # type: bool - paths=None, # type: Optional[List[str]] -): - # type: (...) -> List[Distribution] - """Return a list of installed Distribution objects. - - Left for compatibility until direct pkg_resources uses are refactored out. - """ - from pip._internal.metadata import get_default_environment, get_environment - from pip._internal.metadata.pkg_resources import Distribution as _Dist - - if paths is None: - env = get_default_environment() - else: - env = get_environment(paths) - dists = env.iter_installed_distributions( - local_only=local_only, - skip=skip, - include_editables=include_editables, - editables_only=editables_only, - user_only=user_only, - ) - return [cast(_Dist, dist)._dist for dist in dists] - - -def get_distribution(req_name): - # type: (str) -> Optional[Distribution] - """Given a requirement name, return the installed Distribution object. - - This searches from *all* distributions available in the environment, to - match the behavior of ``pkg_resources.get_distribution()``. - - Left for compatibility until direct pkg_resources uses are refactored out. - """ - from pip._internal.metadata import get_default_environment - from pip._internal.metadata.pkg_resources import Distribution as _Dist - - dist = get_default_environment().get_distribution(req_name) - if dist is None: - return None - return cast(_Dist, dist)._dist - - -def egg_link_path(dist): - # type: (Distribution) -> Optional[str] - """ - Return the path for the .egg-link file if it exists, otherwise, None. - - There's 3 scenarios: - 1) not in a virtualenv - try to find in site.USER_SITE, then site_packages - 2) in a no-global virtualenv - try to find in site_packages - 3) in a yes-global virtualenv - try to find in site_packages, then site.USER_SITE - (don't look in global location) - - For #1 and #3, there could be odd cases, where there's an egg-link in 2 - locations. - - This method will just return the first one found. - """ - sites = [] - if running_under_virtualenv(): - sites.append(site_packages) - if not virtualenv_no_global() and user_site: - sites.append(user_site) - else: - if user_site: - sites.append(user_site) - sites.append(site_packages) - - for site in sites: - egglink = os.path.join(site, dist.project_name) + ".egg-link" - if os.path.isfile(egglink): - return egglink - return None - - -def dist_location(dist): - # type: (Distribution) -> str - """ - Get the site-packages location of this distribution. Generally - this is dist.location, except in the case of develop-installed - packages, where dist.location is the source code location, and we - want to know where the egg-link file is. - - The returned location is normalized (in particular, with symlinks removed). - """ - egg_link = egg_link_path(dist) - if egg_link: - return normalize_path(egg_link) - return normalize_path(dist.location) - - -def write_output(msg, *args): - # type: (Any, Any) -> None +def write_output(msg: Any, *args: Any) -> None: logger.info(msg, *args) class StreamWrapper(StringIO): - orig_stream = None # type: TextIO + orig_stream: TextIO @classmethod - def from_stream(cls, orig_stream): - # type: (TextIO) -> StreamWrapper - cls.orig_stream = orig_stream - return cls() + def from_stream(cls, orig_stream: TextIO) -> "StreamWrapper": + ret = cls() + ret.orig_stream = orig_stream + return ret # compileall.compile_dir() needs stdout.encoding to print to stdout - # https://github.com/python/mypy/issues/4125 + # type ignore is because TextIOBase.encoding is writeable @property - def encoding(self): # type: ignore + def encoding(self) -> str: # type: ignore return self.orig_stream.encoding @contextlib.contextmanager -def captured_output(stream_name): - # type: (str) -> Iterator[StreamWrapper] +def captured_output(stream_name: str) -> Generator[StreamWrapper, None, None]: """Return a context manager used by captured_stdout/stdin/stderr that temporarily replaces the sys stream *stream_name* with a StringIO. @@ -524,8 +371,7 @@ def captured_output(stream_name): setattr(sys, stream_name, orig_stdout) -def captured_stdout(): - # type: () -> ContextManager[StreamWrapper] +def captured_stdout() -> ContextManager[StreamWrapper]: """Capture the output of sys.stdout: with captured_stdout() as stdout: @@ -537,8 +383,7 @@ def captured_stdout(): return captured_output("stdout") -def captured_stderr(): - # type: () -> ContextManager[StreamWrapper] +def captured_stderr() -> ContextManager[StreamWrapper]: """ See captured_stdout(). """ @@ -546,16 +391,14 @@ def captured_stderr(): # Simulates an enum -def enum(*sequential, **named): - # type: (*Any, **Any) -> Type[Any] +def enum(*sequential: Any, **named: Any) -> Type[Any]: enums = dict(zip(sequential, range(len(sequential))), **named) reverse = {value: key for key, value in enums.items()} enums["reverse_mapping"] = reverse return type("Enum", (), enums) -def build_netloc(host, port): - # type: (str, Optional[int]) -> str +def build_netloc(host: str, port: Optional[int]) -> str: """ Build a netloc from a host-port pair """ @@ -567,8 +410,7 @@ def build_netloc(host, port): return f"{host}:{port}" -def build_url_from_netloc(netloc, scheme="https"): - # type: (str, str) -> str +def build_url_from_netloc(netloc: str, scheme: str = "https") -> str: """ Build a full URL from a netloc. """ @@ -578,8 +420,7 @@ def build_url_from_netloc(netloc, scheme="https"): return f"{scheme}://{netloc}" -def parse_netloc(netloc): - # type: (str) -> Tuple[str, Optional[int]] +def parse_netloc(netloc: str) -> Tuple[Optional[str], Optional[int]]: """ Return the host-port pair from a netloc. """ @@ -588,8 +429,7 @@ def parse_netloc(netloc): return parsed.hostname, parsed.port -def split_auth_from_netloc(netloc): - # type: (str) -> NetlocTuple +def split_auth_from_netloc(netloc: str) -> NetlocTuple: """ Parse out and remove the auth information from a netloc. @@ -602,7 +442,7 @@ def split_auth_from_netloc(netloc): # behaves if more than one @ is present (which can be checked using # the password attribute of urlsplit()'s return value). auth, netloc = netloc.rsplit("@", 1) - pw = None # type: Optional[str] + pw: Optional[str] = None if ":" in auth: # Split from the left because that's how urllib.parse.urlsplit() # behaves if more than one : is present (which again can be checked @@ -618,8 +458,7 @@ def split_auth_from_netloc(netloc): return netloc, (user, pw) -def redact_netloc(netloc): - # type: (str) -> str +def redact_netloc(netloc: str) -> str: """ Replace the sensitive data in a netloc with "****", if it exists. @@ -641,8 +480,9 @@ def redact_netloc(netloc): ) -def _transform_url(url, transform_netloc): - # type: (str, Callable[[str], Tuple[Any, ...]]) -> Tuple[str, NetlocTuple] +def _transform_url( + url: str, transform_netloc: Callable[[str], Tuple[Any, ...]] +) -> Tuple[str, NetlocTuple]: """Transform and replace netloc in a url. transform_netloc is a function taking the netloc and returning a @@ -660,18 +500,17 @@ def _transform_url(url, transform_netloc): return surl, cast("NetlocTuple", netloc_tuple) -def _get_netloc(netloc): - # type: (str) -> NetlocTuple +def _get_netloc(netloc: str) -> NetlocTuple: return split_auth_from_netloc(netloc) -def _redact_netloc(netloc): - # type: (str) -> Tuple[str,] +def _redact_netloc(netloc: str) -> Tuple[str]: return (redact_netloc(netloc),) -def split_auth_netloc_from_url(url): - # type: (str) -> Tuple[str, str, Tuple[str, str]] +def split_auth_netloc_from_url( + url: str, +) -> Tuple[str, str, Tuple[Optional[str], Optional[str]]]: """ Parse a url into separate netloc, auth, and url with no auth. @@ -681,41 +520,31 @@ def split_auth_netloc_from_url(url): return url_without_auth, netloc, auth -def remove_auth_from_url(url): - # type: (str) -> str +def remove_auth_from_url(url: str) -> str: """Return a copy of url with 'username:password@' removed.""" # username/pass params are passed to subversion through flags # and are not recognized in the url. return _transform_url(url, _get_netloc)[0] -def redact_auth_from_url(url): - # type: (str) -> str +def redact_auth_from_url(url: str) -> str: """Replace the password in a given url with ****.""" return _transform_url(url, _redact_netloc)[0] class HiddenText: - def __init__( - self, - secret, # type: str - redacted, # type: str - ): - # type: (...) -> None + def __init__(self, secret: str, redacted: str) -> None: self.secret = secret self.redacted = redacted - def __repr__(self): - # type: (...) -> str + def __repr__(self) -> str: return "<HiddenText {!r}>".format(str(self)) - def __str__(self): - # type: (...) -> str + def __str__(self) -> str: return self.redacted # This is useful for testing. - def __eq__(self, other): - # type: (Any) -> bool + def __eq__(self, other: Any) -> bool: if type(self) != type(other): return False @@ -724,28 +553,25 @@ class HiddenText: return self.secret == other.secret -def hide_value(value): - # type: (str) -> HiddenText +def hide_value(value: str) -> HiddenText: return HiddenText(value, redacted="****") -def hide_url(url): - # type: (str) -> HiddenText +def hide_url(url: str) -> HiddenText: redacted = redact_auth_from_url(url) return HiddenText(url, redacted=redacted) -def protect_pip_from_modification_on_windows(modifying_pip): - # type: (bool) -> None +def protect_pip_from_modification_on_windows(modifying_pip: bool) -> None: """Protection of pip.exe from modification on Windows On Windows, any operation modifying pip should be run as: python -m pip ... """ pip_names = [ - "pip.exe", - "pip{}.exe".format(sys.version_info[0]), - "pip{}.{}.exe".format(*sys.version_info[:2]), + "pip", + f"pip{sys.version_info.major}", + f"pip{sys.version_info.major}.{sys.version_info.minor}", ] # See https://github.com/pypa/pip/issues/1299 for more discussion @@ -762,14 +588,27 @@ def protect_pip_from_modification_on_windows(modifying_pip): ) -def is_console_interactive(): - # type: () -> bool +def check_externally_managed() -> None: + """Check whether the current environment is externally managed. + + If the ``EXTERNALLY-MANAGED`` config file is found, the current environment + is considered externally managed, and an ExternallyManagedEnvironment is + raised. + """ + if running_under_virtualenv(): + return + marker = os.path.join(sysconfig.get_path("stdlib"), "EXTERNALLY-MANAGED") + if not os.path.isfile(marker): + return + raise ExternallyManagedEnvironment.from_config(marker) + + +def is_console_interactive() -> bool: """Is this console interactive?""" return sys.stdin is not None and sys.stdin.isatty() -def hash_file(path, blocksize=1 << 20): - # type: (str, int) -> Tuple[Any, int] +def hash_file(path: str, blocksize: int = 1 << 20) -> Tuple[Any, int]: """Return (hash, length) for path using hashlib.sha256()""" h = hashlib.sha256() @@ -781,21 +620,7 @@ def hash_file(path, blocksize=1 << 20): return h, length -def is_wheel_installed(): - # type: () -> bool - """ - Return whether the wheel package is installed. - """ - try: - import wheel # noqa: F401 - except ImportError: - return False - - return True - - -def pairwise(iterable): - # type: (Iterable[Any]) -> Iterator[Tuple[Any, Any]] +def pairwise(iterable: Iterable[Any]) -> Iterator[Tuple[Any, Any]]: """ Return paired elements. @@ -807,10 +632,9 @@ def pairwise(iterable): def partition( - pred, # type: Callable[[T], bool] - iterable, # type: Iterable[T] -): - # type: (...) -> Tuple[Iterable[T], Iterable[T]] + pred: Callable[[T], bool], + iterable: Iterable[T], +) -> Tuple[Iterable[T], Iterable[T]]: """ Use a predicate to partition entries into false entries and true entries, like @@ -819,3 +643,93 @@ def partition( """ t1, t2 = tee(iterable) return filterfalse(pred, t1), filter(pred, t2) + + +class ConfiguredBuildBackendHookCaller(BuildBackendHookCaller): + def __init__( + self, + config_holder: Any, + source_dir: str, + build_backend: str, + backend_path: Optional[str] = None, + runner: Optional[Callable[..., None]] = None, + python_executable: Optional[str] = None, + ): + super().__init__( + source_dir, build_backend, backend_path, runner, python_executable + ) + self.config_holder = config_holder + + def build_wheel( + self, + wheel_directory: str, + config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, + metadata_directory: Optional[str] = None, + ) -> str: + cs = self.config_holder.config_settings + return super().build_wheel( + wheel_directory, config_settings=cs, metadata_directory=metadata_directory + ) + + def build_sdist( + self, + sdist_directory: str, + config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, + ) -> str: + cs = self.config_holder.config_settings + return super().build_sdist(sdist_directory, config_settings=cs) + + def build_editable( + self, + wheel_directory: str, + config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, + metadata_directory: Optional[str] = None, + ) -> str: + cs = self.config_holder.config_settings + return super().build_editable( + wheel_directory, config_settings=cs, metadata_directory=metadata_directory + ) + + def get_requires_for_build_wheel( + self, config_settings: Optional[Dict[str, Union[str, List[str]]]] = None + ) -> List[str]: + cs = self.config_holder.config_settings + return super().get_requires_for_build_wheel(config_settings=cs) + + def get_requires_for_build_sdist( + self, config_settings: Optional[Dict[str, Union[str, List[str]]]] = None + ) -> List[str]: + cs = self.config_holder.config_settings + return super().get_requires_for_build_sdist(config_settings=cs) + + def get_requires_for_build_editable( + self, config_settings: Optional[Dict[str, Union[str, List[str]]]] = None + ) -> List[str]: + cs = self.config_holder.config_settings + return super().get_requires_for_build_editable(config_settings=cs) + + def prepare_metadata_for_build_wheel( + self, + metadata_directory: str, + config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, + _allow_fallback: bool = True, + ) -> str: + cs = self.config_holder.config_settings + return super().prepare_metadata_for_build_wheel( + metadata_directory=metadata_directory, + config_settings=cs, + _allow_fallback=_allow_fallback, + ) + + def prepare_metadata_for_build_editable( + self, + metadata_directory: str, + config_settings: Optional[Dict[str, Union[str, List[str]]]] = None, + _allow_fallback: bool = True, + ) -> str: + cs = self.config_holder.config_settings + return super().prepare_metadata_for_build_editable( + metadata_directory=metadata_directory, + config_settings=cs, + _allow_fallback=_allow_fallback, + ) diff --git a/env/Lib/site-packages/pip/_internal/utils/models.py b/env/Lib/site-packages/pip/_internal/utils/models.py index 0e02bc7a..b6bb21a8 100644 --- a/env/Lib/site-packages/pip/_internal/utils/models.py +++ b/env/Lib/site-packages/pip/_internal/utils/models.py @@ -10,37 +10,29 @@ class KeyBasedCompareMixin: __slots__ = ["_compare_key", "_defining_class"] - def __init__(self, key, defining_class): - # type: (Any, Type[KeyBasedCompareMixin]) -> None + def __init__(self, key: Any, defining_class: Type["KeyBasedCompareMixin"]) -> None: self._compare_key = key self._defining_class = defining_class - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash(self._compare_key) - def __lt__(self, other): - # type: (Any) -> bool + def __lt__(self, other: Any) -> bool: return self._compare(other, operator.__lt__) - def __le__(self, other): - # type: (Any) -> bool + def __le__(self, other: Any) -> bool: return self._compare(other, operator.__le__) - def __gt__(self, other): - # type: (Any) -> bool + def __gt__(self, other: Any) -> bool: return self._compare(other, operator.__gt__) - def __ge__(self, other): - # type: (Any) -> bool + def __ge__(self, other: Any) -> bool: return self._compare(other, operator.__ge__) - def __eq__(self, other): - # type: (Any) -> bool + def __eq__(self, other: Any) -> bool: return self._compare(other, operator.__eq__) - def _compare(self, other, method): - # type: (Any, Callable[[Any, Any], bool]) -> bool + def _compare(self, other: Any, method: Callable[[Any, Any], bool]) -> bool: if not isinstance(other, self._defining_class): return NotImplemented diff --git a/env/Lib/site-packages/pip/_internal/utils/packaging.py b/env/Lib/site-packages/pip/_internal/utils/packaging.py index 3f9dbd3b..b9f6af4d 100644 --- a/env/Lib/site-packages/pip/_internal/utils/packaging.py +++ b/env/Lib/site-packages/pip/_internal/utils/packaging.py @@ -1,20 +1,19 @@ +import functools import logging -from email.message import Message -from email.parser import FeedParser -from typing import Optional, Tuple +import re +from typing import NewType, Optional, Tuple, cast -from pip._vendor import pkg_resources from pip._vendor.packaging import specifiers, version -from pip._vendor.pkg_resources import Distribution +from pip._vendor.packaging.requirements import Requirement -from pip._internal.exceptions import NoneMetadataError -from pip._internal.utils.misc import display_path +NormalizedExtra = NewType("NormalizedExtra", str) logger = logging.getLogger(__name__) -def check_requires_python(requires_python, version_info): - # type: (Optional[str], Tuple[int, ...]) -> bool +def check_requires_python( + requires_python: Optional[str], version_info: Tuple[int, ...] +) -> bool: """ Check if the given Python version matches a "Requires-Python" specifier. @@ -35,55 +34,24 @@ def check_requires_python(requires_python, version_info): return python_version in requires_python_specifier -def get_metadata(dist): - # type: (Distribution) -> Message - """ - :raises NoneMetadataError: if the distribution reports `has_metadata()` - True but `get_metadata()` returns None. - """ - metadata_name = "METADATA" - if isinstance(dist, pkg_resources.DistInfoDistribution) and dist.has_metadata( - metadata_name - ): - metadata = dist.get_metadata(metadata_name) - elif dist.has_metadata("PKG-INFO"): - metadata_name = "PKG-INFO" - metadata = dist.get_metadata(metadata_name) - else: - logger.warning("No metadata found in %s", display_path(dist.location)) - metadata = "" +@functools.lru_cache(maxsize=512) +def get_requirement(req_string: str) -> Requirement: + """Construct a packaging.Requirement object with caching""" + # Parsing requirement strings is expensive, and is also expected to happen + # with a low diversity of different arguments (at least relative the number + # constructed). This method adds a cache to requirement object creation to + # minimize repeated parsing of the same string to construct equivalent + # Requirement objects. + return Requirement(req_string) - if metadata is None: - raise NoneMetadataError(dist, metadata_name) - feed_parser = FeedParser() - # The following line errors out if with a "NoneType" TypeError if - # passed metadata=None. - feed_parser.feed(metadata) - return feed_parser.close() +def safe_extra(extra: str) -> NormalizedExtra: + """Convert an arbitrary string to a standard 'extra' name + Any runs of non-alphanumeric characters are replaced with a single '_', + and the result is always lowercased. -def get_requires_python(dist): - # type: (pkg_resources.Distribution) -> Optional[str] + This function is duplicated from ``pkg_resources``. Note that this is not + the same to either ``canonicalize_name`` or ``_egg_link_name``. """ - Return the "Requires-Python" metadata for a distribution, or None - if not present. - """ - pkg_info_dict = get_metadata(dist) - requires_python = pkg_info_dict.get("Requires-Python") - - if requires_python is not None: - # Convert to a str to satisfy the type checker, since requires_python - # can be a Header object. - requires_python = str(requires_python) - - return requires_python - - -def get_installer(dist): - # type: (Distribution) -> str - if dist.has_metadata("INSTALLER"): - for line in dist.get_metadata_lines("INSTALLER"): - if line.strip(): - return line.strip() - return "" + return cast(NormalizedExtra, re.sub("[^A-Za-z0-9.-]+", "_", extra).lower()) diff --git a/env/Lib/site-packages/pip/_internal/utils/parallel.py b/env/Lib/site-packages/pip/_internal/utils/parallel.py deleted file mode 100644 index de91dc8a..00000000 --- a/env/Lib/site-packages/pip/_internal/utils/parallel.py +++ /dev/null @@ -1,101 +0,0 @@ -"""Convenient parallelization of higher order functions. - -This module provides two helper functions, with appropriate fallbacks on -Python 2 and on systems lacking support for synchronization mechanisms: - -- map_multiprocess -- map_multithread - -These helpers work like Python 3's map, with two differences: - -- They don't guarantee the order of processing of - the elements of the iterable. -- The underlying process/thread pools chop the iterable into - a number of chunks, so that for very long iterables using - a large value for chunksize can make the job complete much faster - than using the default value of 1. -""" - -__all__ = ["map_multiprocess", "map_multithread"] - -from contextlib import contextmanager -from multiprocessing import Pool as ProcessPool -from multiprocessing import pool -from multiprocessing.dummy import Pool as ThreadPool -from typing import Callable, Iterable, Iterator, TypeVar, Union - -from pip._vendor.requests.adapters import DEFAULT_POOLSIZE - -Pool = Union[pool.Pool, pool.ThreadPool] -S = TypeVar("S") -T = TypeVar("T") - -# On platforms without sem_open, multiprocessing[.dummy] Pool -# cannot be created. -try: - import multiprocessing.synchronize # noqa -except ImportError: - LACK_SEM_OPEN = True -else: - LACK_SEM_OPEN = False - -# Incredibly large timeout to work around bpo-8296 on Python 2. -TIMEOUT = 2000000 - - -@contextmanager -def closing(pool): - # type: (Pool) -> Iterator[Pool] - """Return a context manager making sure the pool closes properly.""" - try: - yield pool - finally: - # For Pool.imap*, close and join are needed - # for the returned iterator to begin yielding. - pool.close() - pool.join() - pool.terminate() - - -def _map_fallback(func, iterable, chunksize=1): - # type: (Callable[[S], T], Iterable[S], int) -> Iterator[T] - """Make an iterator applying func to each element in iterable. - - This function is the sequential fallback either on Python 2 - where Pool.imap* doesn't react to KeyboardInterrupt - or when sem_open is unavailable. - """ - return map(func, iterable) - - -def _map_multiprocess(func, iterable, chunksize=1): - # type: (Callable[[S], T], Iterable[S], int) -> Iterator[T] - """Chop iterable into chunks and submit them to a process pool. - - For very long iterables using a large value for chunksize can make - the job complete much faster than using the default value of 1. - - Return an unordered iterator of the results. - """ - with closing(ProcessPool()) as pool: - return pool.imap_unordered(func, iterable, chunksize) - - -def _map_multithread(func, iterable, chunksize=1): - # type: (Callable[[S], T], Iterable[S], int) -> Iterator[T] - """Chop iterable into chunks and submit them to a thread pool. - - For very long iterables using a large value for chunksize can make - the job complete much faster than using the default value of 1. - - Return an unordered iterator of the results. - """ - with closing(ThreadPool(DEFAULT_POOLSIZE)) as pool: - return pool.imap_unordered(func, iterable, chunksize) - - -if LACK_SEM_OPEN: - map_multiprocess = map_multithread = _map_fallback -else: - map_multiprocess = _map_multiprocess - map_multithread = _map_multithread diff --git a/env/Lib/site-packages/pip/_internal/utils/pkg_resources.py b/env/Lib/site-packages/pip/_internal/utils/pkg_resources.py deleted file mode 100644 index ee1eca30..00000000 --- a/env/Lib/site-packages/pip/_internal/utils/pkg_resources.py +++ /dev/null @@ -1,40 +0,0 @@ -from typing import Dict, Iterable, List - -from pip._vendor.pkg_resources import yield_lines - - -class DictMetadata: - """IMetadataProvider that reads metadata files from a dictionary.""" - - def __init__(self, metadata): - # type: (Dict[str, bytes]) -> None - self._metadata = metadata - - def has_metadata(self, name): - # type: (str) -> bool - return name in self._metadata - - def get_metadata(self, name): - # type: (str) -> str - try: - return self._metadata[name].decode() - except UnicodeDecodeError as e: - # Mirrors handling done in pkg_resources.NullProvider. - e.reason += f" in {name} file" - raise - - def get_metadata_lines(self, name): - # type: (str) -> Iterable[str] - return yield_lines(self.get_metadata(name)) - - def metadata_isdir(self, name): - # type: (str) -> bool - return False - - def metadata_listdir(self, name): - # type: (str) -> List[str] - return [] - - def run_script(self, script_name, namespace): - # type: (str, str) -> None - pass diff --git a/env/Lib/site-packages/pip/_internal/utils/setuptools_build.py b/env/Lib/site-packages/pip/_internal/utils/setuptools_build.py index 4b8e4b35..96d1b246 100644 --- a/env/Lib/site-packages/pip/_internal/utils/setuptools_build.py +++ b/env/Lib/site-packages/pip/_internal/utils/setuptools_build.py @@ -1,30 +1,57 @@ import sys +import textwrap from typing import List, Optional, Sequence # Shim to wrap setup.py invocation with setuptools -# -# We set sys.argv[0] to the path to the underlying setup.py file so -# setuptools / distutils don't take the path to the setup.py to be "-c" when -# invoking via the shim. This avoids e.g. the following manifest_maker -# warning: "warning: manifest_maker: standard file '-c' not found". -_SETUPTOOLS_SHIM = ( - "import io, os, sys, setuptools, tokenize; sys.argv[0] = {0!r}; __file__={0!r};" - "f = getattr(tokenize, 'open', open)(__file__) " - "if os.path.exists(__file__) " - "else io.StringIO('from setuptools import setup; setup()');" - "code = f.read().replace('\\r\\n', '\\n');" - "f.close();" - "exec(compile(code, __file__, 'exec'))" -) +# Note that __file__ is handled via two {!r} *and* %r, to ensure that paths on +# Windows are correctly handled (it should be "C:\\Users" not "C:\Users"). +_SETUPTOOLS_SHIM = textwrap.dedent( + """ + exec(compile(''' + # This is <pip-setuptools-caller> -- a caller that pip uses to run setup.py + # + # - It imports setuptools before invoking setup.py, to enable projects that directly + # import from `distutils.core` to work with newer packaging standards. + # - It provides a clear error message when setuptools is not installed. + # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so + # setuptools doesn't think the script is `-c`. This avoids the following warning: + # manifest_maker: standard file '-c' not found". + # - It generates a shim setup.py, for handling setup.cfg-only projects. + import os, sys, tokenize + + try: + import setuptools + except ImportError as error: + print( + "ERROR: Can not execute `setup.py` since setuptools is not available in " + "the build environment.", + file=sys.stderr, + ) + sys.exit(1) + + __file__ = %r + sys.argv[0] = __file__ + + if os.path.exists(__file__): + filename = __file__ + with tokenize.open(__file__) as f: + setup_py_code = f.read() + else: + filename = "<auto-generated setuptools caller>" + setup_py_code = "from setuptools import setup; setup()" + + exec(compile(setup_py_code, filename, "exec")) + ''' % ({!r},), "<pip-setuptools-caller>", "exec")) + """ +).rstrip() def make_setuptools_shim_args( - setup_py_path, # type: str - global_options=None, # type: Sequence[str] - no_user_config=False, # type: bool - unbuffered_output=False, # type: bool -): - # type: (...) -> List[str] + setup_py_path: str, + global_options: Optional[Sequence[str]] = None, + no_user_config: bool = False, + unbuffered_output: bool = False, +) -> List[str]: """ Get setuptools command arguments with shim wrapped setup file invocation. @@ -46,12 +73,11 @@ def make_setuptools_shim_args( def make_setuptools_bdist_wheel_args( - setup_py_path, # type: str - global_options, # type: Sequence[str] - build_options, # type: Sequence[str] - destination_dir, # type: str -): - # type: (...) -> List[str] + setup_py_path: str, + global_options: Sequence[str], + build_options: Sequence[str], + destination_dir: str, +) -> List[str]: # NOTE: Eventually, we'd want to also -S to the flags here, when we're # isolating. Currently, it breaks Python in virtualenvs, because it # relies on site.py to find parts of the standard library outside the @@ -65,10 +91,9 @@ def make_setuptools_bdist_wheel_args( def make_setuptools_clean_args( - setup_py_path, # type: str - global_options, # type: Sequence[str] -): - # type: (...) -> List[str] + setup_py_path: str, + global_options: Sequence[str], +) -> List[str]: args = make_setuptools_shim_args( setup_py_path, global_options=global_options, unbuffered_output=True ) @@ -77,15 +102,14 @@ def make_setuptools_clean_args( def make_setuptools_develop_args( - setup_py_path, # type: str - global_options, # type: Sequence[str] - install_options, # type: Sequence[str] - no_user_config, # type: bool - prefix, # type: Optional[str] - home, # type: Optional[str] - use_user_site, # type: bool -): - # type: (...) -> List[str] + setup_py_path: str, + *, + global_options: Sequence[str], + no_user_config: bool, + prefix: Optional[str], + home: Optional[str], + use_user_site: bool, +) -> List[str]: assert not (use_user_site and prefix) args = make_setuptools_shim_args( @@ -96,8 +120,6 @@ def make_setuptools_develop_args( args += ["develop", "--no-deps"] - args += install_options - if prefix: args += ["--prefix", prefix] if home is not None: @@ -110,11 +132,10 @@ def make_setuptools_develop_args( def make_setuptools_egg_info_args( - setup_py_path, # type: str - egg_info_dir, # type: Optional[str] - no_user_config, # type: bool -): - # type: (...) -> List[str] + setup_py_path: str, + egg_info_dir: Optional[str], + no_user_config: bool, +) -> List[str]: args = make_setuptools_shim_args(setup_py_path, no_user_config=no_user_config) args += ["egg_info"] @@ -123,51 +144,3 @@ def make_setuptools_egg_info_args( args += ["--egg-base", egg_info_dir] return args - - -def make_setuptools_install_args( - setup_py_path, # type: str - global_options, # type: Sequence[str] - install_options, # type: Sequence[str] - record_filename, # type: str - root, # type: Optional[str] - prefix, # type: Optional[str] - header_dir, # type: Optional[str] - home, # type: Optional[str] - use_user_site, # type: bool - no_user_config, # type: bool - pycompile, # type: bool -): - # type: (...) -> List[str] - assert not (use_user_site and prefix) - assert not (use_user_site and root) - - args = make_setuptools_shim_args( - setup_py_path, - global_options=global_options, - no_user_config=no_user_config, - unbuffered_output=True, - ) - args += ["install", "--record", record_filename] - args += ["--single-version-externally-managed"] - - if root is not None: - args += ["--root", root] - if prefix is not None: - args += ["--prefix", prefix] - if home is not None: - args += ["--home", home] - if use_user_site: - args += ["--user", "--prefix="] - - if pycompile: - args += ["--compile"] - else: - args += ["--no-compile"] - - if header_dir: - args += ["--install-headers", header_dir] - - args += install_options - - return args diff --git a/env/Lib/site-packages/pip/_internal/utils/subprocess.py b/env/Lib/site-packages/pip/_internal/utils/subprocess.py index 2c8cf212..1e8ff50e 100644 --- a/env/Lib/site-packages/pip/_internal/utils/subprocess.py +++ b/env/Lib/site-packages/pip/_internal/utils/subprocess.py @@ -2,25 +2,38 @@ import logging import os import shlex import subprocess -from typing import Any, Callable, Iterable, List, Mapping, Optional, Union +from typing import ( + TYPE_CHECKING, + Any, + Callable, + Iterable, + List, + Mapping, + Optional, + Union, +) + +from pip._vendor.rich.markup import escape from pip._internal.cli.spinners import SpinnerInterface, open_spinner from pip._internal.exceptions import InstallationSubprocessError -from pip._internal.utils.logging import subprocess_logger +from pip._internal.utils.logging import VERBOSE, subprocess_logger from pip._internal.utils.misc import HiddenText -CommandArgs = List[Union[str, HiddenText]] - +if TYPE_CHECKING: + # Literal was introduced in Python 3.8. + # + # TODO: Remove `if TYPE_CHECKING` when dropping support for Python 3.7. + from typing import Literal -LOG_DIVIDER = "----------------------------------------" +CommandArgs = List[Union[str, HiddenText]] -def make_command(*args): - # type: (Union[str, HiddenText, CommandArgs]) -> CommandArgs +def make_command(*args: Union[str, HiddenText, CommandArgs]) -> CommandArgs: """ Create a CommandArgs object. """ - command_args = [] # type: CommandArgs + command_args: CommandArgs = [] for arg in args: # Check for list instead of CommandArgs since CommandArgs is # only known during type-checking. @@ -33,8 +46,7 @@ def make_command(*args): return command_args -def format_command_args(args): - # type: (Union[List[str], CommandArgs]) -> str +def format_command_args(args: Union[List[str], CommandArgs]) -> str: """ Format command arguments for display. """ @@ -49,64 +61,27 @@ def format_command_args(args): ) -def reveal_command_args(args): - # type: (Union[List[str], CommandArgs]) -> List[str] +def reveal_command_args(args: Union[List[str], CommandArgs]) -> List[str]: """ Return the arguments in their raw, unredacted form. """ return [arg.secret if isinstance(arg, HiddenText) else arg for arg in args] -def make_subprocess_output_error( - cmd_args, # type: Union[List[str], CommandArgs] - cwd, # type: Optional[str] - lines, # type: List[str] - exit_status, # type: int -): - # type: (...) -> str - """ - Create and return the error message to use to log a subprocess error - with command output. - - :param lines: A list of lines, each ending with a newline. - """ - command = format_command_args(cmd_args) - - # We know the joined output value ends in a newline. - output = "".join(lines) - msg = ( - # Use a unicode string to avoid "UnicodeEncodeError: 'ascii' - # codec can't encode character ..." in Python 2 when a format - # argument (e.g. `output`) has a non-ascii character. - "Command errored out with exit status {exit_status}:\n" - " command: {command_display}\n" - " cwd: {cwd_display}\n" - "Complete output ({line_count} lines):\n{output}{divider}" - ).format( - exit_status=exit_status, - command_display=command, - cwd_display=cwd, - line_count=len(lines), - output=output, - divider=LOG_DIVIDER, - ) - return msg - - def call_subprocess( - cmd, # type: Union[List[str], CommandArgs] - show_stdout=False, # type: bool - cwd=None, # type: Optional[str] - on_returncode="raise", # type: str - extra_ok_returncodes=None, # type: Optional[Iterable[int]] - command_desc=None, # type: Optional[str] - extra_environ=None, # type: Optional[Mapping[str, Any]] - unset_environ=None, # type: Optional[Iterable[str]] - spinner=None, # type: Optional[SpinnerInterface] - log_failed_cmd=True, # type: Optional[bool] - stdout_only=False, # type: Optional[bool] -): - # type: (...) -> str + cmd: Union[List[str], CommandArgs], + show_stdout: bool = False, + cwd: Optional[str] = None, + on_returncode: 'Literal["raise", "warn", "ignore"]' = "raise", + extra_ok_returncodes: Optional[Iterable[int]] = None, + extra_environ: Optional[Mapping[str, Any]] = None, + unset_environ: Optional[Iterable[str]] = None, + spinner: Optional[SpinnerInterface] = None, + log_failed_cmd: Optional[bool] = True, + stdout_only: Optional[bool] = False, + *, + command_desc: str, +) -> str: """ Args: show_stdout: if true, use INFO to log the subprocess's stderr and @@ -141,13 +116,13 @@ def call_subprocess( # replaced by INFO. if show_stdout: # Then log the subprocess output at INFO level. - log_subprocess = subprocess_logger.info + log_subprocess: Callable[..., None] = subprocess_logger.info used_level = logging.INFO else: - # Then log the subprocess output using DEBUG. This also ensures + # Then log the subprocess output using VERBOSE. This also ensures # it will be logged to the log file (aka user_log), if enabled. - log_subprocess = subprocess_logger.debug - used_level = logging.DEBUG + log_subprocess = subprocess_logger.verbose + used_level = VERBOSE # Whether the subprocess will be visible in the console. showing_subprocess = subprocess_logger.getEffectiveLevel() <= used_level @@ -156,9 +131,6 @@ def call_subprocess( # and we have a spinner. use_spinner = not showing_subprocess and spinner is not None - if command_desc is None: - command_desc = format_command_args(cmd) - log_subprocess("Running command %s", command_desc) env = os.environ.copy() if extra_environ: @@ -191,7 +163,7 @@ def call_subprocess( proc.stdin.close() # In this mode, stdout and stderr are in the same pipe. while True: - line = proc.stdout.readline() # type: str + line: str = proc.stdout.readline() if not line: break line = line.rstrip() @@ -231,17 +203,25 @@ def call_subprocess( spinner.finish("done") if proc_had_error: if on_returncode == "raise": - if not showing_subprocess and log_failed_cmd: - # Then the subprocess streams haven't been logged to the - # console yet. - msg = make_subprocess_output_error( - cmd_args=cmd, - cwd=cwd, - lines=all_output, - exit_status=proc.returncode, + error = InstallationSubprocessError( + command_description=command_desc, + exit_code=proc.returncode, + output_lines=all_output if not showing_subprocess else None, + ) + if log_failed_cmd: + subprocess_logger.error("[present-rich] %s", error) + subprocess_logger.verbose( + "[bold magenta]full command[/]: [blue]%s[/]", + escape(format_command_args(cmd)), + extra={"markup": True}, ) - subprocess_logger.error(msg) - raise InstallationSubprocessError(proc.returncode, command_desc) + subprocess_logger.verbose( + "[bold magenta]cwd[/]: %s", + escape(cwd or "[inherit]"), + extra={"markup": True}, + ) + + raise error elif on_returncode == "warn": subprocess_logger.warning( 'Command "%s" had error code %s in %s', @@ -256,23 +236,22 @@ def call_subprocess( return output -def runner_with_spinner_message(message): - # type: (str) -> Callable[..., None] +def runner_with_spinner_message(message: str) -> Callable[..., None]: """Provide a subprocess_runner that shows a spinner message. - Intended for use with for pep517's Pep517HookCaller. Thus, the runner has - an API that matches what's expected by Pep517HookCaller.subprocess_runner. + Intended for use with for BuildBackendHookCaller. Thus, the runner has + an API that matches what's expected by BuildBackendHookCaller.subprocess_runner. """ def runner( - cmd, # type: List[str] - cwd=None, # type: Optional[str] - extra_environ=None, # type: Optional[Mapping[str, Any]] - ): - # type: (...) -> None + cmd: List[str], + cwd: Optional[str] = None, + extra_environ: Optional[Mapping[str, Any]] = None, + ) -> None: with open_spinner(message) as spinner: call_subprocess( cmd, + command_desc=message, cwd=cwd, extra_environ=extra_environ, spinner=spinner, diff --git a/env/Lib/site-packages/pip/_internal/utils/temp_dir.py b/env/Lib/site-packages/pip/_internal/utils/temp_dir.py index 477cbe6b..8ee8a1cb 100644 --- a/env/Lib/site-packages/pip/_internal/utils/temp_dir.py +++ b/env/Lib/site-packages/pip/_internal/utils/temp_dir.py @@ -4,7 +4,7 @@ import logging import os.path import tempfile from contextlib import ExitStack, contextmanager -from typing import Any, Dict, Iterator, Optional, TypeVar, Union +from typing import Any, Dict, Generator, Optional, TypeVar, Union from pip._internal.utils.misc import enum, rmtree @@ -22,12 +22,11 @@ tempdir_kinds = enum( ) -_tempdir_manager = None # type: Optional[ExitStack] +_tempdir_manager: Optional[ExitStack] = None @contextmanager -def global_tempdir_manager(): - # type: () -> Iterator[None] +def global_tempdir_manager() -> Generator[None, None, None]: global _tempdir_manager with ExitStack() as stack: old_tempdir_manager, _tempdir_manager = _tempdir_manager, stack @@ -40,31 +39,27 @@ def global_tempdir_manager(): class TempDirectoryTypeRegistry: """Manages temp directory behavior""" - def __init__(self): - # type: () -> None - self._should_delete = {} # type: Dict[str, bool] + def __init__(self) -> None: + self._should_delete: Dict[str, bool] = {} - def set_delete(self, kind, value): - # type: (str, bool) -> None + def set_delete(self, kind: str, value: bool) -> None: """Indicate whether a TempDirectory of the given kind should be auto-deleted. """ self._should_delete[kind] = value - def get_delete(self, kind): - # type: (str) -> bool + def get_delete(self, kind: str) -> bool: """Get configured auto-delete flag for a given TempDirectory type, default True. """ return self._should_delete.get(kind, True) -_tempdir_registry = None # type: Optional[TempDirectoryTypeRegistry] +_tempdir_registry: Optional[TempDirectoryTypeRegistry] = None @contextmanager -def tempdir_registry(): - # type: () -> Iterator[TempDirectoryTypeRegistry] +def tempdir_registry() -> Generator[TempDirectoryTypeRegistry, None, None]: """Provides a scoped global tempdir registry that can be used to dictate whether directories should be deleted. """ @@ -107,10 +102,10 @@ class TempDirectory: def __init__( self, - path=None, # type: Optional[str] - delete=_default, # type: Union[bool, None, _Default] - kind="temp", # type: str - globally_managed=False, # type: bool + path: Optional[str] = None, + delete: Union[bool, None, _Default] = _default, + kind: str = "temp", + globally_managed: bool = False, ): super().__init__() @@ -139,21 +134,17 @@ class TempDirectory: _tempdir_manager.enter_context(self) @property - def path(self): - # type: () -> str + def path(self) -> str: assert not self._deleted, f"Attempted to access deleted path: {self._path}" return self._path - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: return f"<{self.__class__.__name__} {self.path!r}>" - def __enter__(self): - # type: (_T) -> _T + def __enter__(self: _T) -> _T: return self - def __exit__(self, exc, value, tb): - # type: (Any, Any, Any) -> None + def __exit__(self, exc: Any, value: Any, tb: Any) -> None: if self.delete is not None: delete = self.delete elif _tempdir_registry: @@ -164,8 +155,7 @@ class TempDirectory: if delete: self.cleanup() - def _create(self, kind): - # type: (str) -> str + def _create(self, kind: str) -> str: """Create a temporary directory and store its path in self.path""" # We realpath here because some systems have their default tmpdir # symlinked to another directory. This tends to confuse build @@ -175,8 +165,7 @@ class TempDirectory: logger.debug("Created temporary directory: %s", path) return path - def cleanup(self): - # type: () -> None + def cleanup(self) -> None: """Remove the temporary directory created and reset state""" self._deleted = True if not os.path.exists(self._path): @@ -206,14 +195,12 @@ class AdjacentTempDirectory(TempDirectory): # with leading '-' and invalid metadata LEADING_CHARS = "-~.=%0123456789" - def __init__(self, original, delete=None): - # type: (str, Optional[bool]) -> None + def __init__(self, original: str, delete: Optional[bool] = None) -> None: self.original = original.rstrip("/\\") super().__init__(delete=delete) @classmethod - def _generate_names(cls, name): - # type: (str) -> Iterator[str] + def _generate_names(cls, name: str) -> Generator[str, None, None]: """Generates a series of temporary names. The algorithm replaces the leading characters in the name @@ -238,8 +225,7 @@ class AdjacentTempDirectory(TempDirectory): if new_name != name: yield new_name - def _create(self, kind): - # type: (str) -> str + def _create(self, kind: str) -> str: root, name = os.path.split(self.original) for candidate in self._generate_names(name): path = os.path.join(root, candidate) diff --git a/env/Lib/site-packages/pip/_internal/utils/unpacking.py b/env/Lib/site-packages/pip/_internal/utils/unpacking.py index 44ac4753..78b5c13c 100644 --- a/env/Lib/site-packages/pip/_internal/utils/unpacking.py +++ b/env/Lib/site-packages/pip/_internal/utils/unpacking.py @@ -40,16 +40,14 @@ except ImportError: logger.debug("lzma module is not available") -def current_umask(): - # type: () -> int +def current_umask() -> int: """Get the current umask which involves having to set it temporarily.""" mask = os.umask(0) os.umask(mask) return mask -def split_leading_dir(path): - # type: (str) -> List[str] +def split_leading_dir(path: str) -> List[str]: path = path.lstrip("/").lstrip("\\") if "/" in path and ( ("\\" in path and path.find("/") < path.find("\\")) or "\\" not in path @@ -61,8 +59,7 @@ def split_leading_dir(path): return [path, ""] -def has_leading_dir(paths): - # type: (Iterable[str]) -> bool +def has_leading_dir(paths: Iterable[str]) -> bool: """Returns true if all the paths have the same leading path name (i.e., everything is in one subdirectory in an archive)""" common_prefix = None @@ -77,8 +74,7 @@ def has_leading_dir(paths): return True -def is_within_directory(directory, target): - # type: (str, str) -> bool +def is_within_directory(directory: str, target: str) -> bool: """ Return true if the absolute path of target is within the directory """ @@ -89,8 +85,7 @@ def is_within_directory(directory, target): return prefix == abs_directory -def set_extracted_file_to_default_mode_plus_executable(path): - # type: (str) -> None +def set_extracted_file_to_default_mode_plus_executable(path: str) -> None: """ Make file present at path have execute for user/group/world (chmod +x) is no-op on windows per python docs @@ -98,16 +93,14 @@ def set_extracted_file_to_default_mode_plus_executable(path): os.chmod(path, (0o777 & ~current_umask() | 0o111)) -def zip_item_is_executable(info): - # type: (ZipInfo) -> bool +def zip_item_is_executable(info: ZipInfo) -> bool: mode = info.external_attr >> 16 # if mode and regular file and any execute permissions for # user/group/world? return bool(mode and stat.S_ISREG(mode) and mode & 0o111) -def unzip_file(filename, location, flatten=True): - # type: (str, str, bool) -> None +def unzip_file(filename: str, location: str, flatten: bool = True) -> None: """ Unzip the file (with path `filename`) to the destination `location`. All files are written based on system defaults and umask (i.e. permissions are @@ -153,8 +146,7 @@ def unzip_file(filename, location, flatten=True): zipfp.close() -def untar_file(filename, location): - # type: (str, str) -> None +def untar_file(filename: str, location: str) -> None: """ Untar the file (with path `filename`) to the destination `location`. All files are written based on system defaults and umask (i.e. permissions @@ -178,7 +170,7 @@ def untar_file(filename, location): filename, ) mode = "r:*" - tar = tarfile.open(filename, mode) + tar = tarfile.open(filename, mode, encoding="utf-8") try: leading = has_leading_dir([member.name for member in tar.getmembers()]) for member in tar.getmembers(): @@ -196,8 +188,7 @@ def untar_file(filename, location): ensure_dir(path) elif member.issym(): try: - # https://github.com/python/typeshed/issues/2673 - tar._extract_member(member, path) # type: ignore + tar._extract_member(member, path) except Exception as exc: # Some corrupt tar files seem to produce this # (specifically bad symlinks) @@ -236,11 +227,10 @@ def untar_file(filename, location): def unpack_file( - filename, # type: str - location, # type: str - content_type=None, # type: Optional[str] -): - # type: (...) -> None + filename: str, + location: str, + content_type: Optional[str] = None, +) -> None: filename = os.path.realpath(filename) if ( content_type == "application/zip" diff --git a/env/Lib/site-packages/pip/_internal/utils/urls.py b/env/Lib/site-packages/pip/_internal/utils/urls.py index 50a04d86..6ba2e04f 100644 --- a/env/Lib/site-packages/pip/_internal/utils/urls.py +++ b/env/Lib/site-packages/pip/_internal/utils/urls.py @@ -1,19 +1,19 @@ import os -import sys +import string import urllib.parse import urllib.request from typing import Optional +from .compat import WINDOWS -def get_url_scheme(url): - # type: (str) -> Optional[str] + +def get_url_scheme(url: str) -> Optional[str]: if ":" not in url: return None return url.split(":", 1)[0].lower() -def path_to_url(path): - # type: (str) -> str +def path_to_url(path: str) -> str: """ Convert a path to a file: URL. The path will be made absolute and have quoted path parts. @@ -23,8 +23,7 @@ def path_to_url(path): return url -def url_to_path(url): - # type: (str) -> str +def url_to_path(url: str) -> str: """ Convert a file: URL to a path. """ @@ -37,7 +36,7 @@ def url_to_path(url): if not netloc or netloc == "localhost": # According to RFC 8089, same as empty authority. netloc = "" - elif sys.platform == "win32": + elif WINDOWS: # If we have a UNC path, prepend UNC share notation. netloc = "\\\\" + netloc else: @@ -46,4 +45,18 @@ def url_to_path(url): ) path = urllib.request.url2pathname(netloc + path) + + # On Windows, urlsplit parses the path as something like "/C:/Users/foo". + # This creates issues for path-related functions like io.open(), so we try + # to detect and strip the leading slash. + if ( + WINDOWS + and not netloc # Not UNC. + and len(path) >= 3 + and path[0] == "/" # Leading slash to strip. + and path[1] in string.ascii_letters # Drive letter. + and path[2:4] in (":", ":/") # Colon + end of string, or colon + absolute path. + ): + path = path[1:] + return path diff --git a/env/Lib/site-packages/pip/_internal/utils/virtualenv.py b/env/Lib/site-packages/pip/_internal/utils/virtualenv.py index 51cacb55..882e36f5 100644 --- a/env/Lib/site-packages/pip/_internal/utils/virtualenv.py +++ b/env/Lib/site-packages/pip/_internal/utils/virtualenv.py @@ -11,8 +11,7 @@ _INCLUDE_SYSTEM_SITE_PACKAGES_REGEX = re.compile( ) -def _running_under_venv(): - # type: () -> bool +def _running_under_venv() -> bool: """Checks if sys.base_prefix and sys.prefix match. This handles PEP 405 compliant virtual environments. @@ -20,8 +19,7 @@ def _running_under_venv(): return sys.prefix != getattr(sys, "base_prefix", sys.prefix) -def _running_under_regular_virtualenv(): - # type: () -> bool +def _running_under_legacy_virtualenv() -> bool: """Checks if sys.real_prefix is set. This handles virtual environments created with pypa's virtualenv. @@ -30,14 +28,12 @@ def _running_under_regular_virtualenv(): return hasattr(sys, "real_prefix") -def running_under_virtualenv(): - # type: () -> bool - """Return True if we're running inside a virtualenv, False otherwise.""" - return _running_under_venv() or _running_under_regular_virtualenv() +def running_under_virtualenv() -> bool: + """True if we're running inside a virtual environment, False otherwise.""" + return _running_under_venv() or _running_under_legacy_virtualenv() -def _get_pyvenv_cfg_lines(): - # type: () -> Optional[List[str]] +def _get_pyvenv_cfg_lines() -> Optional[List[str]]: """Reads {sys.prefix}/pyvenv.cfg and returns its contents as list of lines Returns None, if it could not read/access the file. @@ -52,8 +48,7 @@ def _get_pyvenv_cfg_lines(): return None -def _no_global_under_venv(): - # type: () -> bool +def _no_global_under_venv() -> bool: """Check `{sys.prefix}/pyvenv.cfg` for system site-packages inclusion PEP 405 specifies that when system site-packages are not supposed to be @@ -82,8 +77,7 @@ def _no_global_under_venv(): return False -def _no_global_under_regular_virtualenv(): - # type: () -> bool +def _no_global_under_legacy_virtualenv() -> bool: """Check if "no-global-site-packages.txt" exists beside site.py This mirrors logic in pypa/virtualenv for determining whether system @@ -97,15 +91,14 @@ def _no_global_under_regular_virtualenv(): return os.path.exists(no_global_site_packages_file) -def virtualenv_no_global(): - # type: () -> bool +def virtualenv_no_global() -> bool: """Returns a boolean, whether running in venv with no system site-packages.""" # PEP 405 compliance needs to be checked first since virtualenv >=20 would # return True for both checks, but is only able to use the PEP 405 config. if _running_under_venv(): return _no_global_under_venv() - if _running_under_regular_virtualenv(): - return _no_global_under_regular_virtualenv() + if _running_under_legacy_virtualenv(): + return _no_global_under_legacy_virtualenv() return False diff --git a/env/Lib/site-packages/pip/_internal/utils/wheel.py b/env/Lib/site-packages/pip/_internal/utils/wheel.py index 42f08084..e5e3f34e 100644 --- a/env/Lib/site-packages/pip/_internal/utils/wheel.py +++ b/env/Lib/site-packages/pip/_internal/utils/wheel.py @@ -4,14 +4,12 @@ import logging from email.message import Message from email.parser import Parser -from typing import Dict, Tuple +from typing import Tuple from zipfile import BadZipFile, ZipFile from pip._vendor.packaging.utils import canonicalize_name -from pip._vendor.pkg_resources import DistInfoDistribution, Distribution from pip._internal.exceptions import UnsupportedWheel -from pip._internal.utils.pkg_resources import DictMetadata VERSION_COMPATIBLE = (1, 0) @@ -19,53 +17,7 @@ VERSION_COMPATIBLE = (1, 0) logger = logging.getLogger(__name__) -class WheelMetadata(DictMetadata): - """Metadata provider that maps metadata decoding exceptions to our - internal exception type. - """ - - def __init__(self, metadata, wheel_name): - # type: (Dict[str, bytes], str) -> None - super().__init__(metadata) - self._wheel_name = wheel_name - - def get_metadata(self, name): - # type: (str) -> str - try: - return super().get_metadata(name) - except UnicodeDecodeError as e: - # Augment the default error with the origin of the file. - raise UnsupportedWheel( - f"Error decoding metadata for {self._wheel_name}: {e}" - ) - - -def pkg_resources_distribution_for_wheel(wheel_zip, name, location): - # type: (ZipFile, str, str) -> Distribution - """Get a pkg_resources distribution given a wheel. - - :raises UnsupportedWheel: on any errors - """ - info_dir, _ = parse_wheel(wheel_zip, name) - - metadata_files = [p for p in wheel_zip.namelist() if p.startswith(f"{info_dir}/")] - - metadata_text = {} # type: Dict[str, bytes] - for path in metadata_files: - _, metadata_name = path.split("/", 1) - - try: - metadata_text[metadata_name] = read_wheel_metadata_file(wheel_zip, path) - except UnsupportedWheel as e: - raise UnsupportedWheel("{} has an invalid wheel, {}".format(name, str(e))) - - metadata = WheelMetadata(metadata_text, location) - - return DistInfoDistribution(location=location, metadata=metadata, project_name=name) - - -def parse_wheel(wheel_zip, name): - # type: (ZipFile, str) -> Tuple[str, Message] +def parse_wheel(wheel_zip: ZipFile, name: str) -> Tuple[str, Message]: """Extract information from the provided wheel, ensuring it meets basic standards. @@ -83,8 +35,7 @@ def parse_wheel(wheel_zip, name): return info_dir, metadata -def wheel_dist_info_dir(source, name): - # type: (ZipFile, str) -> str +def wheel_dist_info_dir(source: ZipFile, name: str) -> str: """Returns the name of the contained .dist-info directory. Raises AssertionError or UnsupportedWheel if not found, >1 found, or @@ -117,8 +68,7 @@ def wheel_dist_info_dir(source, name): return info_dir -def read_wheel_metadata_file(source, path): - # type: (ZipFile, str) -> bytes +def read_wheel_metadata_file(source: ZipFile, path: str) -> bytes: try: return source.read(path) # BadZipFile for general corruption, KeyError for missing entry, @@ -127,8 +77,7 @@ def read_wheel_metadata_file(source, path): raise UnsupportedWheel(f"could not read {path!r} file: {e!r}") -def wheel_metadata(source, dist_info_dir): - # type: (ZipFile, str) -> Message +def wheel_metadata(source: ZipFile, dist_info_dir: str) -> Message: """Return the WHEEL metadata of an extracted wheel, if possible. Otherwise, raise UnsupportedWheel. """ @@ -147,8 +96,7 @@ def wheel_metadata(source, dist_info_dir): return Parser().parsestr(wheel_text) -def wheel_version(wheel_data): - # type: (Message) -> Tuple[int, ...] +def wheel_version(wheel_data: Message) -> Tuple[int, ...]: """Given WHEEL metadata, return the parsed Wheel-Version. Otherwise, raise UnsupportedWheel. """ @@ -164,8 +112,7 @@ def wheel_version(wheel_data): raise UnsupportedWheel(f"invalid Wheel-Version: {version!r}") -def check_compatibility(version, name): - # type: (Tuple[int, ...], str) -> None +def check_compatibility(version: Tuple[int, ...], name: str) -> None: """Raises errors or warns if called with an incompatible Wheel-Version. pip should refuse to install a Wheel-Version that's a major series diff --git a/env/Lib/site-packages/pip/_internal/vcs/__init__.py b/env/Lib/site-packages/pip/_internal/vcs/__init__.py index 30025d63..b6beddbe 100644 --- a/env/Lib/site-packages/pip/_internal/vcs/__init__.py +++ b/env/Lib/site-packages/pip/_internal/vcs/__init__.py @@ -8,6 +8,7 @@ import pip._internal.vcs.mercurial import pip._internal.vcs.subversion # noqa: F401 from pip._internal.vcs.versioncontrol import ( # noqa: F401 RemoteNotFoundError, + RemoteNotValidError, is_url, make_vcs_requirement_url, vcs, diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index e549a9ac9dbd8a2d84af83182525b1f79d174be6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 512 zcmYe~<>g{vU|^UdaWK`IiGkrUh=Yuo7#J8F7#J9eZ5S9BQW#Pga~Pr+!88+;W`@!% zV45k1HJ2@lEtfrtJ(nYjBbPIZlaV2XF_=M<`6b9)KTVcf!a=FI`6a1-`6X`orFki? zMMe2Vx7ad^<4cQjZb{@OW~auNB^SpRr52WE7NzE<=9PeDn9GujHMwp{6l50Y#b@S~ zq!#5R=IE6r7waV@RwX7D-C{1tEVw0#DV?5Ka!VRhI5)K@xwI%VG3S;HretwxQdw$I zab|wrEd@+js8n)(UP)1YP7x@OikKM~7>Zax1S<mr!%BuC9uONu{Hk-diU}=FEh>&l z%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwu ziAglk&B;&CEH25+j!Dfci}A@!iYd-4N!2Y#OwLYBPc4oq$Slx@hlze!a<P7Vd}dx| fNqoFsLFFwDo80`A(wtN~kjsiW7#J8h7$Fb<7p0rH diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-39.pyc deleted file mode 100644 index 2c9e5c9251b7c6adc92c946de63f4868b712065d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3028 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 B`VasB diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/git.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/git.cpython-39.pyc deleted file mode 100644 index 031887dbba1a53e17922590fbc35ec535f7a1f8a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10004 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 I1`w1702D0+z5oCK diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-39.pyc deleted file mode 100644 index 1c526459dddd98473d542f480fa2345d22d255ec..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4649 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 IsAu2?0E(iwy8r+H diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-39.pyc deleted file mode 100644 index e3997e1e3aab0aacb1ea4cc6fca98f5ed0143ec0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7983 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 diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-39.pyc deleted file mode 100644 index 9db88480547ac3442228bbab60c5bd78f619fc13..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19128 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 P$RQ)Z!sp2s&BhD>=rpk0 diff --git a/env/Lib/site-packages/pip/_internal/vcs/bazaar.py b/env/Lib/site-packages/pip/_internal/vcs/bazaar.py index 42b68773..20a17ed0 100644 --- a/env/Lib/site-packages/pip/_internal/vcs/bazaar.py +++ b/env/Lib/site-packages/pip/_internal/vcs/bazaar.py @@ -16,61 +16,76 @@ logger = logging.getLogger(__name__) class Bazaar(VersionControl): - name = 'bzr' - dirname = '.bzr' - repo_name = 'branch' + name = "bzr" + dirname = ".bzr" + repo_name = "branch" schemes = ( - 'bzr+http', 'bzr+https', 'bzr+ssh', 'bzr+sftp', 'bzr+ftp', - 'bzr+lp', 'bzr+file' + "bzr+http", + "bzr+https", + "bzr+ssh", + "bzr+sftp", + "bzr+ftp", + "bzr+lp", + "bzr+file", ) @staticmethod - def get_base_rev_args(rev): - # type: (str) -> List[str] - return ['-r', rev] + def get_base_rev_args(rev: str) -> List[str]: + return ["-r", rev] - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def fetch_new( + self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int + ) -> None: rev_display = rev_options.to_display() logger.info( - 'Checking out %s%s to %s', + "Checking out %s%s to %s", url, rev_display, display_path(dest), ) - cmd_args = ( - make_command('branch', '-q', rev_options.to_args(), url, dest) + if verbosity <= 0: + flag = "--quiet" + elif verbosity == 1: + flag = "" + else: + flag = f"-{'v'*verbosity}" + cmd_args = make_command( + "checkout", "--lightweight", flag, rev_options.to_args(), url, dest ) self.run_command(cmd_args) - def switch(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - self.run_command(make_command('switch', url), cwd=dest) + def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: + self.run_command(make_command("switch", url), cwd=dest) - def update(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - cmd_args = make_command('pull', '-q', rev_options.to_args()) + def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: + output = self.run_command( + make_command("info"), show_stdout=False, stdout_only=True, cwd=dest + ) + if output.startswith("Standalone "): + # Older versions of pip used to create standalone branches. + # Convert the standalone branch to a checkout by calling "bzr bind". + cmd_args = make_command("bind", "-q", url) + self.run_command(cmd_args, cwd=dest) + + cmd_args = make_command("update", "-q", rev_options.to_args()) self.run_command(cmd_args, cwd=dest) @classmethod - def get_url_rev_and_auth(cls, url): - # type: (str) -> Tuple[str, Optional[str], AuthInfo] - # hotfix the URL scheme after removing bzr+ from bzr+ssh:// readd it + def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]: + # hotfix the URL scheme after removing bzr+ from bzr+ssh:// re-add it url, rev, user_pass = super().get_url_rev_and_auth(url) - if url.startswith('ssh://'): - url = 'bzr+' + url + if url.startswith("ssh://"): + url = "bzr+" + url return url, rev, user_pass @classmethod - def get_remote_url(cls, location): - # type: (str) -> str + def get_remote_url(cls, location: str) -> str: urls = cls.run_command( - ['info'], show_stdout=False, stdout_only=True, cwd=location + ["info"], show_stdout=False, stdout_only=True, cwd=location ) for line in urls.splitlines(): line = line.strip() - for x in ('checkout of branch: ', - 'parent branch: '): + for x in ("checkout of branch: ", "parent branch: "): if line.startswith(x): repo = line.split(x)[1] if cls._is_local_repository(repo): @@ -79,16 +94,17 @@ class Bazaar(VersionControl): raise RemoteNotFoundError @classmethod - def get_revision(cls, location): - # type: (str) -> str + def get_revision(cls, location: str) -> str: revision = cls.run_command( - ['revno'], show_stdout=False, stdout_only=True, cwd=location, + ["revno"], + show_stdout=False, + stdout_only=True, + cwd=location, ) return revision.splitlines()[-1] @classmethod - def is_commit_id_equal(cls, dest, name): - # type: (str, Optional[str]) -> bool + def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool: """Always assume the versions don't match""" return False diff --git a/env/Lib/site-packages/pip/_internal/vcs/git.py b/env/Lib/site-packages/pip/_internal/vcs/git.py index b7c1b9fe..8d1d4993 100644 --- a/env/Lib/site-packages/pip/_internal/vcs/git.py +++ b/env/Lib/site-packages/pip/_internal/vcs/git.py @@ -1,22 +1,21 @@ import logging import os.path +import pathlib import re import urllib.parse import urllib.request from typing import List, Optional, Tuple -from pip._vendor.packaging.version import _BaseVersion -from pip._vendor.packaging.version import parse as parse_version - from pip._internal.exceptions import BadCommand, InstallationError from pip._internal.utils.misc import HiddenText, display_path, hide_url from pip._internal.utils.subprocess import make_command from pip._internal.vcs.versioncontrol import ( AuthInfo, RemoteNotFoundError, + RemoteNotValidError, RevOptions, VersionControl, - find_path_to_setup_from_repo_root, + find_path_to_project_root_from_repo_root, vcs, ) @@ -27,33 +26,57 @@ urlunsplit = urllib.parse.urlunsplit logger = logging.getLogger(__name__) -HASH_REGEX = re.compile('^[a-fA-F0-9]{40}$') +GIT_VERSION_REGEX = re.compile( + r"^git version " # Prefix. + r"(\d+)" # Major. + r"\.(\d+)" # Dot, minor. + r"(?:\.(\d+))?" # Optional dot, patch. + r".*$" # Suffix, including any pre- and post-release segments we don't care about. +) + +HASH_REGEX = re.compile("^[a-fA-F0-9]{40}$") + +# SCP (Secure copy protocol) shorthand. e.g. 'git@example.com:foo/bar.git' +SCP_REGEX = re.compile( + r"""^ + # Optional user, e.g. 'git@' + (\w+@)? + # Server, e.g. 'github.com'. + ([^/:]+): + # The server-side path. e.g. 'user/project.git'. Must start with an + # alphanumeric character so as not to be confusable with a Windows paths + # like 'C:/foo/bar' or 'C:\foo\bar'. + (\w[^:]*) + $""", + re.VERBOSE, +) -def looks_like_hash(sha): - # type: (str) -> bool +def looks_like_hash(sha: str) -> bool: return bool(HASH_REGEX.match(sha)) class Git(VersionControl): - name = 'git' - dirname = '.git' - repo_name = 'clone' + name = "git" + dirname = ".git" + repo_name = "clone" schemes = ( - 'git+http', 'git+https', 'git+ssh', 'git+git', 'git+file', + "git+http", + "git+https", + "git+ssh", + "git+git", + "git+file", ) # Prevent the user's environment variables from interfering with pip: # https://github.com/pypa/pip/issues/1130 - unset_environ = ('GIT_DIR', 'GIT_WORK_TREE') - default_arg_rev = 'HEAD' + unset_environ = ("GIT_DIR", "GIT_WORK_TREE") + default_arg_rev = "HEAD" @staticmethod - def get_base_rev_args(rev): - # type: (str) -> List[str] + def get_base_rev_args(rev: str) -> List[str]: return [rev] - def is_immutable_rev_checkout(self, url, dest): - # type: (str, str) -> bool + def is_immutable_rev_checkout(self, url: str, dest: str) -> bool: _, rev_options = self.get_url_rev_options(hide_url(url)) if not rev_options.rev: return False @@ -64,30 +87,24 @@ class Git(VersionControl): # return False in the rare case rev is both a commit hash # and a tag or a branch; we don't want to cache in that case # because that branch/tag could point to something else in the future - is_tag_or_branch = bool( - self.get_revision_sha(dest, rev_options.rev)[0] - ) + is_tag_or_branch = bool(self.get_revision_sha(dest, rev_options.rev)[0]) return not is_tag_or_branch - def get_git_version(self): - # type: () -> _BaseVersion - VERSION_PFX = 'git version ' + def get_git_version(self) -> Tuple[int, ...]: version = self.run_command( - ['version'], show_stdout=False, stdout_only=True + ["version"], + command_desc="git version", + show_stdout=False, + stdout_only=True, ) - if version.startswith(VERSION_PFX): - version = version[len(VERSION_PFX):].split()[0] - else: - version = '' - # get first 3 positions of the git version because - # on windows it is x.y.z.windows.t, and this parses as - # LegacyVersion which always smaller than a Version. - version = '.'.join(version.split('.')[:3]) - return parse_version(version) + match = GIT_VERSION_REGEX.match(version) + if not match: + logger.warning("Can't parse git version: %s", version) + return () + return tuple(int(c) for c in match.groups()) @classmethod - def get_current_branch(cls, location): - # type: (str) -> Optional[str] + def get_current_branch(cls, location: str) -> Optional[str]: """ Return the current branch, or None if HEAD isn't at a branch (e.g. detached HEAD). @@ -96,24 +113,23 @@ class Git(VersionControl): # HEAD rather than a symbolic ref. In addition, the -q causes the # command to exit with status code 1 instead of 128 in this case # and to suppress the message to stderr. - args = ['symbolic-ref', '-q', 'HEAD'] + args = ["symbolic-ref", "-q", "HEAD"] output = cls.run_command( args, - extra_ok_returncodes=(1, ), + extra_ok_returncodes=(1,), show_stdout=False, stdout_only=True, cwd=location, ) ref = output.strip() - if ref.startswith('refs/heads/'): - return ref[len('refs/heads/'):] + if ref.startswith("refs/heads/"): + return ref[len("refs/heads/") :] return None @classmethod - def get_revision_sha(cls, dest, rev): - # type: (str, str) -> Tuple[Optional[str], bool] + def get_revision_sha(cls, dest: str, rev: str) -> Tuple[Optional[str], bool]: """ Return (sha_or_none, is_branch), where sha_or_none is a commit hash if the revision names a remote branch or tag, otherwise None. @@ -124,11 +140,11 @@ class Git(VersionControl): """ # Pass rev to pre-filter the list. output = cls.run_command( - ['show-ref', rev], + ["show-ref", rev], cwd=dest, show_stdout=False, stdout_only=True, - on_returncode='ignore', + on_returncode="ignore", ) refs = {} # NOTE: We do not use splitlines here since that would split on other @@ -143,12 +159,12 @@ class Git(VersionControl): except ValueError: # Include the offending line to simplify troubleshooting if # this error ever occurs. - raise ValueError(f'unexpected show-ref line: {line!r}') + raise ValueError(f"unexpected show-ref line: {line!r}") refs[ref_name] = ref_sha - branch_ref = f'refs/remotes/origin/{rev}' - tag_ref = f'refs/tags/{rev}' + branch_ref = f"refs/remotes/origin/{rev}" + tag_ref = f"refs/tags/{rev}" sha = refs.get(branch_ref) if sha is not None: @@ -159,8 +175,7 @@ class Git(VersionControl): return (sha, False) @classmethod - def _should_fetch(cls, dest, rev): - # type: (str, str) -> bool + def _should_fetch(cls, dest: str, rev: str) -> bool: """ Return true if rev is a ref or is a commit that we don't have locally. @@ -183,8 +198,9 @@ class Git(VersionControl): return True @classmethod - def resolve_revision(cls, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> RevOptions + def resolve_revision( + cls, dest: str, url: HiddenText, rev_options: RevOptions + ) -> RevOptions: """ Resolve a revision to a new RevOptions object with the SHA1 of the branch, tag, or ref if found. @@ -218,18 +234,17 @@ class Git(VersionControl): # fetch the requested revision cls.run_command( - make_command('fetch', '-q', url, rev_options.to_args()), + make_command("fetch", "-q", url, rev_options.to_args()), cwd=dest, ) # Change the revision to the SHA of the ref we fetched - sha = cls.get_revision(dest, rev='FETCH_HEAD') + sha = cls.get_revision(dest, rev="FETCH_HEAD") rev_options = rev_options.make_new(sha) return rev_options @classmethod - def is_commit_id_equal(cls, dest, name): - # type: (str, Optional[str]) -> bool + def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool: """ Return whether the current commit hash equals the given name. @@ -243,65 +258,95 @@ class Git(VersionControl): return cls.get_revision(dest) == name - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def fetch_new( + self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int + ) -> None: rev_display = rev_options.to_display() - logger.info('Cloning %s%s to %s', url, rev_display, display_path(dest)) - self.run_command(make_command('clone', '-q', url, dest)) + logger.info("Cloning %s%s to %s", url, rev_display, display_path(dest)) + if verbosity <= 0: + flags: Tuple[str, ...] = ("--quiet",) + elif verbosity == 1: + flags = () + else: + flags = ("--verbose", "--progress") + if self.get_git_version() >= (2, 17): + # Git added support for partial clone in 2.17 + # https://git-scm.com/docs/partial-clone + # Speeds up cloning by functioning without a complete copy of repository + self.run_command( + make_command( + "clone", + "--filter=blob:none", + *flags, + url, + dest, + ) + ) + else: + self.run_command(make_command("clone", *flags, url, dest)) if rev_options.rev: # Then a specific revision was requested. rev_options = self.resolve_revision(dest, url, rev_options) - branch_name = getattr(rev_options, 'branch_name', None) + branch_name = getattr(rev_options, "branch_name", None) + logger.debug("Rev options %s, branch_name %s", rev_options, branch_name) if branch_name is None: # Only do a checkout if the current commit id doesn't match # the requested revision. if not self.is_commit_id_equal(dest, rev_options.rev): cmd_args = make_command( - 'checkout', '-q', rev_options.to_args(), + "checkout", + "-q", + rev_options.to_args(), ) self.run_command(cmd_args, cwd=dest) elif self.get_current_branch(dest) != branch_name: # Then a specific branch was requested, and that branch # is not yet checked out. - track_branch = f'origin/{branch_name}' + track_branch = f"origin/{branch_name}" cmd_args = [ - 'checkout', '-b', branch_name, '--track', track_branch, + "checkout", + "-b", + branch_name, + "--track", + track_branch, ] self.run_command(cmd_args, cwd=dest) + else: + sha = self.get_revision(dest) + rev_options = rev_options.make_new(sha) + + logger.info("Resolved %s to commit %s", url, rev_options.rev) #: repo may contain submodules self.update_submodules(dest) - def switch(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: self.run_command( - make_command('config', 'remote.origin.url', url), + make_command("config", "remote.origin.url", url), cwd=dest, ) - cmd_args = make_command('checkout', '-q', rev_options.to_args()) + cmd_args = make_command("checkout", "-q", rev_options.to_args()) self.run_command(cmd_args, cwd=dest) self.update_submodules(dest) - def update(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: # First fetch changes from the default remote - if self.get_git_version() >= parse_version('1.9.0'): + if self.get_git_version() >= (1, 9): # fetch tags in addition to everything else - self.run_command(['fetch', '-q', '--tags'], cwd=dest) + self.run_command(["fetch", "-q", "--tags"], cwd=dest) else: - self.run_command(['fetch', '-q'], cwd=dest) + self.run_command(["fetch", "-q"], cwd=dest) # Then reset to wanted revision (maybe even origin/master) rev_options = self.resolve_revision(dest, url, rev_options) - cmd_args = make_command('reset', '--hard', '-q', rev_options.to_args()) + cmd_args = make_command("reset", "--hard", "-q", rev_options.to_args()) self.run_command(cmd_args, cwd=dest) #: update submodules self.update_submodules(dest) @classmethod - def get_remote_url(cls, location): - # type: (str) -> str + def get_remote_url(cls, location: str) -> str: """ Return URL of the first remote encountered. @@ -311,8 +356,8 @@ class Git(VersionControl): # We need to pass 1 for extra_ok_returncodes since the command # exits with return code 1 if there are no matching lines. stdout = cls.run_command( - ['config', '--get-regexp', r'remote\..*\.url'], - extra_ok_returncodes=(1, ), + ["config", "--get-regexp", r"remote\..*\.url"], + extra_ok_returncodes=(1,), show_stdout=False, stdout_only=True, cwd=location, @@ -324,21 +369,51 @@ class Git(VersionControl): raise RemoteNotFoundError for remote in remotes: - if remote.startswith('remote.origin.url '): + if remote.startswith("remote.origin.url "): found_remote = remote break - url = found_remote.split(' ')[1] - return url.strip() + url = found_remote.split(" ")[1] + return cls._git_remote_to_pip_url(url.strip()) + + @staticmethod + def _git_remote_to_pip_url(url: str) -> str: + """ + Convert a remote url from what git uses to what pip accepts. + + There are 3 legal forms **url** may take: + + 1. A fully qualified url: ssh://git@example.com/foo/bar.git + 2. A local project.git folder: /path/to/bare/repository.git + 3. SCP shorthand for form 1: git@example.com:foo/bar.git + + Form 1 is output as-is. Form 2 must be converted to URI and form 3 must + be converted to form 1. + + See the corresponding test test_git_remote_url_to_pip() for examples of + sample inputs/outputs. + """ + if re.match(r"\w+://", url): + # This is already valid. Pass it though as-is. + return url + if os.path.exists(url): + # A local bare remote (git clone --mirror). + # Needs a file:// prefix. + return pathlib.PurePath(url).as_uri() + scp_match = SCP_REGEX.match(url) + if scp_match: + # Add an ssh:// prefix and replace the ':' with a '/'. + return scp_match.expand(r"ssh://\1\2/\3") + # Otherwise, bail out. + raise RemoteNotValidError(url) @classmethod - def has_commit(cls, location, rev): - # type: (str, str) -> bool + def has_commit(cls, location: str, rev: str) -> bool: """ Check if rev is a commit that is available in the local repository. """ try: cls.run_command( - ['rev-parse', '-q', '--verify', "sha^" + rev], + ["rev-parse", "-q", "--verify", "sha^" + rev], cwd=location, log_failed_cmd=False, ) @@ -348,12 +423,11 @@ class Git(VersionControl): return True @classmethod - def get_revision(cls, location, rev=None): - # type: (str, Optional[str]) -> str + def get_revision(cls, location: str, rev: Optional[str] = None) -> str: if rev is None: - rev = 'HEAD' + rev = "HEAD" current_rev = cls.run_command( - ['rev-parse', rev], + ["rev-parse", rev], show_stdout=False, stdout_only=True, cwd=location, @@ -361,27 +435,25 @@ class Git(VersionControl): return current_rev.strip() @classmethod - def get_subdirectory(cls, location): - # type: (str) -> Optional[str] + def get_subdirectory(cls, location: str) -> Optional[str]: """ - Return the path to setup.py, relative to the repo root. - Return None if setup.py is in the repo root. + Return the path to Python project root, relative to the repo root. + Return None if the project root is in the repo root. """ # find the repo root git_dir = cls.run_command( - ['rev-parse', '--git-dir'], + ["rev-parse", "--git-dir"], show_stdout=False, stdout_only=True, cwd=location, ).strip() if not os.path.isabs(git_dir): git_dir = os.path.join(location, git_dir) - repo_root = os.path.abspath(os.path.join(git_dir, '..')) - return find_path_to_setup_from_repo_root(location, repo_root) + repo_root = os.path.abspath(os.path.join(git_dir, "..")) + return find_path_to_project_root_from_repo_root(location, repo_root) @classmethod - def get_url_rev_and_auth(cls, url): - # type: (str) -> Tuple[str, Optional[str], AuthInfo] + def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]: """ Prefixes stub URLs like 'user@hostname:user/repo.git' with 'ssh://'. That's required because although they use SSH they sometimes don't @@ -391,60 +463,64 @@ class Git(VersionControl): # Works around an apparent Git bug # (see https://article.gmane.org/gmane.comp.version-control.git/146500) scheme, netloc, path, query, fragment = urlsplit(url) - if scheme.endswith('file'): - initial_slashes = path[:-len(path.lstrip('/'))] - newpath = ( - initial_slashes + - urllib.request.url2pathname(path) - .replace('\\', '/').lstrip('/') - ) - after_plus = scheme.find('+') + 1 + if scheme.endswith("file"): + initial_slashes = path[: -len(path.lstrip("/"))] + newpath = initial_slashes + urllib.request.url2pathname(path).replace( + "\\", "/" + ).lstrip("/") + after_plus = scheme.find("+") + 1 url = scheme[:after_plus] + urlunsplit( (scheme[after_plus:], netloc, newpath, query, fragment), ) - if '://' not in url: - assert 'file:' not in url - url = url.replace('git+', 'git+ssh://') + if "://" not in url: + assert "file:" not in url + url = url.replace("git+", "git+ssh://") url, rev, user_pass = super().get_url_rev_and_auth(url) - url = url.replace('ssh://', '') + url = url.replace("ssh://", "") else: url, rev, user_pass = super().get_url_rev_and_auth(url) return url, rev, user_pass @classmethod - def update_submodules(cls, location): - # type: (str) -> None - if not os.path.exists(os.path.join(location, '.gitmodules')): + def update_submodules(cls, location: str) -> None: + if not os.path.exists(os.path.join(location, ".gitmodules")): return cls.run_command( - ['submodule', 'update', '--init', '--recursive', '-q'], + ["submodule", "update", "--init", "--recursive", "-q"], cwd=location, ) @classmethod - def get_repository_root(cls, location): - # type: (str) -> Optional[str] + def get_repository_root(cls, location: str) -> Optional[str]: loc = super().get_repository_root(location) if loc: return loc try: r = cls.run_command( - ['rev-parse', '--show-toplevel'], + ["rev-parse", "--show-toplevel"], cwd=location, show_stdout=False, stdout_only=True, - on_returncode='raise', + on_returncode="raise", log_failed_cmd=False, ) except BadCommand: - logger.debug("could not determine if %s is under git control " - "because git is not available", location) + logger.debug( + "could not determine if %s is under git control " + "because git is not available", + location, + ) return None except InstallationError: return None - return os.path.normpath(r.rstrip('\r\n')) + return os.path.normpath(r.rstrip("\r\n")) + + @staticmethod + def should_add_vcs_url_prefix(repo_url: str) -> bool: + """In either https or ssh form, requirements must be prefixed with git+.""" + return True vcs.register(Git) diff --git a/env/Lib/site-packages/pip/_internal/vcs/mercurial.py b/env/Lib/site-packages/pip/_internal/vcs/mercurial.py index b4f887d3..4595960b 100644 --- a/env/Lib/site-packages/pip/_internal/vcs/mercurial.py +++ b/env/Lib/site-packages/pip/_internal/vcs/mercurial.py @@ -1,7 +1,7 @@ import configparser import logging import os -from typing import List, Optional +from typing import List, Optional, Tuple from pip._internal.exceptions import BadCommand, InstallationError from pip._internal.utils.misc import HiddenText, display_path @@ -10,7 +10,7 @@ from pip._internal.utils.urls import path_to_url from pip._internal.vcs.versioncontrol import ( RevOptions, VersionControl, - find_path_to_setup_from_repo_root, + find_path_to_project_root_from_repo_root, vcs, ) @@ -18,61 +18,68 @@ logger = logging.getLogger(__name__) class Mercurial(VersionControl): - name = 'hg' - dirname = '.hg' - repo_name = 'clone' + name = "hg" + dirname = ".hg" + repo_name = "clone" schemes = ( - 'hg+file', 'hg+http', 'hg+https', 'hg+ssh', 'hg+static-http', + "hg+file", + "hg+http", + "hg+https", + "hg+ssh", + "hg+static-http", ) @staticmethod - def get_base_rev_args(rev): - # type: (str) -> List[str] - return [rev] + def get_base_rev_args(rev: str) -> List[str]: + return ["-r", rev] - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def fetch_new( + self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int + ) -> None: rev_display = rev_options.to_display() logger.info( - 'Cloning hg %s%s to %s', + "Cloning hg %s%s to %s", url, rev_display, display_path(dest), ) - self.run_command(make_command('clone', '--noupdate', '-q', url, dest)) + if verbosity <= 0: + flags: Tuple[str, ...] = ("--quiet",) + elif verbosity == 1: + flags = () + elif verbosity == 2: + flags = ("--verbose",) + else: + flags = ("--verbose", "--debug") + self.run_command(make_command("clone", "--noupdate", *flags, url, dest)) self.run_command( - make_command('update', '-q', rev_options.to_args()), + make_command("update", *flags, rev_options.to_args()), cwd=dest, ) - def switch(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - repo_config = os.path.join(dest, self.dirname, 'hgrc') + def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: + repo_config = os.path.join(dest, self.dirname, "hgrc") config = configparser.RawConfigParser() try: config.read(repo_config) - config.set('paths', 'default', url.secret) - with open(repo_config, 'w') as config_file: + config.set("paths", "default", url.secret) + with open(repo_config, "w") as config_file: config.write(config_file) except (OSError, configparser.NoSectionError) as exc: - logger.warning( - 'Could not switch Mercurial repository to %s: %s', url, exc, - ) + logger.warning("Could not switch Mercurial repository to %s: %s", url, exc) else: - cmd_args = make_command('update', '-q', rev_options.to_args()) + cmd_args = make_command("update", "-q", rev_options.to_args()) self.run_command(cmd_args, cwd=dest) - def update(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None - self.run_command(['pull', '-q'], cwd=dest) - cmd_args = make_command('update', '-q', rev_options.to_args()) + def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: + self.run_command(["pull", "-q"], cwd=dest) + cmd_args = make_command("update", "-q", rev_options.to_args()) self.run_command(cmd_args, cwd=dest) @classmethod - def get_remote_url(cls, location): - # type: (str) -> str + def get_remote_url(cls, location: str) -> str: url = cls.run_command( - ['showconfig', 'paths.default'], + ["showconfig", "paths.default"], show_stdout=False, stdout_only=True, cwd=location, @@ -82,13 +89,12 @@ class Mercurial(VersionControl): return url.strip() @classmethod - def get_revision(cls, location): - # type: (str) -> str + def get_revision(cls, location: str) -> str: """ Return the repository-local changeset revision number, as an integer. """ current_revision = cls.run_command( - ['parents', '--template={rev}'], + ["parents", "--template={rev}"], show_stdout=False, stdout_only=True, cwd=location, @@ -96,14 +102,13 @@ class Mercurial(VersionControl): return current_revision @classmethod - def get_requirement_revision(cls, location): - # type: (str) -> str + def get_requirement_revision(cls, location: str) -> str: """ Return the changeset identification hash, as a 40-character hexadecimal string """ current_rev_hash = cls.run_command( - ['parents', '--template={node}'], + ["parents", "--template={node}"], show_stdout=False, stdout_only=True, cwd=location, @@ -111,48 +116,48 @@ class Mercurial(VersionControl): return current_rev_hash @classmethod - def is_commit_id_equal(cls, dest, name): - # type: (str, Optional[str]) -> bool + def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool: """Always assume the versions don't match""" return False @classmethod - def get_subdirectory(cls, location): - # type: (str) -> Optional[str] + def get_subdirectory(cls, location: str) -> Optional[str]: """ - Return the path to setup.py, relative to the repo root. - Return None if setup.py is in the repo root. + Return the path to Python project root, relative to the repo root. + Return None if the project root is in the repo root. """ # find the repo root repo_root = cls.run_command( - ['root'], show_stdout=False, stdout_only=True, cwd=location + ["root"], show_stdout=False, stdout_only=True, cwd=location ).strip() if not os.path.isabs(repo_root): repo_root = os.path.abspath(os.path.join(location, repo_root)) - return find_path_to_setup_from_repo_root(location, repo_root) + return find_path_to_project_root_from_repo_root(location, repo_root) @classmethod - def get_repository_root(cls, location): - # type: (str) -> Optional[str] + def get_repository_root(cls, location: str) -> Optional[str]: loc = super().get_repository_root(location) if loc: return loc try: r = cls.run_command( - ['root'], + ["root"], cwd=location, show_stdout=False, stdout_only=True, - on_returncode='raise', + on_returncode="raise", log_failed_cmd=False, ) except BadCommand: - logger.debug("could not determine if %s is under hg control " - "because hg is not available", location) + logger.debug( + "could not determine if %s is under hg control " + "because hg is not available", + location, + ) return None except InstallationError: return None - return os.path.normpath(r.rstrip('\r\n')) + return os.path.normpath(r.rstrip("\r\n")) vcs.register(Mercurial) diff --git a/env/Lib/site-packages/pip/_internal/vcs/subversion.py b/env/Lib/site-packages/pip/_internal/vcs/subversion.py index 4d1237ca..16d93a67 100644 --- a/env/Lib/site-packages/pip/_internal/vcs/subversion.py +++ b/env/Lib/site-packages/pip/_internal/vcs/subversion.py @@ -7,6 +7,7 @@ from pip._internal.utils.misc import ( HiddenText, display_path, is_console_interactive, + is_installable_dir, split_auth_from_netloc, ) from pip._internal.utils.subprocess import CommandArgs, make_command @@ -23,30 +24,25 @@ logger = logging.getLogger(__name__) _svn_xml_url_re = re.compile('url="([^"]+)"') _svn_rev_re = re.compile(r'committed-rev="(\d+)"') _svn_info_xml_rev_re = re.compile(r'\s*revision="(\d+)"') -_svn_info_xml_url_re = re.compile(r'<url>(.*)</url>') +_svn_info_xml_url_re = re.compile(r"<url>(.*)</url>") class Subversion(VersionControl): - name = 'svn' - dirname = '.svn' - repo_name = 'checkout' - schemes = ( - 'svn+ssh', 'svn+http', 'svn+https', 'svn+svn', 'svn+file' - ) + name = "svn" + dirname = ".svn" + repo_name = "checkout" + schemes = ("svn+ssh", "svn+http", "svn+https", "svn+svn", "svn+file") @classmethod - def should_add_vcs_url_prefix(cls, remote_url): - # type: (str) -> bool + def should_add_vcs_url_prefix(cls, remote_url: str) -> bool: return True @staticmethod - def get_base_rev_args(rev): - # type: (str) -> List[str] - return ['-r', rev] + def get_base_rev_args(rev: str) -> List[str]: + return ["-r", rev] @classmethod - def get_revision(cls, location): - # type: (str) -> str + def get_revision(cls, location: str) -> str: """ Return the maximum revision for all files under a given location """ @@ -56,9 +52,9 @@ class Subversion(VersionControl): for base, dirs, _ in os.walk(location): if cls.dirname not in dirs: dirs[:] = [] - continue # no sense walking uncontrolled subdirs + continue # no sense walking uncontrolled subdirs dirs.remove(cls.dirname) - entries_fn = os.path.join(base, cls.dirname, 'entries') + entries_fn = os.path.join(base, cls.dirname, "entries") if not os.path.exists(entries_fn): # FIXME: should we warn? continue @@ -67,21 +63,22 @@ class Subversion(VersionControl): if base == location: assert dirurl is not None - base = dirurl + '/' # save the root url + base = dirurl + "/" # save the root url elif not dirurl or not dirurl.startswith(base): dirs[:] = [] - continue # not part of the same svn tree, skip it + continue # not part of the same svn tree, skip it revision = max(revision, localrev) return str(revision) @classmethod - def get_netloc_and_auth(cls, netloc, scheme): - # type: (str, str) -> Tuple[str, Tuple[Optional[str], Optional[str]]] + def get_netloc_and_auth( + cls, netloc: str, scheme: str + ) -> Tuple[str, Tuple[Optional[str], Optional[str]]]: """ This override allows the auth information to be passed to svn via the --username and --password options instead of via the URL. """ - if scheme == 'ssh': + if scheme == "ssh": # The --username and --password options can't be used for # svn+ssh URLs, so keep the auth information in the URL. return super().get_netloc_and_auth(netloc, scheme) @@ -89,40 +86,38 @@ class Subversion(VersionControl): return split_auth_from_netloc(netloc) @classmethod - def get_url_rev_and_auth(cls, url): - # type: (str) -> Tuple[str, Optional[str], AuthInfo] - # hotfix the URL scheme after removing svn+ from svn+ssh:// readd it + def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]: + # hotfix the URL scheme after removing svn+ from svn+ssh:// re-add it url, rev, user_pass = super().get_url_rev_and_auth(url) - if url.startswith('ssh://'): - url = 'svn+' + url + if url.startswith("ssh://"): + url = "svn+" + url return url, rev, user_pass @staticmethod - def make_rev_args(username, password): - # type: (Optional[str], Optional[HiddenText]) -> CommandArgs - extra_args = [] # type: CommandArgs + def make_rev_args( + username: Optional[str], password: Optional[HiddenText] + ) -> CommandArgs: + extra_args: CommandArgs = [] if username: - extra_args += ['--username', username] + extra_args += ["--username", username] if password: - extra_args += ['--password', password] + extra_args += ["--password", password] return extra_args @classmethod - def get_remote_url(cls, location): - # type: (str) -> str - # In cases where the source is in a subdirectory, not alongside - # setup.py we have to look up in the location until we find a real - # setup.py + def get_remote_url(cls, location: str) -> str: + # In cases where the source is in a subdirectory, we have to look up in + # the location until we find a valid project root. orig_location = location - while not os.path.exists(os.path.join(location, 'setup.py')): + while not is_installable_dir(location): last_location = location location = os.path.dirname(location) if location == last_location: # We've traversed up to the root of the filesystem without - # finding setup.py + # finding a Python project. logger.warning( - "Could not find setup.py for directory %s (tried all " + "Could not find Python project for directory %s (tried all " "parent directories)", orig_location, ) @@ -135,30 +130,27 @@ class Subversion(VersionControl): return url @classmethod - def _get_svn_url_rev(cls, location): - # type: (str) -> Tuple[Optional[str], int] + def _get_svn_url_rev(cls, location: str) -> Tuple[Optional[str], int]: from pip._internal.exceptions import InstallationError - entries_path = os.path.join(location, cls.dirname, 'entries') + entries_path = os.path.join(location, cls.dirname, "entries") if os.path.exists(entries_path): with open(entries_path) as f: data = f.read() else: # subversion >= 1.7 does not have the 'entries' file - data = '' + data = "" url = None - if (data.startswith('8') or - data.startswith('9') or - data.startswith('10')): - entries = list(map(str.splitlines, data.split('\n\x0c\n'))) + if data.startswith("8") or data.startswith("9") or data.startswith("10"): + entries = list(map(str.splitlines, data.split("\n\x0c\n"))) del entries[0][0] # get rid of the '8' url = entries[0][3] revs = [int(d[9]) for d in entries if len(d) > 9 and d[9]] + [0] - elif data.startswith('<?xml'): + elif data.startswith("<?xml"): match = _svn_xml_url_re.search(data) if not match: - raise ValueError(f'Badly formatted data: {data!r}') - url = match.group(1) # get repository URL + raise ValueError(f"Badly formatted data: {data!r}") + url = match.group(1) # get repository URL revs = [int(m.group(1)) for m in _svn_rev_re.finditer(data)] + [0] else: try: @@ -169,16 +161,14 @@ class Subversion(VersionControl): # is being used to prompt for passwords, because passwords # are only potentially needed for remote server requests. xml = cls.run_command( - ['info', '--xml', location], + ["info", "--xml", location], show_stdout=False, stdout_only=True, ) match = _svn_info_xml_url_re.search(xml) assert match is not None url = match.group(1) - revs = [ - int(m.group(1)) for m in _svn_info_xml_rev_re.finditer(xml) - ] + revs = [int(m.group(1)) for m in _svn_info_xml_rev_re.finditer(xml)] except InstallationError: url, revs = None, [] @@ -190,13 +180,11 @@ class Subversion(VersionControl): return url, rev @classmethod - def is_commit_id_equal(cls, dest, name): - # type: (str, Optional[str]) -> bool + def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool: """Always assume the versions don't match""" return False - def __init__(self, use_interactive=None): - # type: (bool) -> None + def __init__(self, use_interactive: Optional[bool] = None) -> None: if use_interactive is None: use_interactive = is_console_interactive() self.use_interactive = use_interactive @@ -206,12 +194,11 @@ class Subversion(VersionControl): # Special value definitions: # None: Not evaluated yet. # Empty tuple: Could not parse version. - self._vcs_version = None # type: Optional[Tuple[int, ...]] + self._vcs_version: Optional[Tuple[int, ...]] = None super().__init__() - def call_vcs_version(self): - # type: () -> Tuple[int, ...] + def call_vcs_version(self) -> Tuple[int, ...]: """Query the version of the currently installed Subversion client. :return: A tuple containing the parts of the version information or @@ -225,15 +212,13 @@ class Subversion(VersionControl): # compiled Mar 28 2018, 08:49:13 on x86_64-pc-linux-gnu # svn, version 1.12.0-SlikSvn (SlikSvn/1.12.0) # compiled May 28 2019, 13:44:56 on x86_64-microsoft-windows6.2 - version_prefix = 'svn, version ' - version = self.run_command( - ['--version'], show_stdout=False, stdout_only=True - ) + version_prefix = "svn, version " + version = self.run_command(["--version"], show_stdout=False, stdout_only=True) if not version.startswith(version_prefix): return () - version = version[len(version_prefix):].split()[0] - version_list = version.partition('-')[0].split('.') + version = version[len(version_prefix) :].split()[0] + version_list = version.partition("-")[0].split(".") try: parsed_version = tuple(map(int, version_list)) except ValueError: @@ -241,8 +226,7 @@ class Subversion(VersionControl): return parsed_version - def get_vcs_version(self): - # type: () -> Tuple[int, ...] + def get_vcs_version(self) -> Tuple[int, ...]: """Return the version of the currently installed Subversion client. If the version of the Subversion client has already been queried, @@ -262,8 +246,7 @@ class Subversion(VersionControl): self._vcs_version = vcs_version return vcs_version - def get_remote_call_options(self): - # type: () -> CommandArgs + def get_remote_call_options(self) -> CommandArgs: """Return options to be used on calls to Subversion that contact the server. These options are applicable for the following ``svn`` subcommands used @@ -278,7 +261,7 @@ class Subversion(VersionControl): if not self.use_interactive: # --non-interactive switch is available since Subversion 0.14.4. # Subversion < 1.8 runs in interactive mode by default. - return ['--non-interactive'] + return ["--non-interactive"] svn_version = self.get_vcs_version() # By default, Subversion >= 1.8 runs in non-interactive mode if @@ -290,37 +273,49 @@ class Subversion(VersionControl): # SVN 1.7, pip should continue to support SVN 1.7. Therefore, pip # can't safely add the option if the SVN version is < 1.8 (or unknown). if svn_version >= (1, 8): - return ['--force-interactive'] + return ["--force-interactive"] return [] - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def fetch_new( + self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int + ) -> None: rev_display = rev_options.to_display() logger.info( - 'Checking out %s%s to %s', + "Checking out %s%s to %s", url, rev_display, display_path(dest), ) + if verbosity <= 0: + flag = "--quiet" + else: + flag = "" cmd_args = make_command( - 'checkout', '-q', self.get_remote_call_options(), - rev_options.to_args(), url, dest, + "checkout", + flag, + self.get_remote_call_options(), + rev_options.to_args(), + url, + dest, ) self.run_command(cmd_args) - def switch(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: cmd_args = make_command( - 'switch', self.get_remote_call_options(), rev_options.to_args(), - url, dest, + "switch", + self.get_remote_call_options(), + rev_options.to_args(), + url, + dest, ) self.run_command(cmd_args) - def update(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: cmd_args = make_command( - 'update', self.get_remote_call_options(), rev_options.to_args(), + "update", + self.get_remote_call_options(), + rev_options.to_args(), dest, ) self.run_command(cmd_args) diff --git a/env/Lib/site-packages/pip/_internal/vcs/versioncontrol.py b/env/Lib/site-packages/pip/_internal/vcs/versioncontrol.py index 97977b57..02bbf68e 100644 --- a/env/Lib/site-packages/pip/_internal/vcs/versioncontrol.py +++ b/env/Lib/site-packages/pip/_internal/vcs/versioncontrol.py @@ -6,6 +6,7 @@ import shutil import sys import urllib.parse from typing import ( + TYPE_CHECKING, Any, Dict, Iterable, @@ -27,12 +28,25 @@ from pip._internal.utils.misc import ( display_path, hide_url, hide_value, + is_installable_dir, rmtree, ) -from pip._internal.utils.subprocess import CommandArgs, call_subprocess, make_command +from pip._internal.utils.subprocess import ( + CommandArgs, + call_subprocess, + format_command_args, + make_command, +) from pip._internal.utils.urls import get_url_scheme -__all__ = ['vcs'] +if TYPE_CHECKING: + # Literal was introduced in Python 3.8. + # + # TODO: Remove `if TYPE_CHECKING` when dropping support for Python 3.7. + from typing import Literal + + +__all__ = ["vcs"] logger = logging.getLogger(__name__) @@ -40,19 +54,19 @@ logger = logging.getLogger(__name__) AuthInfo = Tuple[Optional[str], Optional[str]] -def is_url(name): - # type: (str) -> bool +def is_url(name: str) -> bool: """ Return true if the name looks like a URL. """ scheme = get_url_scheme(name) if scheme is None: return False - return scheme in ['http', 'https', 'file', 'ftp'] + vcs.all_schemes + return scheme in ["http", "https", "file", "ftp"] + vcs.all_schemes -def make_vcs_requirement_url(repo_url, rev, project_name, subdir=None): - # type: (str, str, str, Optional[str]) -> str +def make_vcs_requirement_url( + repo_url: str, rev: str, project_name: str, subdir: Optional[str] = None +) -> str: """ Return the URL for a VCS requirement. @@ -61,30 +75,31 @@ def make_vcs_requirement_url(repo_url, rev, project_name, subdir=None): project_name: the (unescaped) project name. """ egg_project_name = project_name.replace("-", "_") - req = f'{repo_url}@{rev}#egg={egg_project_name}' + req = f"{repo_url}@{rev}#egg={egg_project_name}" if subdir: - req += f'&subdirectory={subdir}' + req += f"&subdirectory={subdir}" return req -def find_path_to_setup_from_repo_root(location, repo_root): - # type: (str, str) -> Optional[str] +def find_path_to_project_root_from_repo_root( + location: str, repo_root: str +) -> Optional[str]: """ - Find the path to `setup.py` by searching up the filesystem from `location`. - Return the path to `setup.py` relative to `repo_root`. - Return None if `setup.py` is in `repo_root` or cannot be found. + Find the the Python project's root by searching up the filesystem from + `location`. Return the path to project root relative to `repo_root`. + Return None if the project root is `repo_root`, or cannot be found. """ - # find setup.py + # find project root. orig_location = location - while not os.path.exists(os.path.join(location, 'setup.py')): + while not is_installable_dir(location): last_location = location location = os.path.dirname(location) if location == last_location: # We've traversed up to the root of the filesystem without - # finding setup.py + # finding a Python project. logger.warning( - "Could not find setup.py for directory %s (tried all " + "Could not find a Python project for directory %s (tried all " "parent directories)", orig_location, ) @@ -100,6 +115,12 @@ class RemoteNotFoundError(Exception): pass +class RemoteNotValidError(Exception): + def __init__(self, url: str): + super().__init__(url) + self.url = url + + class RevOptions: """ @@ -111,11 +132,10 @@ class RevOptions: def __init__( self, - vc_class, # type: Type[VersionControl] - rev=None, # type: Optional[str] - extra_args=None, # type: Optional[CommandArgs] - ): - # type: (...) -> None + vc_class: Type["VersionControl"], + rev: Optional[str] = None, + extra_args: Optional[CommandArgs] = None, + ) -> None: """ Args: vc_class: a VersionControl subclass. @@ -128,26 +148,23 @@ class RevOptions: self.extra_args = extra_args self.rev = rev self.vc_class = vc_class - self.branch_name = None # type: Optional[str] + self.branch_name: Optional[str] = None - def __repr__(self): - # type: () -> str - return f'<RevOptions {self.vc_class.name}: rev={self.rev!r}>' + def __repr__(self) -> str: + return f"<RevOptions {self.vc_class.name}: rev={self.rev!r}>" @property - def arg_rev(self): - # type: () -> Optional[str] + def arg_rev(self) -> Optional[str]: if self.rev is None: return self.vc_class.default_arg_rev return self.rev - def to_args(self): - # type: () -> CommandArgs + def to_args(self) -> CommandArgs: """ Return the VCS-specific command arguments. """ - args = [] # type: CommandArgs + args: CommandArgs = [] rev = self.arg_rev if rev is not None: args += self.vc_class.get_base_rev_args(rev) @@ -155,15 +172,13 @@ class RevOptions: return args - def to_display(self): - # type: () -> str + def to_display(self) -> str: if not self.rev: - return '' + return "" - return f' (to revision {self.rev})' + return f" (to revision {self.rev})" - def make_new(self, rev): - # type: (str) -> RevOptions + def make_new(self, rev: str) -> "RevOptions": """ Make a copy of the current instance, but with a new rev. @@ -174,54 +189,46 @@ class RevOptions: class VcsSupport: - _registry = {} # type: Dict[str, VersionControl] - schemes = ['ssh', 'git', 'hg', 'bzr', 'sftp', 'svn'] + _registry: Dict[str, "VersionControl"] = {} + schemes = ["ssh", "git", "hg", "bzr", "sftp", "svn"] - def __init__(self): - # type: () -> None + def __init__(self) -> None: # Register more schemes with urlparse for various version control # systems urllib.parse.uses_netloc.extend(self.schemes) super().__init__() - def __iter__(self): - # type: () -> Iterator[str] + def __iter__(self) -> Iterator[str]: return self._registry.__iter__() @property - def backends(self): - # type: () -> List[VersionControl] + def backends(self) -> List["VersionControl"]: return list(self._registry.values()) @property - def dirnames(self): - # type: () -> List[str] + def dirnames(self) -> List[str]: return [backend.dirname for backend in self.backends] @property - def all_schemes(self): - # type: () -> List[str] - schemes = [] # type: List[str] + def all_schemes(self) -> List[str]: + schemes: List[str] = [] for backend in self.backends: schemes.extend(backend.schemes) return schemes - def register(self, cls): - # type: (Type[VersionControl]) -> None - if not hasattr(cls, 'name'): - logger.warning('Cannot register VCS %s', cls.__name__) + def register(self, cls: Type["VersionControl"]) -> None: + if not hasattr(cls, "name"): + logger.warning("Cannot register VCS %s", cls.__name__) return if cls.name not in self._registry: self._registry[cls.name] = cls() - logger.debug('Registered VCS backend: %s', cls.name) + logger.debug("Registered VCS backend: %s", cls.name) - def unregister(self, name): - # type: (str) -> None + def unregister(self, name: str) -> None: if name in self._registry: del self._registry[name] - def get_backend_for_dir(self, location): - # type: (str) -> Optional[VersionControl] + def get_backend_for_dir(self, location: str) -> Optional["VersionControl"]: """ Return a VersionControl object if a repository of that type is found at the given directory. @@ -231,8 +238,7 @@ class VcsSupport: repo_path = vcs_backend.get_repository_root(location) if not repo_path: continue - logger.debug('Determine that %s uses VCS: %s', - location, vcs_backend.name) + logger.debug("Determine that %s uses VCS: %s", location, vcs_backend.name) vcs_backends[repo_path] = vcs_backend if not vcs_backends: @@ -245,8 +251,7 @@ class VcsSupport: inner_most_repo_path = max(vcs_backends, key=len) return vcs_backends[inner_most_repo_path] - def get_backend_for_scheme(self, scheme): - # type: (str) -> Optional[VersionControl] + def get_backend_for_scheme(self, scheme: str) -> Optional["VersionControl"]: """ Return a VersionControl object or None. """ @@ -255,8 +260,7 @@ class VcsSupport: return vcs_backend return None - def get_backend(self, name): - # type: (str) -> Optional[VersionControl] + def get_backend(self, name: str) -> Optional["VersionControl"]: """ Return a VersionControl object or None. """ @@ -268,44 +272,40 @@ vcs = VcsSupport() class VersionControl: - name = '' - dirname = '' - repo_name = '' + name = "" + dirname = "" + repo_name = "" # List of supported schemes for this Version Control - schemes = () # type: Tuple[str, ...] + schemes: Tuple[str, ...] = () # Iterable of environment variable names to pass to call_subprocess(). - unset_environ = () # type: Tuple[str, ...] - default_arg_rev = None # type: Optional[str] + unset_environ: Tuple[str, ...] = () + default_arg_rev: Optional[str] = None @classmethod - def should_add_vcs_url_prefix(cls, remote_url): - # type: (str) -> bool + def should_add_vcs_url_prefix(cls, remote_url: str) -> bool: """ Return whether the vcs prefix (e.g. "git+") should be added to a repository's remote url when used in a requirement. """ - return not remote_url.lower().startswith(f'{cls.name}:') + return not remote_url.lower().startswith(f"{cls.name}:") @classmethod - def get_subdirectory(cls, location): - # type: (str) -> Optional[str] + def get_subdirectory(cls, location: str) -> Optional[str]: """ - Return the path to setup.py, relative to the repo root. - Return None if setup.py is in the repo root. + Return the path to Python project root, relative to the repo root. + Return None if the project root is in the repo root. """ return None @classmethod - def get_requirement_revision(cls, repo_dir): - # type: (str) -> str + def get_requirement_revision(cls, repo_dir: str) -> str: """ Return the revision string that should be used in a requirement. """ return cls.get_revision(repo_dir) @classmethod - def get_src_requirement(cls, repo_dir, project_name): - # type: (str, str) -> str + def get_src_requirement(cls, repo_dir: str, project_name: str) -> str: """ Return the requirement string to use to redownload the files currently at the given repository directory. @@ -320,18 +320,16 @@ class VersionControl: repo_url = cls.get_remote_url(repo_dir) if cls.should_add_vcs_url_prefix(repo_url): - repo_url = f'{cls.name}+{repo_url}' + repo_url = f"{cls.name}+{repo_url}" revision = cls.get_requirement_revision(repo_dir) subdir = cls.get_subdirectory(repo_dir) - req = make_vcs_requirement_url(repo_url, revision, project_name, - subdir=subdir) + req = make_vcs_requirement_url(repo_url, revision, project_name, subdir=subdir) return req @staticmethod - def get_base_rev_args(rev): - # type: (str) -> List[str] + def get_base_rev_args(rev: str) -> List[str]: """ Return the base revision arguments for a vcs command. @@ -340,8 +338,7 @@ class VersionControl: """ raise NotImplementedError - def is_immutable_rev_checkout(self, url, dest): - # type: (str, str) -> bool + def is_immutable_rev_checkout(self, url: str, dest: str) -> bool: """ Return true if the commit hash checked out at dest matches the revision in url. @@ -355,8 +352,9 @@ class VersionControl: return False @classmethod - def make_rev_options(cls, rev=None, extra_args=None): - # type: (Optional[str], Optional[CommandArgs]) -> RevOptions + def make_rev_options( + cls, rev: Optional[str] = None, extra_args: Optional[CommandArgs] = None + ) -> RevOptions: """ Return a RevOptions object. @@ -367,18 +365,18 @@ class VersionControl: return RevOptions(cls, rev, extra_args=extra_args) @classmethod - def _is_local_repository(cls, repo): - # type: (str) -> bool + def _is_local_repository(cls, repo: str) -> bool: """ - posix absolute paths start with os.path.sep, - win32 ones start with drive (like c:\\folder) + posix absolute paths start with os.path.sep, + win32 ones start with drive (like c:\\folder) """ drive, tail = os.path.splitdrive(repo) return repo.startswith(os.path.sep) or bool(drive) @classmethod - def get_netloc_and_auth(cls, netloc, scheme): - # type: (str, str) -> Tuple[str, Tuple[Optional[str], Optional[str]]] + def get_netloc_and_auth( + cls, netloc: str, scheme: str + ) -> Tuple[str, Tuple[Optional[str], Optional[str]]]: """ Parse the repository URL's netloc, and return the new netloc to use along with auth information. @@ -397,8 +395,7 @@ class VersionControl: return netloc, (None, None) @classmethod - def get_url_rev_and_auth(cls, url): - # type: (str) -> Tuple[str, Optional[str], AuthInfo] + def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]: """ Parse the repository URL to use, and return the URL, revision, and auth info to use. @@ -406,44 +403,44 @@ class VersionControl: Returns: (url, rev, (username, password)). """ scheme, netloc, path, query, frag = urllib.parse.urlsplit(url) - if '+' not in scheme: + if "+" not in scheme: raise ValueError( "Sorry, {!r} is a malformed VCS url. " "The format is <vcs>+<protocol>://<url>, " "e.g. svn+http://myrepo/svn/MyApp#egg=MyApp".format(url) ) # Remove the vcs prefix. - scheme = scheme.split('+', 1)[1] + scheme = scheme.split("+", 1)[1] netloc, user_pass = cls.get_netloc_and_auth(netloc, scheme) rev = None - if '@' in path: - path, rev = path.rsplit('@', 1) + if "@" in path: + path, rev = path.rsplit("@", 1) if not rev: raise InstallationError( "The URL {!r} has an empty revision (after @) " "which is not supported. Include a revision after @ " "or remove @ from the URL.".format(url) ) - url = urllib.parse.urlunsplit((scheme, netloc, path, query, '')) + url = urllib.parse.urlunsplit((scheme, netloc, path, query, "")) return url, rev, user_pass @staticmethod - def make_rev_args(username, password): - # type: (Optional[str], Optional[HiddenText]) -> CommandArgs + def make_rev_args( + username: Optional[str], password: Optional[HiddenText] + ) -> CommandArgs: """ Return the RevOptions "extra arguments" to use in obtain(). """ return [] - def get_url_rev_options(self, url): - # type: (HiddenText) -> Tuple[HiddenText, RevOptions] + def get_url_rev_options(self, url: HiddenText) -> Tuple[HiddenText, RevOptions]: """ Return the URL and RevOptions object to use in obtain(), as a tuple (url, rev_options). """ secret_url, rev, user_pass = self.get_url_rev_and_auth(url.secret) username, secret_password = user_pass - password = None # type: Optional[HiddenText] + password: Optional[HiddenText] = None if secret_password is not None: password = hide_value(secret_password) extra_args = self.make_rev_args(username, password) @@ -452,24 +449,23 @@ class VersionControl: return hide_url(secret_url), rev_options @staticmethod - def normalize_url(url): - # type: (str) -> str + def normalize_url(url: str) -> str: """ Normalize a URL for comparison by unquoting it and removing any trailing slash. """ - return urllib.parse.unquote(url).rstrip('/') + return urllib.parse.unquote(url).rstrip("/") @classmethod - def compare_urls(cls, url1, url2): - # type: (str, str) -> bool + def compare_urls(cls, url1: str, url2: str) -> bool: """ Compare two repo URLs for identity, ignoring incidental differences. """ - return (cls.normalize_url(url1) == cls.normalize_url(url2)) + return cls.normalize_url(url1) == cls.normalize_url(url2) - def fetch_new(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def fetch_new( + self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int + ) -> None: """ Fetch a revision from a repository, in the case that this is the first fetch from the repository. @@ -477,11 +473,11 @@ class VersionControl: Args: dest: the directory to fetch the repository to. rev_options: a RevOptions object. + verbosity: verbosity level. """ raise NotImplementedError - def switch(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: """ Switch the repo at ``dest`` to point to ``URL``. @@ -490,8 +486,7 @@ class VersionControl: """ raise NotImplementedError - def update(self, dest, url, rev_options): - # type: (str, HiddenText, RevOptions) -> None + def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None: """ Update an already-existing repo to the given ``rev_options``. @@ -501,8 +496,7 @@ class VersionControl: raise NotImplementedError @classmethod - def is_commit_id_equal(cls, dest, name): - # type: (str, Optional[str]) -> bool + def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool: """ Return whether the id of the current commit equals the given name. @@ -512,19 +506,19 @@ class VersionControl: """ raise NotImplementedError - def obtain(self, dest, url): - # type: (str, HiddenText) -> None + def obtain(self, dest: str, url: HiddenText, verbosity: int) -> None: """ Install or update in editable mode the package represented by this VersionControl object. :param dest: the repository directory in which to install or update. :param url: the repository URL starting with a vcs prefix. + :param verbosity: verbosity level. """ url, rev_options = self.get_url_rev_options(url) if not os.path.exists(dest): - self.fetch_new(dest, url, rev_options) + self.fetch_new(dest, url, rev_options, verbosity=verbosity) return rev_display = rev_options.to_display() @@ -532,73 +526,68 @@ class VersionControl: existing_url = self.get_remote_url(dest) if self.compare_urls(existing_url, url.secret): logger.debug( - '%s in %s exists, and has correct URL (%s)', + "%s in %s exists, and has correct URL (%s)", self.repo_name.title(), display_path(dest), url, ) if not self.is_commit_id_equal(dest, rev_options.rev): logger.info( - 'Updating %s %s%s', + "Updating %s %s%s", display_path(dest), self.repo_name, rev_display, ) self.update(dest, url, rev_options) else: - logger.info('Skipping because already up-to-date.') + logger.info("Skipping because already up-to-date.") return logger.warning( - '%s %s in %s exists with URL %s', + "%s %s in %s exists with URL %s", self.name, self.repo_name, display_path(dest), existing_url, ) - prompt = ('(s)witch, (i)gnore, (w)ipe, (b)ackup ', - ('s', 'i', 'w', 'b')) + prompt = ("(s)witch, (i)gnore, (w)ipe, (b)ackup ", ("s", "i", "w", "b")) else: logger.warning( - 'Directory %s already exists, and is not a %s %s.', + "Directory %s already exists, and is not a %s %s.", dest, self.name, self.repo_name, ) # https://github.com/python/mypy/issues/1174 - prompt = ('(i)gnore, (w)ipe, (b)ackup ', # type: ignore - ('i', 'w', 'b')) + prompt = ("(i)gnore, (w)ipe, (b)ackup ", ("i", "w", "b")) # type: ignore logger.warning( - 'The plan is to install the %s repository %s', + "The plan is to install the %s repository %s", self.name, url, ) - response = ask_path_exists('What to do? {}'.format( - prompt[0]), prompt[1]) + response = ask_path_exists("What to do? {}".format(prompt[0]), prompt[1]) - if response == 'a': + if response == "a": sys.exit(-1) - if response == 'w': - logger.warning('Deleting %s', display_path(dest)) + if response == "w": + logger.warning("Deleting %s", display_path(dest)) rmtree(dest) - self.fetch_new(dest, url, rev_options) + self.fetch_new(dest, url, rev_options, verbosity=verbosity) return - if response == 'b': + if response == "b": dest_dir = backup_dir(dest) - logger.warning( - 'Backing up %s to %s', display_path(dest), dest_dir, - ) + logger.warning("Backing up %s to %s", display_path(dest), dest_dir) shutil.move(dest, dest_dir) - self.fetch_new(dest, url, rev_options) + self.fetch_new(dest, url, rev_options, verbosity=verbosity) return # Do nothing if the response is "i". - if response == 's': + if response == "s": logger.info( - 'Switching %s %s to %s%s', + "Switching %s %s to %s%s", self.repo_name, display_path(dest), url, @@ -606,21 +595,20 @@ class VersionControl: ) self.switch(dest, url, rev_options) - def unpack(self, location, url): - # type: (str, HiddenText) -> None + def unpack(self, location: str, url: HiddenText, verbosity: int) -> None: """ Clean up current location and download the url repository (and vcs infos) into location :param url: the repository URL starting with a vcs prefix. + :param verbosity: verbosity level. """ if os.path.exists(location): rmtree(location) - self.obtain(location, url=url) + self.obtain(location, url=url, verbosity=verbosity) @classmethod - def get_remote_url(cls, location): - # type: (str) -> str + def get_remote_url(cls, location: str) -> str: """ Return the url used at location @@ -630,8 +618,7 @@ class VersionControl: raise NotImplementedError @classmethod - def get_revision(cls, location): - # type: (str) -> str + def get_revision(cls, location: str) -> str: """ Return the current commit id of the files at the given location. """ @@ -640,40 +627,46 @@ class VersionControl: @classmethod def run_command( cls, - cmd, # type: Union[List[str], CommandArgs] - show_stdout=True, # type: bool - cwd=None, # type: Optional[str] - on_returncode='raise', # type: str - extra_ok_returncodes=None, # type: Optional[Iterable[int]] - command_desc=None, # type: Optional[str] - extra_environ=None, # type: Optional[Mapping[str, Any]] - spinner=None, # type: Optional[SpinnerInterface] - log_failed_cmd=True, # type: bool - stdout_only=False, # type: bool - ): - # type: (...) -> str + cmd: Union[List[str], CommandArgs], + show_stdout: bool = True, + cwd: Optional[str] = None, + on_returncode: 'Literal["raise", "warn", "ignore"]' = "raise", + extra_ok_returncodes: Optional[Iterable[int]] = None, + command_desc: Optional[str] = None, + extra_environ: Optional[Mapping[str, Any]] = None, + spinner: Optional[SpinnerInterface] = None, + log_failed_cmd: bool = True, + stdout_only: bool = False, + ) -> str: """ Run a VCS subcommand This is simply a wrapper around call_subprocess that adds the VCS command name, and checks that the VCS is available """ cmd = make_command(cls.name, *cmd) + if command_desc is None: + command_desc = format_command_args(cmd) try: - return call_subprocess(cmd, show_stdout, cwd, - on_returncode=on_returncode, - extra_ok_returncodes=extra_ok_returncodes, - command_desc=command_desc, - extra_environ=extra_environ, - unset_environ=cls.unset_environ, - spinner=spinner, - log_failed_cmd=log_failed_cmd, - stdout_only=stdout_only) + return call_subprocess( + cmd, + show_stdout, + cwd, + on_returncode=on_returncode, + extra_ok_returncodes=extra_ok_returncodes, + command_desc=command_desc, + extra_environ=extra_environ, + unset_environ=cls.unset_environ, + spinner=spinner, + log_failed_cmd=log_failed_cmd, + stdout_only=stdout_only, + ) except FileNotFoundError: # errno.ENOENT = no such file or directory # In other words, the VCS executable isn't available raise BadCommand( - f'Cannot find command {cls.name!r} - do you have ' - f'{cls.name!r} installed and in your PATH?') + f"Cannot find command {cls.name!r} - do you have " + f"{cls.name!r} installed and in your PATH?" + ) except PermissionError: # errno.EACCES = Permission denied # This error occurs, for instance, when the command is installed @@ -688,18 +681,15 @@ class VersionControl: ) @classmethod - def is_repository_directory(cls, path): - # type: (str) -> bool + def is_repository_directory(cls, path: str) -> bool: """ Return whether a directory path is a repository directory. """ - logger.debug('Checking in %s for %s (%s)...', - path, cls.dirname, cls.name) + logger.debug("Checking in %s for %s (%s)...", path, cls.dirname, cls.name) return os.path.exists(os.path.join(path, cls.dirname)) @classmethod - def get_repository_root(cls, location): - # type: (str) -> Optional[str] + def get_repository_root(cls, location: str) -> Optional[str]: """ Return the "root" (top-level) directory controlled by the vcs, or `None` if the directory is not in any. diff --git a/env/Lib/site-packages/pip/_internal/wheel_builder.py b/env/Lib/site-packages/pip/_internal/wheel_builder.py index 92f172bc..60d75dd1 100644 --- a/env/Lib/site-packages/pip/_internal/wheel_builder.py +++ b/env/Lib/site-packages/pip/_internal/wheel_builder.py @@ -5,21 +5,22 @@ import logging import os.path import re import shutil -from typing import Any, Callable, Iterable, List, Optional, Tuple +from typing import Iterable, List, Optional, Tuple from pip._vendor.packaging.utils import canonicalize_name, canonicalize_version from pip._vendor.packaging.version import InvalidVersion, Version from pip._internal.cache import WheelCache from pip._internal.exceptions import InvalidWheelFilename, UnsupportedWheel -from pip._internal.metadata import get_wheel_distribution +from pip._internal.metadata import FilesystemWheel, get_wheel_distribution from pip._internal.models.link import Link from pip._internal.models.wheel import Wheel from pip._internal.operations.build.wheel import build_wheel_pep517 +from pip._internal.operations.build.wheel_editable import build_wheel_editable from pip._internal.operations.build.wheel_legacy import build_wheel_legacy from pip._internal.req.req_install import InstallRequirement from pip._internal.utils.logging import indent_log -from pip._internal.utils.misc import ensure_dir, hash_file, is_wheel_installed +from pip._internal.utils.misc import ensure_dir, hash_file from pip._internal.utils.setuptools_build import make_setuptools_clean_args from pip._internal.utils.subprocess import call_subprocess from pip._internal.utils.temp_dir import TempDirectory @@ -28,14 +29,12 @@ from pip._internal.vcs import vcs logger = logging.getLogger(__name__) -_egg_info_re = re.compile(r'([a-z0-9_.]+)-([a-z0-9_.!+-]+)', re.IGNORECASE) +_egg_info_re = re.compile(r"([a-z0-9_.]+)-([a-z0-9_.!+-]+)", re.IGNORECASE) -BinaryAllowedPredicate = Callable[[InstallRequirement], bool] BuildResult = Tuple[List[InstallRequirement], List[InstallRequirement]] -def _contains_egg_info(s): - # type: (str) -> bool +def _contains_egg_info(s: str) -> bool: """Determine whether the string looks like an egg_info. :param s: The string to parse. E.g. foo-2.1 @@ -44,11 +43,9 @@ def _contains_egg_info(s): def _should_build( - req, # type: InstallRequirement - need_wheel, # type: bool - check_binary_allowed, # type: BinaryAllowedPredicate -): - # type: (...) -> bool + req: InstallRequirement, + need_wheel: bool, +) -> bool: """Return whether an InstallRequirement should be built into a wheel.""" if req.constraint: # never build requirements that are merely constraints @@ -56,7 +53,8 @@ def _should_build( if req.is_wheel: if need_wheel: logger.info( - 'Skipping %s, due to already being wheel.', req.name, + "Skipping %s, due to already being wheel.", + req.name, ) return False @@ -67,53 +65,31 @@ def _should_build( # From this point, this concerns the pip install command only # (need_wheel=False). - if req.editable or not req.source_dir: - return False - - if req.use_pep517: - return True - - if not check_binary_allowed(req): - logger.info( - "Skipping wheel build for %s, due to binaries " - "being disabled for it.", req.name, - ) + if not req.source_dir: return False - if not is_wheel_installed(): - # we don't build legacy requirements if wheel is not installed - logger.info( - "Using legacy 'setup.py install' for %s, " - "since package 'wheel' is not installed.", req.name, - ) - return False + if req.editable: + # we only build PEP 660 editable requirements + return req.supports_pyproject_editable() return True def should_build_for_wheel_command( - req, # type: InstallRequirement -): - # type: (...) -> bool - return _should_build( - req, need_wheel=True, check_binary_allowed=_always_true - ) + req: InstallRequirement, +) -> bool: + return _should_build(req, need_wheel=True) def should_build_for_install_command( - req, # type: InstallRequirement - check_binary_allowed, # type: BinaryAllowedPredicate -): - # type: (...) -> bool - return _should_build( - req, need_wheel=False, check_binary_allowed=check_binary_allowed - ) + req: InstallRequirement, +) -> bool: + return _should_build(req, need_wheel=False) def _should_cache( - req, # type: InstallRequirement -): - # type: (...) -> Optional[bool] + req: InstallRequirement, +) -> Optional[bool]: """ Return whether a built InstallRequirement can be stored in the persistent wheel cache, assuming the wheel cache is available, and _should_build() @@ -144,10 +120,9 @@ def _should_cache( def _get_cache_dir( - req, # type: InstallRequirement - wheel_cache, # type: WheelCache -): - # type: (...) -> str + req: InstallRequirement, + wheel_cache: WheelCache, +) -> str: """Return the persistent or temporary cache directory where the built wheel need to be stored. """ @@ -160,13 +135,7 @@ def _get_cache_dir( return cache_dir -def _always_true(_): - # type: (Any) -> bool - return True - - -def _verify_one(req, wheel_path): - # type: (InstallRequirement, str) -> None +def _verify_one(req: InstallRequirement, wheel_path: str) -> None: canonical_name = canonicalize_name(req.name or "") w = Wheel(os.path.basename(wheel_path)) if canonicalize_name(w.name) != canonical_name: @@ -174,7 +143,7 @@ def _verify_one(req, wheel_path): "Wheel has unexpected file name: expected {!r}, " "got {!r}".format(canonical_name, w.name), ) - dist = get_wheel_distribution(wheel_path, canonical_name) + dist = get_wheel_distribution(FilesystemWheel(wheel_path), canonical_name) dist_verstr = str(dist.version) if canonicalize_version(dist_verstr) != canonicalize_version(w.version): raise InvalidWheelFilename( @@ -189,8 +158,7 @@ def _verify_one(req, wheel_path): except InvalidVersion: msg = f"Invalid Metadata-Version: {metadata_version_value}" raise UnsupportedWheel(msg) - if (metadata_version >= Version("1.2") - and not isinstance(dist.version, Version)): + if metadata_version >= Version("1.2") and not isinstance(dist.version, Version): raise UnsupportedWheel( "Metadata 1.2 mandates PEP 440 version, " "but {!r} is not".format(dist_verstr) @@ -198,47 +166,50 @@ def _verify_one(req, wheel_path): def _build_one( - req, # type: InstallRequirement - output_dir, # type: str - verify, # type: bool - build_options, # type: List[str] - global_options, # type: List[str] -): - # type: (...) -> Optional[str] + req: InstallRequirement, + output_dir: str, + verify: bool, + build_options: List[str], + global_options: List[str], + editable: bool, +) -> Optional[str]: """Build one wheel. :return: The filename of the built wheel, or None if the build failed. """ + artifact = "editable" if editable else "wheel" try: ensure_dir(output_dir) except OSError as e: logger.warning( - "Building wheel for %s failed: %s", - req.name, e, + "Building %s for %s failed: %s", + artifact, + req.name, + e, ) return None # Install build deps into temporary directory (PEP 518) with req.build_env: wheel_path = _build_one_inside_env( - req, output_dir, build_options, global_options + req, output_dir, build_options, global_options, editable ) if wheel_path and verify: try: _verify_one(req, wheel_path) except (InvalidWheelFilename, UnsupportedWheel) as e: - logger.warning("Built wheel for %s is invalid: %s", req.name, e) + logger.warning("Built %s for %s is invalid: %s", artifact, req.name, e) return None return wheel_path def _build_one_inside_env( - req, # type: InstallRequirement - output_dir, # type: str - build_options, # type: List[str] - global_options, # type: List[str] -): - # type: (...) -> Optional[str] + req: InstallRequirement, + output_dir: str, + build_options: List[str], + global_options: List[str], + editable: bool, +) -> Optional[str]: with TempDirectory(kind="wheel") as temp_dir: assert req.name if req.use_pep517: @@ -246,18 +217,26 @@ def _build_one_inside_env( assert req.pep517_backend if global_options: logger.warning( - 'Ignoring --global-option when building %s using PEP 517', req.name + "Ignoring --global-option when building %s using PEP 517", req.name ) if build_options: logger.warning( - 'Ignoring --build-option when building %s using PEP 517', req.name + "Ignoring --build-option when building %s using PEP 517", req.name + ) + if editable: + wheel_path = build_wheel_editable( + name=req.name, + backend=req.pep517_backend, + metadata_directory=req.metadata_directory, + tempd=temp_dir.path, + ) + else: + wheel_path = build_wheel_pep517( + name=req.name, + backend=req.pep517_backend, + metadata_directory=req.metadata_directory, + tempd=temp_dir.path, ) - wheel_path = build_wheel_pep517( - name=req.name, - backend=req.pep517_backend, - metadata_directory=req.metadata_directory, - tempd=temp_dir.path, - ) else: wheel_path = build_wheel_legacy( name=req.name, @@ -274,16 +253,20 @@ def _build_one_inside_env( try: wheel_hash, length = hash_file(wheel_path) shutil.move(wheel_path, dest_path) - logger.info('Created wheel for %s: ' - 'filename=%s size=%d sha256=%s', - req.name, wheel_name, length, - wheel_hash.hexdigest()) - logger.info('Stored in directory: %s', output_dir) + logger.info( + "Created wheel for %s: filename=%s size=%d sha256=%s", + req.name, + wheel_name, + length, + wheel_hash.hexdigest(), + ) + logger.info("Stored in directory: %s", output_dir) return dest_path except Exception as e: logger.warning( "Building wheel for %s failed: %s", - req.name, e, + req.name, + e, ) # Ignore return, we can't do anything else useful. if not req.use_pep517: @@ -291,30 +274,30 @@ def _build_one_inside_env( return None -def _clean_one_legacy(req, global_options): - # type: (InstallRequirement, List[str]) -> bool +def _clean_one_legacy(req: InstallRequirement, global_options: List[str]) -> bool: clean_args = make_setuptools_clean_args( req.setup_py_path, global_options=global_options, ) - logger.info('Running setup.py clean for %s', req.name) + logger.info("Running setup.py clean for %s", req.name) try: - call_subprocess(clean_args, cwd=req.source_dir) + call_subprocess( + clean_args, command_desc="python setup.py clean", cwd=req.source_dir + ) return True except Exception: - logger.error('Failed cleaning build dir for %s', req.name) + logger.error("Failed cleaning build dir for %s", req.name) return False def build( - requirements, # type: Iterable[InstallRequirement] - wheel_cache, # type: WheelCache - verify, # type: bool - build_options, # type: List[str] - global_options, # type: List[str] -): - # type: (...) -> BuildResult + requirements: Iterable[InstallRequirement], + wheel_cache: WheelCache, + verify: bool, + build_options: List[str], + global_options: List[str], +) -> BuildResult: """Build wheels. :return: The list of InstallRequirement that succeeded to build and @@ -325,18 +308,30 @@ def build( # Build the wheels. logger.info( - 'Building wheels for collected packages: %s', - ', '.join(req.name for req in requirements), # type: ignore + "Building wheels for collected packages: %s", + ", ".join(req.name for req in requirements), # type: ignore ) with indent_log(): build_successes, build_failures = [], [] for req in requirements: + assert req.name cache_dir = _get_cache_dir(req, wheel_cache) wheel_file = _build_one( - req, cache_dir, verify, build_options, global_options + req, + cache_dir, + verify, + build_options, + global_options, + req.editable and req.permit_editable_wheels, ) if wheel_file: + # Record the download origin in the cache + if req.download_info is not None: + # download_info is guaranteed to be set because when we build an + # InstallRequirement it has been through the preparer before, but + # let's be cautious. + wheel_cache.record_download_origin(cache_dir, req.download_info) # Update the link for this. req.link = Link(path_to_url(wheel_file)) req.local_file_path = req.link.file_path @@ -348,13 +343,13 @@ def build( # notify success/failure if build_successes: logger.info( - 'Successfully built %s', - ' '.join([req.name for req in build_successes]), # type: ignore + "Successfully built %s", + " ".join([req.name for req in build_successes]), # type: ignore ) if build_failures: logger.info( - 'Failed to build %s', - ' '.join([req.name for req in build_failures]), # type: ignore + "Failed to build %s", + " ".join([req.name for req in build_failures]), # type: ignore ) # Return a list of requirements that failed to build return build_successes, build_failures diff --git a/env/Lib/site-packages/pip/_vendor/__init__.py b/env/Lib/site-packages/pip/_vendor/__init__.py index a10ecd60..b22f7abb 100644 --- a/env/Lib/site-packages/pip/_vendor/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/__init__.py @@ -58,13 +58,11 @@ if DEBUNDLED: sys.path[:] = glob.glob(os.path.join(WHEEL_DIR, "*.whl")) + sys.path # Actually alias all of our vendored dependencies. - vendored("appdirs") vendored("cachecontrol") vendored("certifi") vendored("colorama") vendored("distlib") vendored("distro") - vendored("html5lib") vendored("six") vendored("six.moves") vendored("six.moves.urllib") @@ -74,6 +72,7 @@ if DEBUNDLED: vendored("packaging.specifiers") vendored("pep517") vendored("pkg_resources") + vendored("platformdirs") vendored("progress") vendored("requests") vendored("requests.exceptions") @@ -106,8 +105,16 @@ if DEBUNDLED: vendored("requests.packages.urllib3.util.timeout") vendored("requests.packages.urllib3.util.url") vendored("resolvelib") + vendored("rich") + vendored("rich.console") + vendored("rich.highlighter") + vendored("rich.logging") + vendored("rich.markup") + vendored("rich.progress") + vendored("rich.segment") + vendored("rich.style") + vendored("rich.text") + vendored("rich.traceback") vendored("tenacity") - vendored("toml") - vendored("toml.encoder") - vendored("toml.decoder") + vendored("tomli") vendored("urllib3") diff --git a/env/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 44980fc6fc07a83d803c9c2c8f445fbf0a9293fb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2974 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 diff --git a/env/Lib/site-packages/pip/_vendor/__pycache__/appdirs.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/__pycache__/appdirs.cpython-39.pyc deleted file mode 100644 index 56bdeee96913eee10207643cdb43c03408645567..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21427 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 E04j}20{{R3 diff --git a/env/Lib/site-packages/pip/_vendor/__pycache__/distro.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/__pycache__/distro.cpython-39.pyc deleted file mode 100644 index 7a4216e49825f65191a088d7d1e2bd48755d1cea..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 36906 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 KY|I?uT#NwYlpyc` diff --git a/env/Lib/site-packages/pip/_vendor/__pycache__/pyparsing.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/__pycache__/pyparsing.cpython-39.pyc deleted file mode 100644 index a88fe70a195b513e28b7a7a0cec5f1e40fe85bb9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 240463 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 N65<qM<zbXy1ONcGO?LnQ diff --git a/env/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-39.pyc deleted file mode 100644 index fb7259e9dd481e461f0478555689e5f713599bca..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26973 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 diff --git a/env/Lib/site-packages/pip/_vendor/appdirs.py b/env/Lib/site-packages/pip/_vendor/appdirs.py deleted file mode 100644 index 33a3b774..00000000 --- a/env/Lib/site-packages/pip/_vendor/appdirs.py +++ /dev/null @@ -1,633 +0,0 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- -# Copyright (c) 2005-2010 ActiveState Software Inc. -# Copyright (c) 2013 Eddy Petrișor - -"""Utilities for determining application-specific dirs. - -See <http://github.com/ActiveState/appdirs> for details and usage. -""" -# Dev Notes: -# - MSDN on where to store app data files: -# http://support.microsoft.com/default.aspx?scid=kb;en-us;310294#XSLTH3194121123120121120120 -# - Mac OS X: http://developer.apple.com/documentation/MacOSX/Conceptual/BPFileSystem/index.html -# - XDG spec for Un*x: http://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html - -__version__ = "1.4.4" -__version_info__ = tuple(int(segment) for segment in __version__.split(".")) - - -import sys -import os - -PY3 = sys.version_info[0] == 3 - -if PY3: - unicode = str - -if sys.platform.startswith('java'): - import platform - os_name = platform.java_ver()[3][0] - if os_name.startswith('Windows'): # "Windows XP", "Windows 7", etc. - system = 'win32' - elif os_name.startswith('Mac'): # "Mac OS X", etc. - system = 'darwin' - else: # "Linux", "SunOS", "FreeBSD", etc. - # Setting this to "linux2" is not ideal, but only Windows or Mac - # are actually checked for and the rest of the module expects - # *sys.platform* style strings. - system = 'linux2' -elif sys.platform == 'cli' and os.name == 'nt': - # Detect Windows in IronPython to match pip._internal.utils.compat.WINDOWS - # Discussion: <https://github.com/pypa/pip/pull/7501> - system = 'win32' -else: - system = sys.platform - - - -def user_data_dir(appname=None, appauthor=None, version=None, roaming=False): - r"""Return full path to the user-specific data dir for this application. - - "appname" is the name of application. - If None, just the system directory is returned. - "appauthor" (only used on Windows) is the name of the - appauthor or distributing body for this application. Typically - it is the owning company name. This falls back to appname. You may - pass False to disable it. - "version" is an optional version path element to append to the - path. You might want to use this if you want multiple versions - of your app to be able to run independently. If used, this - would typically be "<major>.<minor>". - Only applied when appname is present. - "roaming" (boolean, default False) can be set True to use the Windows - roaming appdata directory. That means that for users on a Windows - network setup for roaming profiles, this user data will be - sync'd on login. See - <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx> - for a discussion of issues. - - Typical user data directories are: - Mac OS X: ~/Library/Application Support/<AppName> # or ~/.config/<AppName>, if the other does not exist - Unix: ~/.local/share/<AppName> # or in $XDG_DATA_HOME, if defined - Win XP (not roaming): C:\Documents and Settings\<username>\Application Data\<AppAuthor>\<AppName> - Win XP (roaming): C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName> - Win 7 (not roaming): C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName> - Win 7 (roaming): C:\Users\<username>\AppData\Roaming\<AppAuthor>\<AppName> - - For Unix, we follow the XDG spec and support $XDG_DATA_HOME. - That means, by default "~/.local/share/<AppName>". - """ - if system == "win32": - if appauthor is None: - appauthor = appname - const = roaming and "CSIDL_APPDATA" or "CSIDL_LOCAL_APPDATA" - path = os.path.normpath(_get_win_folder(const)) - if appname: - if appauthor is not False: - path = os.path.join(path, appauthor, appname) - else: - path = os.path.join(path, appname) - elif system == 'darwin': - path = os.path.expanduser('~/Library/Application Support/') - if appname: - path = os.path.join(path, appname) - else: - path = os.getenv('XDG_DATA_HOME', os.path.expanduser("~/.local/share")) - if appname: - path = os.path.join(path, appname) - if appname and version: - path = os.path.join(path, version) - return path - - -def site_data_dir(appname=None, appauthor=None, version=None, multipath=False): - r"""Return full path to the user-shared data dir for this application. - - "appname" is the name of application. - If None, just the system directory is returned. - "appauthor" (only used on Windows) is the name of the - appauthor or distributing body for this application. Typically - it is the owning company name. This falls back to appname. You may - pass False to disable it. - "version" is an optional version path element to append to the - path. You might want to use this if you want multiple versions - of your app to be able to run independently. If used, this - would typically be "<major>.<minor>". - Only applied when appname is present. - "multipath" is an optional parameter only applicable to *nix - which indicates that the entire list of data dirs should be - returned. By default, the first item from XDG_DATA_DIRS is - returned, or '/usr/local/share/<AppName>', - if XDG_DATA_DIRS is not set - - Typical site data directories are: - Mac OS X: /Library/Application Support/<AppName> - Unix: /usr/local/share/<AppName> or /usr/share/<AppName> - Win XP: C:\Documents and Settings\All Users\Application Data\<AppAuthor>\<AppName> - Vista: (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.) - Win 7: C:\ProgramData\<AppAuthor>\<AppName> # Hidden, but writeable on Win 7. - - For Unix, this is using the $XDG_DATA_DIRS[0] default. - - WARNING: Do not use this on Windows. See the Vista-Fail note above for why. - """ - if system == "win32": - if appauthor is None: - appauthor = appname - path = os.path.normpath(_get_win_folder("CSIDL_COMMON_APPDATA")) - if appname: - if appauthor is not False: - path = os.path.join(path, appauthor, appname) - else: - path = os.path.join(path, appname) - elif system == 'darwin': - path = os.path.expanduser('/Library/Application Support') - if appname: - path = os.path.join(path, appname) - else: - # XDG default for $XDG_DATA_DIRS - # only first, if multipath is False - path = os.getenv('XDG_DATA_DIRS', - os.pathsep.join(['/usr/local/share', '/usr/share'])) - pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep)] - if appname: - if version: - appname = os.path.join(appname, version) - pathlist = [os.path.join(x, appname) for x in pathlist] - - if multipath: - path = os.pathsep.join(pathlist) - else: - path = pathlist[0] - return path - - if appname and version: - path = os.path.join(path, version) - return path - - -def user_config_dir(appname=None, appauthor=None, version=None, roaming=False): - r"""Return full path to the user-specific config dir for this application. - - "appname" is the name of application. - If None, just the system directory is returned. - "appauthor" (only used on Windows) is the name of the - appauthor or distributing body for this application. Typically - it is the owning company name. This falls back to appname. You may - pass False to disable it. - "version" is an optional version path element to append to the - path. You might want to use this if you want multiple versions - of your app to be able to run independently. If used, this - would typically be "<major>.<minor>". - Only applied when appname is present. - "roaming" (boolean, default False) can be set True to use the Windows - roaming appdata directory. That means that for users on a Windows - network setup for roaming profiles, this user data will be - sync'd on login. See - <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx> - for a discussion of issues. - - Typical user config directories are: - Mac OS X: same as user_data_dir - Unix: ~/.config/<AppName> # or in $XDG_CONFIG_HOME, if defined - Win *: same as user_data_dir - - For Unix, we follow the XDG spec and support $XDG_CONFIG_HOME. - That means, by default "~/.config/<AppName>". - """ - if system in ["win32", "darwin"]: - path = user_data_dir(appname, appauthor, None, roaming) - else: - path = os.getenv('XDG_CONFIG_HOME', os.path.expanduser("~/.config")) - if appname: - path = os.path.join(path, appname) - if appname and version: - path = os.path.join(path, version) - return path - - -# for the discussion regarding site_config_dir locations -# see <https://github.com/pypa/pip/issues/1733> -def site_config_dir(appname=None, appauthor=None, version=None, multipath=False): - r"""Return full path to the user-shared data dir for this application. - - "appname" is the name of application. - If None, just the system directory is returned. - "appauthor" (only used on Windows) is the name of the - appauthor or distributing body for this application. Typically - it is the owning company name. This falls back to appname. You may - pass False to disable it. - "version" is an optional version path element to append to the - path. You might want to use this if you want multiple versions - of your app to be able to run independently. If used, this - would typically be "<major>.<minor>". - Only applied when appname is present. - "multipath" is an optional parameter only applicable to *nix - which indicates that the entire list of config dirs should be - returned. By default, the first item from XDG_CONFIG_DIRS is - returned, or '/etc/xdg/<AppName>', if XDG_CONFIG_DIRS is not set - - Typical site config directories are: - Mac OS X: same as site_data_dir - Unix: /etc/xdg/<AppName> or $XDG_CONFIG_DIRS[i]/<AppName> for each value in - $XDG_CONFIG_DIRS - Win *: same as site_data_dir - Vista: (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.) - - For Unix, this is using the $XDG_CONFIG_DIRS[0] default, if multipath=False - - WARNING: Do not use this on Windows. See the Vista-Fail note above for why. - """ - if system in ["win32", "darwin"]: - path = site_data_dir(appname, appauthor) - if appname and version: - path = os.path.join(path, version) - else: - # XDG default for $XDG_CONFIG_DIRS (missing or empty) - # see <https://github.com/pypa/pip/pull/7501#discussion_r360624829> - # only first, if multipath is False - path = os.getenv('XDG_CONFIG_DIRS') or '/etc/xdg' - pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep) if x] - if appname: - if version: - appname = os.path.join(appname, version) - pathlist = [os.path.join(x, appname) for x in pathlist] - - if multipath: - path = os.pathsep.join(pathlist) - else: - path = pathlist[0] - return path - - -def user_cache_dir(appname=None, appauthor=None, version=None, opinion=True): - r"""Return full path to the user-specific cache dir for this application. - - "appname" is the name of application. - If None, just the system directory is returned. - "appauthor" (only used on Windows) is the name of the - appauthor or distributing body for this application. Typically - it is the owning company name. This falls back to appname. You may - pass False to disable it. - "version" is an optional version path element to append to the - path. You might want to use this if you want multiple versions - of your app to be able to run independently. If used, this - would typically be "<major>.<minor>". - Only applied when appname is present. - "opinion" (boolean) can be False to disable the appending of - "Cache" to the base app data dir for Windows. See - discussion below. - - Typical user cache directories are: - Mac OS X: ~/Library/Caches/<AppName> - Unix: ~/.cache/<AppName> (XDG default) - Win XP: C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName>\Cache - Vista: C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName>\Cache - - On Windows the only suggestion in the MSDN docs is that local settings go in - the `CSIDL_LOCAL_APPDATA` directory. This is identical to the non-roaming - app data dir (the default returned by `user_data_dir` above). Apps typically - put cache data somewhere *under* the given dir here. Some examples: - ...\Mozilla\Firefox\Profiles\<ProfileName>\Cache - ...\Acme\SuperApp\Cache\1.0 - OPINION: This function appends "Cache" to the `CSIDL_LOCAL_APPDATA` value. - This can be disabled with the `opinion=False` option. - """ - if system == "win32": - if appauthor is None: - appauthor = appname - path = os.path.normpath(_get_win_folder("CSIDL_LOCAL_APPDATA")) - # When using Python 2, return paths as bytes on Windows like we do on - # other operating systems. See helper function docs for more details. - if not PY3 and isinstance(path, unicode): - path = _win_path_to_bytes(path) - if appname: - if appauthor is not False: - path = os.path.join(path, appauthor, appname) - else: - path = os.path.join(path, appname) - if opinion: - path = os.path.join(path, "Cache") - elif system == 'darwin': - path = os.path.expanduser('~/Library/Caches') - if appname: - path = os.path.join(path, appname) - else: - path = os.getenv('XDG_CACHE_HOME', os.path.expanduser('~/.cache')) - if appname: - path = os.path.join(path, appname) - if appname and version: - path = os.path.join(path, version) - return path - - -def user_state_dir(appname=None, appauthor=None, version=None, roaming=False): - r"""Return full path to the user-specific state dir for this application. - - "appname" is the name of application. - If None, just the system directory is returned. - "appauthor" (only used on Windows) is the name of the - appauthor or distributing body for this application. Typically - it is the owning company name. This falls back to appname. You may - pass False to disable it. - "version" is an optional version path element to append to the - path. You might want to use this if you want multiple versions - of your app to be able to run independently. If used, this - would typically be "<major>.<minor>". - Only applied when appname is present. - "roaming" (boolean, default False) can be set True to use the Windows - roaming appdata directory. That means that for users on a Windows - network setup for roaming profiles, this user data will be - sync'd on login. See - <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx> - for a discussion of issues. - - Typical user state directories are: - Mac OS X: same as user_data_dir - Unix: ~/.local/state/<AppName> # or in $XDG_STATE_HOME, if defined - Win *: same as user_data_dir - - For Unix, we follow this Debian proposal <https://wiki.debian.org/XDGBaseDirectorySpecification#state> - to extend the XDG spec and support $XDG_STATE_HOME. - - That means, by default "~/.local/state/<AppName>". - """ - if system in ["win32", "darwin"]: - path = user_data_dir(appname, appauthor, None, roaming) - else: - path = os.getenv('XDG_STATE_HOME', os.path.expanduser("~/.local/state")) - if appname: - path = os.path.join(path, appname) - if appname and version: - path = os.path.join(path, version) - return path - - -def user_log_dir(appname=None, appauthor=None, version=None, opinion=True): - r"""Return full path to the user-specific log dir for this application. - - "appname" is the name of application. - If None, just the system directory is returned. - "appauthor" (only used on Windows) is the name of the - appauthor or distributing body for this application. Typically - it is the owning company name. This falls back to appname. You may - pass False to disable it. - "version" is an optional version path element to append to the - path. You might want to use this if you want multiple versions - of your app to be able to run independently. If used, this - would typically be "<major>.<minor>". - Only applied when appname is present. - "opinion" (boolean) can be False to disable the appending of - "Logs" to the base app data dir for Windows, and "log" to the - base cache dir for Unix. See discussion below. - - Typical user log directories are: - Mac OS X: ~/Library/Logs/<AppName> - Unix: ~/.cache/<AppName>/log # or under $XDG_CACHE_HOME if defined - Win XP: C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName>\Logs - Vista: C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName>\Logs - - On Windows the only suggestion in the MSDN docs is that local settings - go in the `CSIDL_LOCAL_APPDATA` directory. (Note: I'm interested in - examples of what some windows apps use for a logs dir.) - - OPINION: This function appends "Logs" to the `CSIDL_LOCAL_APPDATA` - value for Windows and appends "log" to the user cache dir for Unix. - This can be disabled with the `opinion=False` option. - """ - if system == "darwin": - path = os.path.join( - os.path.expanduser('~/Library/Logs'), - appname) - elif system == "win32": - path = user_data_dir(appname, appauthor, version) - version = False - if opinion: - path = os.path.join(path, "Logs") - else: - path = user_cache_dir(appname, appauthor, version) - version = False - if opinion: - path = os.path.join(path, "log") - if appname and version: - path = os.path.join(path, version) - return path - - -class AppDirs(object): - """Convenience wrapper for getting application dirs.""" - def __init__(self, appname=None, appauthor=None, version=None, - roaming=False, multipath=False): - self.appname = appname - self.appauthor = appauthor - self.version = version - self.roaming = roaming - self.multipath = multipath - - @property - def user_data_dir(self): - return user_data_dir(self.appname, self.appauthor, - version=self.version, roaming=self.roaming) - - @property - def site_data_dir(self): - return site_data_dir(self.appname, self.appauthor, - version=self.version, multipath=self.multipath) - - @property - def user_config_dir(self): - return user_config_dir(self.appname, self.appauthor, - version=self.version, roaming=self.roaming) - - @property - def site_config_dir(self): - return site_config_dir(self.appname, self.appauthor, - version=self.version, multipath=self.multipath) - - @property - def user_cache_dir(self): - return user_cache_dir(self.appname, self.appauthor, - version=self.version) - - @property - def user_state_dir(self): - return user_state_dir(self.appname, self.appauthor, - version=self.version) - - @property - def user_log_dir(self): - return user_log_dir(self.appname, self.appauthor, - version=self.version) - - -#---- internal support stuff - -def _get_win_folder_from_registry(csidl_name): - """This is a fallback technique at best. I'm not sure if using the - registry for this guarantees us the correct answer for all CSIDL_* - names. - """ - if PY3: - import winreg as _winreg - else: - import _winreg - - shell_folder_name = { - "CSIDL_APPDATA": "AppData", - "CSIDL_COMMON_APPDATA": "Common AppData", - "CSIDL_LOCAL_APPDATA": "Local AppData", - }[csidl_name] - - key = _winreg.OpenKey( - _winreg.HKEY_CURRENT_USER, - r"Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders" - ) - dir, type = _winreg.QueryValueEx(key, shell_folder_name) - return dir - - -def _get_win_folder_with_pywin32(csidl_name): - from win32com.shell import shellcon, shell - dir = shell.SHGetFolderPath(0, getattr(shellcon, csidl_name), 0, 0) - # Try to make this a unicode path because SHGetFolderPath does - # not return unicode strings when there is unicode data in the - # path. - try: - dir = unicode(dir) - - # Downgrade to short path name if have highbit chars. See - # <http://bugs.activestate.com/show_bug.cgi?id=85099>. - has_high_char = False - for c in dir: - if ord(c) > 255: - has_high_char = True - break - if has_high_char: - try: - import win32api - dir = win32api.GetShortPathName(dir) - except ImportError: - pass - except UnicodeError: - pass - return dir - - -def _get_win_folder_with_ctypes(csidl_name): - import ctypes - - csidl_const = { - "CSIDL_APPDATA": 26, - "CSIDL_COMMON_APPDATA": 35, - "CSIDL_LOCAL_APPDATA": 28, - }[csidl_name] - - buf = ctypes.create_unicode_buffer(1024) - ctypes.windll.shell32.SHGetFolderPathW(None, csidl_const, None, 0, buf) - - # Downgrade to short path name if have highbit chars. See - # <http://bugs.activestate.com/show_bug.cgi?id=85099>. - has_high_char = False - for c in buf: - if ord(c) > 255: - has_high_char = True - break - if has_high_char: - buf2 = ctypes.create_unicode_buffer(1024) - if ctypes.windll.kernel32.GetShortPathNameW(buf.value, buf2, 1024): - buf = buf2 - - return buf.value - -def _get_win_folder_with_jna(csidl_name): - import array - from com.sun import jna - from com.sun.jna.platform import win32 - - buf_size = win32.WinDef.MAX_PATH * 2 - buf = array.zeros('c', buf_size) - shell = win32.Shell32.INSTANCE - shell.SHGetFolderPath(None, getattr(win32.ShlObj, csidl_name), None, win32.ShlObj.SHGFP_TYPE_CURRENT, buf) - dir = jna.Native.toString(buf.tostring()).rstrip("\0") - - # Downgrade to short path name if have highbit chars. See - # <http://bugs.activestate.com/show_bug.cgi?id=85099>. - has_high_char = False - for c in dir: - if ord(c) > 255: - has_high_char = True - break - if has_high_char: - buf = array.zeros('c', buf_size) - kernel = win32.Kernel32.INSTANCE - if kernel.GetShortPathName(dir, buf, buf_size): - dir = jna.Native.toString(buf.tostring()).rstrip("\0") - - return dir - -if system == "win32": - try: - from ctypes import windll - _get_win_folder = _get_win_folder_with_ctypes - except ImportError: - try: - import com.sun.jna - _get_win_folder = _get_win_folder_with_jna - except ImportError: - _get_win_folder = _get_win_folder_from_registry - - -def _win_path_to_bytes(path): - """Encode Windows paths to bytes. Only used on Python 2. - - Motivation is to be consistent with other operating systems where paths - are also returned as bytes. This avoids problems mixing bytes and Unicode - elsewhere in the codebase. For more details and discussion see - <https://github.com/pypa/pip/issues/3463>. - - If encoding using ASCII and MBCS fails, return the original Unicode path. - """ - for encoding in ('ASCII', 'MBCS'): - try: - return path.encode(encoding) - except (UnicodeEncodeError, LookupError): - pass - return path - - -#---- self test code - -if __name__ == "__main__": - appname = "MyApp" - appauthor = "MyCompany" - - props = ("user_data_dir", - "user_config_dir", - "user_cache_dir", - "user_state_dir", - "user_log_dir", - "site_data_dir", - "site_config_dir") - - print("-- app dirs %s --" % __version__) - - print("-- app dirs (with optional 'version')") - dirs = AppDirs(appname, appauthor, version="1.0") - for prop in props: - print("%s: %s" % (prop, getattr(dirs, prop))) - - print("\n-- app dirs (without optional 'version')") - dirs = AppDirs(appname, appauthor) - for prop in props: - print("%s: %s" % (prop, getattr(dirs, prop))) - - print("\n-- app dirs (without optional 'appauthor')") - dirs = AppDirs(appname) - for prop in props: - print("%s: %s" % (prop, getattr(dirs, prop))) - - print("\n-- app dirs (with disabled 'appauthor')") - dirs = AppDirs(appname, appauthor=False) - for prop in props: - print("%s: %s" % (prop, getattr(dirs, prop))) diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py index a1bbbbe3..f631ae6d 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py @@ -1,11 +1,18 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + """CacheControl import Interface. Make it easy to import from cachecontrol without long namespaces. """ __author__ = "Eric Larson" __email__ = "eric@ionrock.org" -__version__ = "0.12.6" +__version__ = "0.12.11" from .wrapper import CacheControl from .adapter import CacheControlAdapter from .controller import CacheController + +import logging +logging.getLogger(__name__).addHandler(logging.NullHandler()) diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 7f8709b8f861c7d704fc88181acca9d7432a8e66..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 577 zcmYe~<>g{vU|^UdaWGYnk%8ech=Yuo7#J8F7#J9eEf^RWQW&BbQW&EcQ<$QdQkbKd zQ&>`1b69d&qgWXkQdm;ha@ca&qu9Z0_8g8}&L~bsh7^uq22IYYB<IBBj8y0Rypp2) z9EHr>g8ZTq1<$;a)S|S+<WxN_F5krLRE5kEh1A62N`;bqn3A-j{9J`(kltjd-tx?n zjQr9Pg`E7nbcMXc+|=TN#N^asJ+3Nl*P_g11)s#C;{3cSfz+bRWQWZByrTT%Y`y%V z^eQ$3JwqcsvzLqv3=Eo#w|J0Uq{(<o7@6;wl2}lZTBON%iyv7yC$-2=lj|0He0)lN za(w(PuK4)G(vpn)qWJh*obmCgxrv!M@$t8~<KxRxi;6Sz^Wx)gv6mMm78Ilw6@h~C z7JDMZ<RWGU28LT)P*3Hg78S8DFfgoSDB@vYfDpf0ovmU*i&Kk=V^VWcGK*sT^HN=k zGRsmGbQMDVJi}arf;~eVgB3jeT>Sl9gFPK%f?a)GgF{?{6wG1*0(@c;O>}ee(=&@p zGP7e+^U7j;GLvG8GfPr+3lfvF6Vp?RV+t}0^yAA?^HTDQ^pV3@KR!M)FS8^*Uaz3? g7Kcr4eoARhsvRiYib2j}VPRopVPs+AVdP;108zQFjQ{`u diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-39.pyc deleted file mode 100644 index babf4480c0b72b44b0c67208f79c3c7b208b1077..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1598 zcmYe~<>g{vU|^UdaWIvim4V?gh=Yuo85kHG7#J9eD;O9UQW#Pga~PsPG*b>^E>jc} zBZ$qM!<@?!#R6ut<gn(lMX`a|tU2tt98nx#Hd_v7E>{#6BSQ*%3P%e=6n6?|3Req5 z6i*6w3Qr3|6mN<^3U3Nu3u6>tDt`)pHd9eaDqk}LBSQ*fFoUMxOOTuVG#PJk6r~oH zrWThJYck#vc1}#rNOjK7D=Es)aZE`pC`m2SWW2@cl9^lrmeORr#g>zwo(>k~b1X_P z%}vcK2}mp|PAy6XnFzy-3=9k)pE`qls>Hy+P{Oc)v4km$c_AYsLkZIYmW2$pATib& z29QV!LokCTqn{>Q5i0`&!!3^D)DoZ6vecYg>>%4R^U`mzy0|)py5HgrE-6Y)%=Jjj zOUX$sy2X{4k^*IGGTvg(fC#T-DB@*cVEEPOY!wq)oLW>IlbVx~Srp@+m+DfKS(d7x zs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2?CR?p9O4?JU=|Y);1iQ*qMMVSo>^RynH`gw zR~F-wnG{o;S(2(-keHmEn4Vf3Q;=DpA77T5my%zkp9~7SWJuWQ$0z5e=oM7n;w?@s zDJ_VH`ho`(8f>62V&q}uU@YQiU|>KAHYNrJ29P{B*zCZ;R>IiKkiwV(N)}ALEVZD( zV_wKm%UHv>fF*^whG8KSBLkSt0%bE~vDPrgv(<p2nbj{ullc}m*lF>pC5h?9x44Q^ zi!u{)GOJRHZgFO$mKK5hmt4i3QBqQ1rLSMb0b&$e>FaB<7lC51h=qZHp$O!#TkOH9 z#l@NVdAC?|^GoweZgD|<3yKK=h#d$KO{QDyiI608i={ZVxELHK5P}aB$=vCwCGjAM z%=|ndP{0U)1BQu_>pvSa2O|$74-*GtktBK$fl?O8N#G!o0S8etLoGuMLl$ESV+vCW zb1x`B7#1)s1f?k!zgx_uMLAUxAsML(p+P<hCHV>^MU@JPc_|8D7i%)!V#!F&DbQpt z0tNgnp2U=t_(W*JzQt7lO4=YkD0{Ghc|{OEfKpfy*drVuk0chQ7t4Ws0WyVwk&Tg$ zu}B`|c945P9s^-ec*5Nt0(Uzoiop@eRKozuA+<~;ETEiP!<faofUSlpi@k;^ivtqT zS*!~<K_Uwoi#$rWQW%>V85#08O1M&(KrC=RV)m<I2j|ul#VTIE{1S*qQxvQ;G`YcU z0tf0X=JeE(A}LVhf|6m87${Eoz+n<!lv-SnpI4lEiyc}x++r?DEWZVjO^JsIvKAC& z=9OqN-(mszzDNRO0t-kldI+)PCT8ZTfI<fn$83yj%sk9&%tFk3j9g4b8X%1v@$n#4 z@$sN?K%j^NB*tBkS)d2aU*IGdrGO-&2X-tp#pyxQ8aT~H$>CH6)&ow{QOdX#L2_|U zY7w+NN-Ro;#62i>!PyoZhLF&NIX^EkH#I&U$?r%>#3naCr8Fni4wM>-K|#&I#KXh` SPUJky9Bdps9Bf=79E<>cK9hd{ diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-39.pyc deleted file mode 100644 index e0f1373c6316e56a3453fc290c3eb991f10fb2d4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3103 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 diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-39.pyc deleted file mode 100644 index f228f240b7d9bbfe7aaf212595e452a17ad68afa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1850 zcmYe~<>g{vU|^UdaWGYtnStRkh=Yt-7#J8F7#J9eO&Ay$QW&BbQW#U1au{=&qL>&N z+!<1sQ&?IUQdm-%o0+3n+!<0>Q`lM<QrJ>inwg_mQ`mzUG&!o0xI!{g6_OK^Gg1}u zld@8iOB5UfJQdRNixe_*3vyC(Q}aqP^U@(IiuDvgs#8+a5=(PR6f%ny5*11^ic%9( zxQY|gQWY}ubaPX4^NT7KQZkcEGV}8iiz@ZFUV_}L$#{#!CqFqm8N@-xOfXOAFfcHr zGDI<^FhntdJkr7t#SHO66br=ZAV;Tgv@k@mrEmr_XmZ`+bV@8vbq2XT8DtF1SP+|$ zfq}sp6gHqBEMaJ7XktuZ2xeHx=(m#bmat!bi6_i=sVS~SMfpW5nQpNZr{<*HV$M#j zT**)b()X*$*(xTqIJKxaCN(D|vna+tFV&?evn*9XS0U8TGt4z8*fYd2Si#fJ#oy00 z*wZm4*wxoHIK(wb!7L^qz$YfrL^mftJ+rtZGdm_VuPnwVGbyGxvm{lwATc>RF+H_7 zrXaIGKfWwAFD1W79~=wG`FSNp`8g1dUP0w8=JeDOkYkEL-eO>^;)Q!!FFmy+nHlD5 z1_lNY8;8e>K#8S@m4Sg_C36u60|P@5Cj$e+E!MKcoYGXVXCVYPNR+uawS*TGc$iie zr<M>K)(9($*g+P8Jb`2hTS{t9YDua9l05<luR$b}LB4@`5X1&yaI}KF1By_HB_N|U z86o}xv5~A{P0q<LP8CM7g&$!HSk6zA{T4@jd|qO1YJB`HuK4)e{FKrh5Su4HzOXbg z2O?9%1M&nvhyb~{ND#zASO#W+LazuE3!o4#1`!-g9LyjH7R5;XAf@0OtcRTVxl))? zm|Ga5m{V9%SX&sPSW?(h*jpH)SW`GsIKj!EF_=M<`xd85W^xHQ`TJqS2`J{k0VT%3 zzyM1BH4O2LHH-y(nG7`y@l5cb(_}6JDZRy#lb@V@izOwoBvF$I9FVs-GxIV_;z2nX z5}a@!f<g-{7cU74R!~$hFmf<f3Blc?7atE%fZ;BXVz9gT7#J987_t}^FxD`pFf3#W zW&lT}CR33(C}6>XjV0NDV?h>VEy&rR?0~QoTXq1&0oXn(sD1qkj39d%7ckW@)-Yu< zE@Wh62xmxPU}0ckXl7<)$P+MRDAqAxU<AWR21W+tumXi9*nzj$N()jFOHzwK`2;O| zia?1(0pv!IZ^1#si*O~j90YeIC^3LSrC*Jap@y-BA&aq$p-2uygWQYNtwx01%3P3N zfGrOeffBL`$f0bYOvcE;$i-MCfN&}#6KXR0X|fjyfno)ejfzA-EKtmY;{xniut7+n z08c7Kq6`cSpa_L#1}+v3W)2pxsGla=E%x~Ml>FrQ_*<NiY9uo+9g-Z`AaxNq*ML=H YGyE2Z4J51Dfr^D<kRMoBc$fwF0rQYwn*aa+ diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-39.pyc deleted file mode 100644 index b1058db3c293c3e418b78f03d0ada27255a6d3d4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 774 zcmYe~<>g{vU|^UdaWHi|69dCz5C<7^FfcGUFfcF_-(g^2s1itFNMX!j$YqRTWMl|u z$dhAXNM)+jV`Kn9upBc)E|MXS$$+7XCxsz}DTgJBHJl+&3amB^q>_;VEY2Fm3RMR( zmpO+mmpzId$=o)$TIL)Mh#Zo7mK@Gpt|%@f_1oa;S#r1`a!~agsXS4<;S70VEDWi9 zmDeEZQu(8JA@V6q!3>(LFG2p+WW2>*T9lKOpPA>U$#{#$BP1jsD7CmCKd(3y#Lp~_ zPb-K|&dD!MP0<v%#Zy|8laraGSCCj#oLa=hz`$^e+cUQyzo^8us3^ba7Ds7O4p{CM zdvZW#a&}JYEw%zM9i>;0S)dnRmYSE6U!+%*T3DJ|TvDu8keHmEn4Vg!2Qk=KuLx>+ z5i<h=LzE1%CUhlHTFA1vjVvw6%qe04xm5yL1I##(^ey(%yv*eMl+;_CC8-r9@g<c7 zskb=&5_3}_{$egJDO$-;#LvJ0A$~PGTg8MHrxq2*q~@e#7RC7IrMeVlmZd7_DunuZ zhPeg>dxkg$D|q_3`1`pAdpgDhyZX8YhqwkQn8gGH_{1cd=;q|7XBL-aX2+!FmBsjE zCdCwImZa*!0wks&vp^pjT>8n0$r-81`FSNp`8oQ@`MCv&C3*#ww>WHa^HWN5QtcQ) lDOQbvfq{upfRTq$h?$9zhmnVoj}^*ig3`=Pj2w(Si~w#0(%k?6 diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-39.pyc deleted file mode 100644 index 1c44791a4bc4d1bb4f5cabcdb2c8dd7d69809daa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7791 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 diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-39.pyc deleted file mode 100644 index 0841947fd645d6befe015bf398f76dabd0eccaea..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2199 zcmYe~<>g{vU|^UdaWM5MCj-M{5C<8vFfcGUFfcF_D=;uHq%fo~<}l<kMlmunxHF_M zr7*WJq%fy4H8V#sr?3PwXtKTp>D6Ss#qLyDl3MKPpA6z7V`i9nP7DkTsSHt!DGX6e zDU4Cf5YwVqQdm-0TNt8PQ`l12TNt9)QaDmLTNt9)Q}|Q3Q+Qe!qc~D{Q}|jKqBv8y zf*CXgZV5Xl=Hw(LCTF{4=A?!fB^DH<7A2N3GB9u{C@3fd=O*UlD3n8l6%vc`OY>3` z5*5-46!Md@Qj<#*$}=*PGZe}*b8-|)Qd1RD%TkLfOENO^(iMtQ6H^p2^Gfm+62V3# zm8PYo7U?J?=A|f<XQbvSlw>59D5PcPq$*?<D<tRS7pJBuWR^h8O07suE-gt_NK{CM zI!~cIvm`^IBqJ4USaN<|Norn6u|j?t#2kp}dR$;x$DAC6#FCPt%%swi)MACiqEv-~ zqWp@?)D(r1e2^ImrFki-MLCrqcY<92@eNdaNCwzJiN(bVrNybm3c0DdNvTD}5EmpW zq~w<-<)lK4C{E5VN>$K^kJnVlNli=vnO9JhnwD9iP@J!jSPXVeUVaJ4+Qj7K%#_r; zlEj>xN`>N##FYGUg~U9BJN3YdlR+^Ii*XQ}iGhK^8I*z~7#J8z7@8Ss7~&ag7;6~f znQEA77~+{z7=jsAGWuz<6oHi9l8na^q4DuarD?Y$uuG*C+>*mC0}Fdi=36YqsX1x4 zn9>Svalk}ZG8Az$Ffjb;aJGsGElw>ej!Df)$t;TT&r5YF$}CG&&{YWa^9*wh3ib?f z3|8>;bMg0c4fb@533l~$4GwV)QZS1N2=IwXG||n;PtPna$;^&P%`1!X$xMnV&MZmQ zEl5nxPE1cNjw#42(2p-m%}dEI(oarI&PWACe^GvpJ}B;>iBqqj@)k#Yd}dx|NqoEj zD8Sf2!N|zL$i`SDgC$J#V2YDL;RaF*!k{1rVQ`R(FfcIGFf3q5VO+>q%T&Tx!&JlA z%oNO^$>diAGF_ADmOy-bdTI$gvBk&VVu$iInTt3W7#MD`<R#{&7I88#K!OV#W<@+8 z8E&}V_;^u}i$SFY11A?_l{|L$LQRg3Pi6$U6^cP@kWFAGyD%^?RPog?WHDqhrZAK; zgfj#)urQP`RVpwtfM6s;9+Lq>6&F|qGhEgVB*(}AkxgL)d(lmk1?)?(+i&qX!ZMU= zQBi);EjCDwUC9XcCB#>t<N)y+UwnLKaeP`qJVccu$ag{@_cAgu@-gu+vN16+a)D@; zDkbcGMb?htT~I)Qy$dQ<L0%~m1I1GfLl)x#riBa(85tQ;KpBMrlsSq(sx_I5*g;Xi z3JQ3R^wg5F#GKO9B2WyYyPXZ<Xd{rDL9xuh$i^tZUL}RqonZg@;Z8z2;3SmAuz;}! zoQP@|vX~Yy*D!&cSi`V@Wg$b6Mh(LP)`bj=3^h!_3=qe%fdl>)3#be&0y~+tyeP9I z^_CL$jEWpsMdAz$3@f3Dk2x{7<Q7XxVo4&JFN;9Mi7m*B;0lb9hmnVogOP)&N&=fV zLGHlqM^FU^iUhbH8B-XunTix@m{OP^bT9)Jf7>AYTa(%EB`6;jg9u(OO=t*k#TO^0 zrN)Eo2ZuwEBq$Q4Km^E}MbaP^IN5;-P_`<PXJBA(1^J8*oZxsE1(;cwpuUsC<~xKP znv8y$T%ckElxO4PZ*j%P=jNxB=A_2Q-{OgnFDy;Wfy%JQ$EV~c$Hy1(f?Oa7A`q?u zg)P__NP&)UAE<Z%CCOrt`#2a`xH(ukcsK+(xVborKyrSXEVr04^C87K8>D6eOJFnY R7KaVQg?6A~033Qe%mCFd9QyzO diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-39.pyc deleted file mode 100644 index 762c6978cd7a53faa5a511a76f8c8560e5f813ef..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4731 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 E08Nfkxc~qF diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-39.pyc deleted file mode 100644 index 2ade01220d8e1573af27b8b9303741cea233c271..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4250 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 diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-39.pyc deleted file mode 100644 index 2f99daf818dc703fd376949b4720b6abe42f8dd3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 701 zcmYe~<>g{vU|^UdaWHig69dCz5C<8vGcYhXFfcF_t1&Pzq%fo~<}l<kMlmvi*i1Q0 zxy(__j0`F4DXb}MEsRktDa^qPnj9|~85kHe8E*+YCnjg4I_Kw=6y@hQrX&`Wq!wv1 z-r{u0OfCUS`Gq8NAlb&rz`y|FJA*9rVqjpXVN78tWhmk+VQ6N^W2#}SWvpQ<kSJlS zWvgMUVXR@QVXk4RVXa|LVeDnA<)~p;z?8yN!?BQwkpawRhOvVgG+F#KS#NPCgB%o} zT9TMve2c3%wJ0+&C$lQG=oV*2YH3ksaY<(KErDc+dvj8Y;*)a{i;Hgwf^{V(<)p^v zrj}&nrxaJQXOxr_Sn2Cmaex@bR{Hvy%tg!$3=Bm~3=9mnSab7B^GY;1Z?P1o78l=Q z1shPr0+MG15o{m=6tuT^6CuF@v8o8<`&;Z#v6T!(d<+Z>zgnEFVnT~ki;81Xb5b&k zV*K+`U5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYs zbMn(czRQkD%`1!X$xMnV&MZmQEl5nxPE1cNjw#42(2p-m%}dEI(g(X08V361MTrFk zsYQAPmA81nF$RrHkS~g*KvBmn#K^(OgbaVNaquwmFck@a5&^qkh#v@OvKH}zJPit- tB5n{199keXU{4|u{Gbrzu*uC&Da}c>10|(mAqEBp9!4Hk21X?K0|0qnuGIhl diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py index f1e0ad94..4266b5ee 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py @@ -1,3 +1,7 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + import logging from pip._vendor import requests diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py index 815650e8..94c75e1a 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py @@ -1,16 +1,20 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + import types import functools import zlib from pip._vendor.requests.adapters import HTTPAdapter -from .controller import CacheController +from .controller import CacheController, PERMANENT_REDIRECT_STATUSES from .cache import DictCache from .filewrapper import CallbackFileWrapper class CacheControlAdapter(HTTPAdapter): - invalidating_methods = {"PUT", "DELETE"} + invalidating_methods = {"PUT", "PATCH", "DELETE"} def __init__( self, @@ -93,7 +97,7 @@ class CacheControlAdapter(HTTPAdapter): response = cached_response # We always cache the 301 responses - elif response.status == 301: + elif int(response.status) in PERMANENT_REDIRECT_STATUSES: self.controller.cache_response(request, response) else: # Wrap the response file with a wrapper that will cache the diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/cache.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/cache.py index 94e07732..2a965f59 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/cache.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/cache.py @@ -1,3 +1,7 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + """ The cache object API for implementing caches. The default is a thread safe in-memory dictionary. @@ -10,7 +14,7 @@ class BaseCache(object): def get(self, key): raise NotImplementedError() - def set(self, key, value): + def set(self, key, value, expires=None): raise NotImplementedError() def delete(self, key): @@ -29,7 +33,7 @@ class DictCache(BaseCache): def get(self, key): return self.data.get(key, None) - def set(self, key, value): + def set(self, key, value, expires=None): with self.lock: self.data.update({key: value}) @@ -37,3 +41,25 @@ class DictCache(BaseCache): with self.lock: if key in self.data: self.data.pop(key) + + +class SeparateBodyBaseCache(BaseCache): + """ + In this variant, the body is not stored mixed in with the metadata, but is + passed in (as a bytes-like object) in a separate call to ``set_body()``. + + That is, the expected interaction pattern is:: + + cache.set(key, serialized_metadata) + cache.set_body(key) + + Similarly, the body should be loaded separately via ``get_body()``. + """ + def set_body(self, key, body): + raise NotImplementedError() + + def get_body(self, key): + """ + Return the body as file-like object. + """ + raise NotImplementedError() diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py index 0e1658fa..37827291 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py @@ -1,2 +1,9 @@ -from .file_cache import FileCache # noqa -from .redis_cache import RedisCache # noqa +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + +from .file_cache import FileCache, SeparateBodyFileCache +from .redis_cache import RedisCache + + +__all__ = ["FileCache", "SeparateBodyFileCache", "RedisCache"] diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index c73e5810a5331f1466b4a28580b19a019833375f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 321 zcmYe~<>g{vU|^UdaWFNEfq~&Mh=Yuo7#J8F7#J9eWf&M3QW#Pga~N_NqZk=MY^EHh zT;?cdMursTU<OT=my8Sy44RC$INdUHQk@f%Gg37fZ*c{sreqd_d48HKx46<Wb5i4z zL6Suvqi=B+f#jhg%nS?+D;bK|7#JYLuO4Tsn9$<XqT-m;oRrL>82`Lfm!izFR0Umy zP(RNw*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!klnAE(o z7@y3fnBvTmRNaEa<m|-s)Z&<e%mV%Rvedkk{33m@vy$`kN{aGxAe>_T`1s7c%#!$c Zy@JYH95%W6DWy57b|8-ygPhO92mr!qSVsT= diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-39.pyc deleted file mode 100644 index 69ee4447ae818ae0a7b0a8a7e2a87e09b2cb0849..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3337 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 I9GU_l0N1qn5C8xG diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-39.pyc deleted file mode 100644 index 25d81532e984ec5fec1d5b61f04ded9f82bc250e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1593 zcmYe~<>g{vU|^UdaWFN4nStRkh=Yt-7#J8F7#J9eEf^RWQW#Pga~N_NqZk=MY^EHh zT&5@{Fq=7tIhQ4hg^|IXA%!J{wS^&tHI=2AIf^xfEto-*{UyjuO~zXsDVb%N#hLke zV0L0jYDs2pswU$tPN&4;ROiIxjMQY1N@UCobAcTL14Al96k`fQ6jKUg3R4S16mtr5 z3QG$^6iW(U3R?<$3u6>(3P%cO3qurJ3Renu3qurp3Qr1e3quq~3TrTfCjTw2pwyJi zVu(#lNY;SZAnXkCD=0{67;6~f8B!R68CEj-X)@koNzTv9(`35EQk<HTR>aQ0z_5~` zh?9YV;a9)2RZM7cYEf}aYEDXKQH+0Hs!LI3S*n7rLa3i-m}^k5XNY64f~TL0zn^Qc zr(;a8tFLQth-;97Sxi8HPfVhTZccuBW^qYoc1&tsS&UC+QcQ7XNvdu^Vsdt3dTMb@ zL1uw|d|7H<N`8@kGB}X(^Gb^Hb0C~z{UVT`;=wX{1(mlr;^Q;(GE3s)IYFKQ`HF$D zN*LjBJ(zqlSPmKrAT}th!6CrIz`#($kj1cov4(LWV=zMz8v_G_CKK4-x0usYOI9)! zaWF72++xm7tpo=HgaCzH5lAx#7lVvsV65UpvN}Dr#4j0?sGznofY>0z!PeS<tYt11 zfmvO{w2+CBAy1`-xrAu}^Fjs*hFWH@97_#j32P1W0=9(=&5Sin3z<QQ5avvFs56UG zONu}~y2VynlAM=cev7p@wIsFT7IS7^$t~WJ{F20+_~O*${JfN6O%||siugc&Vl7L| zDNVh_o?20mS(I7~@fj#Ai@@IFXJB9e;bKq#Ffg((3NZ1Yda^jR1b5I1fcyv#T4Z-a zgO@EOH7B(swTPF20g}QX4glLN#=yV;!mywfL<(Anwq!<F$TBc6fFb}Cz~I1DfLpwf z!G$4Kpq3FFluV!)W@ISjN?{CU&}6Fe^hnJqNG(!G%P&$$&Ph!y%FIhwNX*GmD9K1w z$WE;+R>;g#NK{BkEJ;jCEKb!^2rW)kD9<d(;8K8s<iygF%=|n>KTT#xOt65o6@lE1 z%~Q8n!PZEE5-Z5D49t9tRRTyJ152a$3*<)-2Kx)72kLfvur7tt;?!aVP<~BK2028b zAU{7RGcR37AunGcFEuqqp(I}+IVZn373?R3LOnllP-`+m5(7BO!2~GmLC(xCPL&5a z6BMotOlXeGFHY5D^wZ=7<-fed+|>B^TU_z+x%nxjIUqJqe0*VPVh%*6h#M5SpiEK( zN=lHhkpPK-f&uIbBm!i85i0`&1E|<32I=Bp;$Y@r=3?hy=3oQM_-V3%Y)dOGDJ@Ek zk1qnb5S;j<<O(ti^q{4O9=ME1hLj!<P7x^hz(ychi10Lr4a5U>px`bBWmFy}9!4H! E0Pzo9l>h($ diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py index 607b9452..f1ddb2eb 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py @@ -1,8 +1,12 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + import hashlib import os from textwrap import dedent -from ..cache import BaseCache +from ..cache import BaseCache, SeparateBodyBaseCache from ..controller import CacheController try: @@ -53,7 +57,8 @@ def _secure_open_write(filename, fmode): raise -class FileCache(BaseCache): +class _FileCacheMixin: + """Shared implementation for both FileCache variants.""" def __init__( self, @@ -114,22 +119,27 @@ class FileCache(BaseCache): except FileNotFoundError: return None - def set(self, key, value): + def set(self, key, value, expires=None): name = self._fn(key) + self._write(name, value) + def _write(self, path, data: bytes): + """ + Safely write the data to the given path. + """ # Make sure the directory exists try: - os.makedirs(os.path.dirname(name), self.dirmode) + os.makedirs(os.path.dirname(path), self.dirmode) except (IOError, OSError): pass - with self.lock_class(name) as lock: + with self.lock_class(path) as lock: # Write our actual file with _secure_open_write(lock.path, self.filemode) as fh: - fh.write(value) + fh.write(data) - def delete(self, key): - name = self._fn(key) + def _delete(self, key, suffix): + name = self._fn(key) + suffix if not self.forever: try: os.remove(name) @@ -137,6 +147,38 @@ class FileCache(BaseCache): pass +class FileCache(_FileCacheMixin, BaseCache): + """ + Traditional FileCache: body is stored in memory, so not suitable for large + downloads. + """ + + def delete(self, key): + self._delete(key, "") + + +class SeparateBodyFileCache(_FileCacheMixin, SeparateBodyBaseCache): + """ + Memory-efficient FileCache: body is stored in a separate file, reducing + peak memory usage. + """ + + def get_body(self, key): + name = self._fn(key) + ".body" + try: + return open(name, "rb") + except FileNotFoundError: + return None + + def set_body(self, key, body): + name = self._fn(key) + ".body" + self._write(name, body) + + def delete(self, key): + self._delete(key, "") + self._delete(key, ".body") + + def url_to_file_path(url, filecache): """Return the file cache path based on the URL. diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py index ed705ce7..2cba4b07 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py @@ -1,3 +1,7 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + from __future__ import division from datetime import datetime @@ -15,9 +19,11 @@ class RedisCache(BaseCache): def set(self, key, value, expires=None): if not expires: self.conn.set(key, value) - else: + elif isinstance(expires, datetime): expires = expires - datetime.utcnow() self.conn.setex(key, int(expires.total_seconds()), value) + else: + self.conn.setex(key, expires, value) def delete(self, key): self.conn.delete(key) diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/compat.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/compat.py index 33b5aed0..ccec9379 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/compat.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/compat.py @@ -1,3 +1,7 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + try: from urllib.parse import urljoin except ImportError: @@ -9,7 +13,6 @@ try: except ImportError: import pickle - # Handle the case where the requests module has been patched to not have # urllib3 bundled as part of its source. try: diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/controller.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/controller.py index dafe55ca..7f23529f 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/controller.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/controller.py @@ -1,3 +1,7 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + """ The httplib2 algorithms ported for use with requests. """ @@ -9,7 +13,7 @@ from email.utils import parsedate_tz from pip._vendor.requests.structures import CaseInsensitiveDict -from .cache import DictCache +from .cache import DictCache, SeparateBodyBaseCache from .serialize import Serializer @@ -17,19 +21,20 @@ logger = logging.getLogger(__name__) URI = re.compile(r"^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?") +PERMANENT_REDIRECT_STATUSES = (301, 308) + def parse_uri(uri): """Parses a URI using the regex given in Appendix B of RFC 3986. - (scheme, authority, path, query, fragment) = parse_uri(uri) + (scheme, authority, path, query, fragment) = parse_uri(uri) """ groups = URI.match(uri).groups() return (groups[1], groups[3], groups[4], groups[6], groups[8]) class CacheController(object): - """An interface to see if request should cached or not. - """ + """An interface to see if request should cached or not.""" def __init__( self, cache=None, cache_etags=True, serializer=None, status_codes=None @@ -37,7 +42,7 @@ class CacheController(object): self.cache = DictCache() if cache is None else cache self.cache_etags = cache_etags self.serializer = serializer or Serializer() - self.cacheable_status_codes = status_codes or (200, 203, 300, 301) + self.cacheable_status_codes = status_codes or (200, 203, 300, 301, 308) @classmethod def _urlnorm(cls, uri): @@ -141,23 +146,29 @@ class CacheController(object): logger.debug("No cache entry available") return False + if isinstance(self.cache, SeparateBodyBaseCache): + body_file = self.cache.get_body(cache_url) + else: + body_file = None + # Check whether it can be deserialized - resp = self.serializer.loads(request, cache_data) + resp = self.serializer.loads(request, cache_data, body_file) if not resp: logger.warning("Cache entry deserialization failed, entry ignored") return False - # If we have a cached 301, return it immediately. We don't - # need to test our response for other headers b/c it is + # If we have a cached permanent redirect, return it immediately. We + # don't need to test our response for other headers b/c it is # intrinsically "cacheable" as it is Permanent. + # # See: # https://tools.ietf.org/html/rfc7231#section-6.4.2 # # Client can try to refresh the value by repeating the request # with cache busting headers as usual (ie no-cache). - if resp.status == 301: + if int(resp.status) in PERMANENT_REDIRECT_STATUSES: msg = ( - 'Returning cached "301 Moved Permanently" response ' + "Returning cached permanent redirect response " "(ignoring date and etag information)" ) logger.debug(msg) @@ -244,6 +255,26 @@ class CacheController(object): return new_headers + def _cache_set(self, cache_url, request, response, body=None, expires_time=None): + """ + Store the data in the cache. + """ + if isinstance(self.cache, SeparateBodyBaseCache): + # We pass in the body separately; just put a placeholder empty + # string in the metadata. + self.cache.set( + cache_url, + self.serializer.dumps(request, response, b""), + expires=expires_time, + ) + self.cache.set_body(cache_url, body) + else: + self.cache.set( + cache_url, + self.serializer.dumps(request, response, body), + expires=expires_time, + ) + def cache_response(self, request, response, body=None, status_codes=None): """ Algorithm for caching requests. @@ -261,6 +292,11 @@ class CacheController(object): response_headers = CaseInsensitiveDict(response.headers) + if "date" in response_headers: + date = calendar.timegm(parsedate_tz(response_headers["date"])) + else: + date = 0 + # If we've been given a body, our response has a Content-Length, that # Content-Length is valid then we can check to see if the body we've # been given matches the expected size, and if it doesn't we'll just @@ -304,35 +340,62 @@ class CacheController(object): # If we've been given an etag, then keep the response if self.cache_etags and "etag" in response_headers: + expires_time = 0 + if response_headers.get("expires"): + expires = parsedate_tz(response_headers["expires"]) + if expires is not None: + expires_time = calendar.timegm(expires) - date + + expires_time = max(expires_time, 14 * 86400) + + logger.debug("etag object cached for {0} seconds".format(expires_time)) logger.debug("Caching due to etag") - self.cache.set( - cache_url, self.serializer.dumps(request, response, body=body) - ) + self._cache_set(cache_url, request, response, body, expires_time) - # Add to the cache any 301s. We do this before looking that - # the Date headers. - elif response.status == 301: - logger.debug("Caching permanant redirect") - self.cache.set(cache_url, self.serializer.dumps(request, response)) + # Add to the cache any permanent redirects. We do this before looking + # that the Date headers. + elif int(response.status) in PERMANENT_REDIRECT_STATUSES: + logger.debug("Caching permanent redirect") + self._cache_set(cache_url, request, response, b"") # Add to the cache if the response headers demand it. If there # is no date header then we can't do anything about expiring # the cache. elif "date" in response_headers: + date = calendar.timegm(parsedate_tz(response_headers["date"])) # cache when there is a max-age > 0 if "max-age" in cc and cc["max-age"] > 0: logger.debug("Caching b/c date exists and max-age > 0") - self.cache.set( - cache_url, self.serializer.dumps(request, response, body=body) + expires_time = cc["max-age"] + self._cache_set( + cache_url, + request, + response, + body, + expires_time, ) # If the request can expire, it means we should cache it # in the meantime. elif "expires" in response_headers: if response_headers["expires"]: - logger.debug("Caching b/c of expires header") - self.cache.set( - cache_url, self.serializer.dumps(request, response, body=body) + expires = parsedate_tz(response_headers["expires"]) + if expires is not None: + expires_time = calendar.timegm(expires) - date + else: + expires_time = None + + logger.debug( + "Caching b/c of expires header. expires in {0} seconds".format( + expires_time + ) + ) + self._cache_set( + cache_url, + request, + response, + body, + expires_time, ) def update_cached_response(self, request, response): @@ -371,6 +434,6 @@ class CacheController(object): cached_response.status = 200 # update our cache - self.cache.set(cache_url, self.serializer.dumps(request, cached_response)) + self._cache_set(cache_url, request, cached_response) return cached_response diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py index 30ed4c5a..f5ed5f6f 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py @@ -1,4 +1,9 @@ -from io import BytesIO +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + +from tempfile import NamedTemporaryFile +import mmap class CallbackFileWrapper(object): @@ -11,10 +16,17 @@ class CallbackFileWrapper(object): This class uses members with a double underscore (__) leading prefix so as not to accidentally shadow an attribute. + + The data is stored in a temporary file until it is all available. As long + as the temporary files directory is disk-based (sometimes it's a + memory-backed-``tmpfs`` on Linux), data will be unloaded to disk if memory + pressure is high. For small files the disk usually won't be used at all, + it'll all be in the filesystem memory cache, so there should be no + performance impact. """ def __init__(self, fp, callback): - self.__buf = BytesIO() + self.__buf = NamedTemporaryFile("rb+", delete=True) self.__fp = fp self.__callback = callback @@ -49,7 +61,19 @@ class CallbackFileWrapper(object): def _close(self): if self.__callback: - self.__callback(self.__buf.getvalue()) + if self.__buf.tell() == 0: + # Empty file: + result = b"" + else: + # Return the data without actually loading it into memory, + # relying on Python's buffer API and mmap(). mmap() just gives + # a view directly into the filesystem's memory cache, so it + # doesn't result in duplicate memory use. + self.__buf.seek(0, 0) + result = memoryview( + mmap.mmap(self.__buf.fileno(), 0, access=mmap.ACCESS_READ) + ) + self.__callback(result) # We assign this to None here, because otherwise we can get into # really tricky problems where the CPython interpreter dead locks @@ -58,9 +82,16 @@ class CallbackFileWrapper(object): # and allows the garbage collector to do it's thing normally. self.__callback = None + # Closing the temporary file releases memory and frees disk space. + # Important when caching big files. + self.__buf.close() + def read(self, amt=None): data = self.__fp.read(amt) - self.__buf.write(data) + if data: + # We may be dealing with b'', a sign that things are over: + # it's passed e.g. after we've already closed self.__buf. + self.__buf.write(data) if self.__is_fp_closed(): self._close() diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py index 6c0e9790..ebe4a96f 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py @@ -1,3 +1,7 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + import calendar import time diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py index 3b6ec2de..7fe1a3e3 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py @@ -1,3 +1,7 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + import base64 import io import json @@ -17,24 +21,18 @@ def _b64_decode_str(s): return _b64_decode_bytes(s).decode("utf8") -class Serializer(object): +_default_body_read = object() + +class Serializer(object): def dumps(self, request, response, body=None): response_headers = CaseInsensitiveDict(response.headers) if body is None: + # When a body isn't passed in, we'll read the response. We + # also update the response with a new file handler to be + # sure it acts as though it was never read. body = response.read(decode_content=False) - - # NOTE: 99% sure this is dead code. I'm only leaving it - # here b/c I don't have a test yet to prove - # it. Basically, before using - # `cachecontrol.filewrapper.CallbackFileWrapper`, - # this made an effort to reset the file handle. The - # `CallbackFileWrapper` short circuits this code by - # setting the body as the content is consumed, the - # result being a `body` argument is *always* passed - # into cache_response, and in turn, - # `Serializer.dump`. response._fp = io.BytesIO(body) # NOTE: This is all a bit weird, but it's really important that on @@ -46,7 +44,7 @@ class Serializer(object): # enough to have msgpack know the difference. data = { u"response": { - u"body": body, + u"body": body, # Empty bytestring if body is stored separately u"headers": dict( (text_type(k), text_type(v)) for k, v in response.headers.items() ), @@ -71,7 +69,7 @@ class Serializer(object): return b",".join([b"cc=4", msgpack.dumps(data, use_bin_type=True)]) - def loads(self, request, data): + def loads(self, request, data, body_file=None): # Short circuit if we've been given an empty set of data if not data: return @@ -94,14 +92,14 @@ class Serializer(object): # Dispatch to the actual load method for the given version try: - return getattr(self, "_loads_v{}".format(ver))(request, data) + return getattr(self, "_loads_v{}".format(ver))(request, data, body_file) except AttributeError: # This is a version we don't have a loads function for, so we'll # just treat it as a miss and return None return - def prepare_response(self, request, cached): + def prepare_response(self, request, cached, body_file=None): """Verify our vary headers match and construct a real urllib3 HTTPResponse object. """ @@ -127,7 +125,10 @@ class Serializer(object): cached["response"]["headers"] = headers try: - body = io.BytesIO(body_raw) + if body_file is None: + body = io.BytesIO(body_raw) + else: + body = body_file except TypeError: # This can happen if cachecontrol serialized to v1 format (pickle) # using Python 2. A Python 2 str(byte string) will be unpickled as @@ -139,21 +140,22 @@ class Serializer(object): return HTTPResponse(body=body, preload_content=False, **cached["response"]) - def _loads_v0(self, request, data): + def _loads_v0(self, request, data, body_file=None): # The original legacy cache data. This doesn't contain enough # information to construct everything we need, so we'll treat this as # a miss. return - def _loads_v1(self, request, data): + def _loads_v1(self, request, data, body_file=None): try: cached = pickle.loads(data) except ValueError: return - return self.prepare_response(request, cached) + return self.prepare_response(request, cached, body_file) - def _loads_v2(self, request, data): + def _loads_v2(self, request, data, body_file=None): + assert body_file is None try: cached = json.loads(zlib.decompress(data).decode("utf8")) except (ValueError, zlib.error): @@ -171,18 +173,18 @@ class Serializer(object): for k, v in cached["vary"].items() ) - return self.prepare_response(request, cached) + return self.prepare_response(request, cached, body_file) - def _loads_v3(self, request, data): + def _loads_v3(self, request, data, body_file): # Due to Python 2 encoding issues, it's impossible to know for sure # exactly how to load v3 entries, thus we'll treat these as a miss so # that they get rewritten out as v4 entries. return - def _loads_v4(self, request, data): + def _loads_v4(self, request, data, body_file=None): try: cached = msgpack.loads(data, raw=False) except ValueError: return - return self.prepare_response(request, cached) + return self.prepare_response(request, cached, body_file) diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py index d8e6fc6a..b6ee7f20 100644 --- a/env/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py +++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py @@ -1,3 +1,7 @@ +# SPDX-FileCopyrightText: 2015 Eric Larson +# +# SPDX-License-Identifier: Apache-2.0 + from .adapter import CacheControlAdapter from .cache import DictCache diff --git a/env/Lib/site-packages/pip/_vendor/certifi/__init__.py b/env/Lib/site-packages/pip/_vendor/certifi/__init__.py index 17aaf900..705f416d 100644 --- a/env/Lib/site-packages/pip/_vendor/certifi/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/certifi/__init__.py @@ -1,3 +1,4 @@ from .core import contents, where -__version__ = "2020.12.05" +__all__ = ["contents", "where"] +__version__ = "2023.05.07" diff --git a/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 99d32824883247cc407f8e383caf487b5f3a287f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 303 zcmYe~<>g{vU|^UdaWK`6fq~&Mh=Yuo7#J8F7#J9eB^VeOQW#Pga~N_NqZo6UqL>&N zQkbHcQ<#GpG+ACUGB7Y`GTq`x&d)1J%_}Ls#af<`T9jJFWn^Gvpl4{LXJG25$#RP& zIlm~i2xMpxGXn#|E$;aEvecsD%>2Cg_>~MrYzzz#;#Y&SRZM7cYEf}aYEDXKQH+0H zs!LI3S*n7rLa3i-m}^k5XNY64f~TL0zn^Qcr(;a8tFLQth-;97Sxi8HPfVhTZccuB zW^qYoc1&tsS&UC+QcQ7XNvdu^Vsdt3dTMb@L1uw|d|7H<N`8@ka%xdYW?H6xe0*kJ dW=VX!UP0w84x8Nkl+v73JCN6kK~5H60swD<QFZ_T diff --git a/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-39.pyc deleted file mode 100644 index 4612f777771face6c86a29b2157064620795bdcb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 480 zcmYe~<>g{vU|^UdaWM5i0|Ucj5C<8vGB7YWFfcF_M=&rjq%fo~<}gHoXr>&-T&5_d zT;?cdMut>|1uP30qF7T|v)EFYQ&>`1Q`mYz;;akU7cxX~q;h026?vs{rZP1%G&3?X z<Z-2PrZPj=DU87kn(Qw@cKT^D-Qq~j&nrpID=EIkTAq<wlv>54n_R`Es|y$ADlW+{ zN{ufmDoxd7yv3H7T#}ier^$7TBe5vGAhD=8^_Fl!W`SOOS!!NNevw{sYEemMT4oUw z0|P@5GXn#|Ek4Jh^wQkaypjNr>Y`h0U|mJGcoI`m;uE2Ax46KfAb#;Jmc*j;;#;f* zMVWaeD;bLTKt_RxUk%PyF`>n&Ma40xIVqV%G5&d}E=8GTsS3IZp?;oWu0g?`A&$Wc zo_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylBsk#M; z$=QkNsl_n`nFab#ujoU)q8}fho0ypwAFo$Xd5gm)H$SB`C)JJ-6h|OOaWDxmaWD!n Laxk$m@-P7a>4S@2 diff --git a/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-39.pyc deleted file mode 100644 index 61150cb275e196c9b6cc95dfacb202ace573d423..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1571 zcmYe~<>g{vU|^UdaWGYan}Ojmh=Ytd7#J8F7#J9e7cej|q%cG=q%fv1<uFDux-+CO zr?9jzq_CtiH8V#sS2?9JX0a?_O<`Tg7{!*#R%DaHmcrh`5XGL#+|1C#n8KLCk;9S8 z8O4>$9mUPakiwM6lfsn9o5BfE70!@n!orZsTv@=#0D_SWc`7UnseF}_Ks-i<6oC}( z6rL8wDDD(qh>l2xJSGE%6uuPx7KSMP6sBMXO~I;EuH@9BlFYPBy@E=vIym6s3dzVU zR>;jyDa}b$C`v6UEy^oaD9K1w$jmD)NzBPfEXmBzQ^?6rhA{He6p|A`Cg~NV<|^bD zDP)!uD<tRVm89mC6zg%l1O<^_GKfURjIhAsVPIfLWr$)-VTfW%VGL%_WV$65ACOrP zkXVwOk(%NRabj{}NvfYF^DU0}_`Jm2)cE*YT=DU_U?;}M-{OgnFDy;Wfyk_6C}Lw^ zfDpfGoULL)i&Kk=V^VWcGK*sT^HN=kGRsmGbQMDVJi}arf;~eVgB3jeT>Sl9gFPK% zf?a)GgF{?{6wG1*0(@c;O>}ee(=&@pGP7e+^U7j;GLvG8GfPr+3lfvF6Vp?RV+t}0 z^yAA?^HTDQ^g*GJnU<-aoL`ixS5R5R#K6D+@?SBC!NCaT-x7%r@C=9#4srBzarE)` zbB%X)4GO^;KF*-T#KOS9P{I(*pvmZ`$yfwRV+ij-SnLc847XUzGg6CE#XvehmN76E zaWXJ~0+Xd6u_WUbXHjZmN_<IbMG1yY%nS?+V4IY{Hl;9>G8D;`fD$27GgBf{33Cb4 z0+xjg&5Vf<cQE@^2^VA*=s`WL2lezXE<`HOWWB``@9YTjSbTtEh{r9C^wg4gutT_E z;?5xvx0s7dif(bn$EW6%q!z`;L%aizydsdtz}}Dtc?;xq1`ZBxE=C@vTdax2$(fnS zAh*L(6)2!UYQTQ60sEzdv6&%-v4$yysh7E5qL#Uac>&WxhHwTZh7<-C1{Q{9W=4i! z21ABoJp*t?Vq}P9U}Q)Eg*LO_EykjijJG&a^OEyZGV{_knQyV=7o_Ha9dwHY6rP$a zx7eYH@D?lBdqtw4xL`?1EJ;N24A>vs3=9nRAb)_|$-pSYSOgM5i49Pm0Lg-VAO-e8 z7UKe@66S@BwG1T;S&R!<Y8X-&7lN`clV1@iWofeBV#+Tr0u@ZR*i$l#Kv@8kNzyWN zK$(OkD?c+&lkpZ~8oF~pslyfF93CbVmw>{Q6_zgez%Bt5W}srMmpPb0lhyAQJ2c+G z&L|QB<v0;gii7wI$vSX+f`Z@{2dq@^23ZVEriu_vAOkc7Zn4M5r{pKc#}`S10+Q3U zB004HRNO$a4tr`|S!Pjw-Yw?z)DlQu0QuvVaAs~neo;wIW|Ce}YH@yPQF1CIOo~8m z2M2T!Kgfl=AXB+L!Kz)0it>w!K-Ob-tPP}iu>+;CVo=^-VdG#HU}0k6VPs+CU}9qu TU}9lpVd9bC0g<d+Y<z40h-+Gl diff --git a/env/Lib/site-packages/pip/_vendor/certifi/cacert.pem b/env/Lib/site-packages/pip/_vendor/certifi/cacert.pem index c9459dc8..5183934b 100644 --- a/env/Lib/site-packages/pip/_vendor/certifi/cacert.pem +++ b/env/Lib/site-packages/pip/_vendor/certifi/cacert.pem @@ -28,36 +28,6 @@ DKqC5JlR3XC321Y9YeRq4VzW9v493kHMB65jUr9TU/Qr6cf9tveCX4XSQRjbgbME HMUfpIBvFSDJ3gyICh3WZlXi/EjJKSZp4A== -----END CERTIFICATE----- -# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R2 -# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R2 -# Label: "GlobalSign Root CA - R2" -# Serial: 4835703278459682885658125 -# MD5 Fingerprint: 94:14:77:7e:3e:5e:fd:8f:30:bd:41:b0:cf:e7:d0:30 -# SHA1 Fingerprint: 75:e0:ab:b6:13:85:12:27:1c:04:f8:5f:dd:de:38:e4:b7:24:2e:fe -# SHA256 Fingerprint: ca:42:dd:41:74:5f:d0:b8:1e:b9:02:36:2c:f9:d8:bf:71:9d:a1:bd:1b:1e:fc:94:6f:5b:4c:99:f4:2c:1b:9e ------BEGIN CERTIFICATE----- -MIIDujCCAqKgAwIBAgILBAAAAAABD4Ym5g0wDQYJKoZIhvcNAQEFBQAwTDEgMB4G -A1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjIxEzARBgNVBAoTCkdsb2JhbFNp -Z24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMDYxMjE1MDgwMDAwWhcNMjExMjE1 -MDgwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMjETMBEG -A1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCASIwDQYJKoZI -hvcNAQEBBQADggEPADCCAQoCggEBAKbPJA6+Lm8omUVCxKs+IVSbC9N/hHD6ErPL -v4dfxn+G07IwXNb9rfF73OX4YJYJkhD10FPe+3t+c4isUoh7SqbKSaZeqKeMWhG8 -eoLrvozps6yWJQeXSpkqBy+0Hne/ig+1AnwblrjFuTosvNYSuetZfeLQBoZfXklq -tTleiDTsvHgMCJiEbKjNS7SgfQx5TfC4LcshytVsW33hoCmEofnTlEnLJGKRILzd -C9XZzPnqJworc5HGnRusyMvo4KD0L5CLTfuwNhv2GXqF4G3yYROIXJ/gkwpRl4pa -zq+r1feqCapgvdzZX99yqWATXgAByUr6P6TqBwMhAo6CygPCm48CAwEAAaOBnDCB -mTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUm+IH -V2ccHsBqBt5ZtJot39wZhi4wNgYDVR0fBC8wLTAroCmgJ4YlaHR0cDovL2NybC5n -bG9iYWxzaWduLm5ldC9yb290LXIyLmNybDAfBgNVHSMEGDAWgBSb4gdXZxwewGoG -3lm0mi3f3BmGLjANBgkqhkiG9w0BAQUFAAOCAQEAmYFThxxol4aR7OBKuEQLq4Gs -J0/WwbgcQ3izDJr86iw8bmEbTUsp9Z8FHSbBuOmDAGJFtqkIk7mpM0sYmsL4h4hO -291xNBrBVNpGP+DTKqttVCL1OmLNIG+6KYnX3ZHu01yiPqFbQfXf5WRDLenVOavS -ot+3i9DAgBkcRcAtjOj4LaR0VknFBbVPFd5uRHg5h6h+u/N5GJG79G+dwfCMNYxd -AfvDbbnvRG15RjF+Cv6pgsH/76tuIMRQyV+dTZsXjAzlAcmgQWpzU/qlULRuJQ/7 -TBj0/VLZjmmx6BEP3ojY+x1J96relc8geMJgEtslQIxq/H5COEBkEveegeGTLg== ------END CERTIFICATE----- - # Issuer: CN=Entrust.net Certification Authority (2048) O=Entrust.net OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/(c) 1999 Entrust.net Limited # Subject: CN=Entrust.net Certification Authority (2048) O=Entrust.net OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/(c) 1999 Entrust.net Limited # Label: "Entrust.net Premium 2048 Secure Server CA" @@ -188,48 +158,6 @@ l2D4kF501KKaU73yqWjgom7C12yxow+ev+to51byrvLjKzg6CYG1a4XXvi3tPxq3 smPi9WIsgtRqAEFQ8TmDn5XpNpaYbg== -----END CERTIFICATE----- -# Issuer: CN=QuoVadis Root Certification Authority O=QuoVadis Limited OU=Root Certification Authority -# Subject: CN=QuoVadis Root Certification Authority O=QuoVadis Limited OU=Root Certification Authority -# Label: "QuoVadis Root CA" -# Serial: 985026699 -# MD5 Fingerprint: 27:de:36:fe:72:b7:00:03:00:9d:f4:f0:1e:6c:04:24 -# SHA1 Fingerprint: de:3f:40:bd:50:93:d3:9b:6c:60:f6:da:bc:07:62:01:00:89:76:c9 -# SHA256 Fingerprint: a4:5e:de:3b:bb:f0:9c:8a:e1:5c:72:ef:c0:72:68:d6:93:a2:1c:99:6f:d5:1e:67:ca:07:94:60:fd:6d:88:73 ------BEGIN CERTIFICATE----- -MIIF0DCCBLigAwIBAgIEOrZQizANBgkqhkiG9w0BAQUFADB/MQswCQYDVQQGEwJC -TTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDElMCMGA1UECxMcUm9vdCBDZXJ0 -aWZpY2F0aW9uIEF1dGhvcml0eTEuMCwGA1UEAxMlUXVvVmFkaXMgUm9vdCBDZXJ0 -aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wMTAzMTkxODMzMzNaFw0yMTAzMTcxODMz -MzNaMH8xCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMSUw -IwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MS4wLAYDVQQDEyVR -dW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG -9w0BAQEFAAOCAQ8AMIIBCgKCAQEAv2G1lVO6V/z68mcLOhrfEYBklbTRvM16z/Yp -li4kVEAkOPcahdxYTMukJ0KX0J+DisPkBgNbAKVRHnAEdOLB1Dqr1607BxgFjv2D -rOpm2RgbaIr1VxqYuvXtdj182d6UajtLF8HVj71lODqV0D1VNk7feVcxKh7YWWVJ -WCCYfqtffp/p1k3sg3Spx2zY7ilKhSoGFPlU5tPaZQeLYzcS19Dsw3sgQUSj7cug -F+FxZc4dZjH3dgEZyH0DWLaVSR2mEiboxgx24ONmy+pdpibu5cxfvWenAScOospU -xbF6lR1xHkopigPcakXBpBlebzbNw6Kwt/5cOOJSvPhEQ+aQuwIDAQABo4ICUjCC -Ak4wPQYIKwYBBQUHAQEEMTAvMC0GCCsGAQUFBzABhiFodHRwczovL29jc3AucXVv -dmFkaXNvZmZzaG9yZS5jb20wDwYDVR0TAQH/BAUwAwEB/zCCARoGA1UdIASCAREw -ggENMIIBCQYJKwYBBAG+WAABMIH7MIHUBggrBgEFBQcCAjCBxxqBxFJlbGlhbmNl -IG9uIHRoZSBRdW9WYWRpcyBSb290IENlcnRpZmljYXRlIGJ5IGFueSBwYXJ0eSBh -c3N1bWVzIGFjY2VwdGFuY2Ugb2YgdGhlIHRoZW4gYXBwbGljYWJsZSBzdGFuZGFy -ZCB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB1c2UsIGNlcnRpZmljYXRpb24gcHJh -Y3RpY2VzLCBhbmQgdGhlIFF1b1ZhZGlzIENlcnRpZmljYXRlIFBvbGljeS4wIgYI -KwYBBQUHAgEWFmh0dHA6Ly93d3cucXVvdmFkaXMuYm0wHQYDVR0OBBYEFItLbe3T -KbkGGew5Oanwl4Rqy+/fMIGuBgNVHSMEgaYwgaOAFItLbe3TKbkGGew5Oanwl4Rq -y+/foYGEpIGBMH8xCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1p -dGVkMSUwIwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MS4wLAYD -VQQDEyVRdW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggQ6tlCL -MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAitQUtf70mpKnGdSk -fnIYj9lofFIk3WdvOXrEql494liwTXCYhGHoG+NpGA7O+0dQoE7/8CQfvbLO9Sf8 -7C9TqnN7Az10buYWnuulLsS/VidQK2K6vkscPFVcQR0kvoIgR13VRH56FmjffU1R -cHhXHTMe/QKZnAzNCgVPx7uOpHX6Sm2xgI4JVrmcGmD+XcHXetwReNDWXcG31a0y -mQM6isxUJTkxgXsTIlG6Rmyhu576BGxJJnSP0nPrzDCi5upZIof4l/UO/erMkqQW -xFIY6iHOsfHmhIHluqmGKPJDWl0Snawe2ajlCmqnf6CHKc/yiU3U7MXi5nrQNiOK -SnQ2+Q== ------END CERTIFICATE----- - # Issuer: CN=QuoVadis Root CA 2 O=QuoVadis Limited # Subject: CN=QuoVadis Root CA 2 O=QuoVadis Limited # Label: "QuoVadis Root CA 2" @@ -345,33 +273,6 @@ JRDL8Try2frbSVa7pv6nQTXD4IhhyYjH3zYQIphZ6rBK+1YWc26sTfcioU+tHXot RSflMMFe8toTyyVCUZVHA4xsIcx0Qu1T/zOLjw9XARYvz6buyXAiFL39vmwLAw== -----END CERTIFICATE----- -# Issuer: CN=Sonera Class2 CA O=Sonera -# Subject: CN=Sonera Class2 CA O=Sonera -# Label: "Sonera Class 2 Root CA" -# Serial: 29 -# MD5 Fingerprint: a3:ec:75:0f:2e:88:df:fa:48:01:4e:0b:5c:48:6f:fb -# SHA1 Fingerprint: 37:f7:6d:e6:07:7c:90:c5:b1:3e:93:1a:b7:41:10:b4:f2:e4:9a:27 -# SHA256 Fingerprint: 79:08:b4:03:14:c1:38:10:0b:51:8d:07:35:80:7f:fb:fc:f8:51:8a:00:95:33:71:05:ba:38:6b:15:3d:d9:27 ------BEGIN CERTIFICATE----- -MIIDIDCCAgigAwIBAgIBHTANBgkqhkiG9w0BAQUFADA5MQswCQYDVQQGEwJGSTEP -MA0GA1UEChMGU29uZXJhMRkwFwYDVQQDExBTb25lcmEgQ2xhc3MyIENBMB4XDTAx -MDQwNjA3Mjk0MFoXDTIxMDQwNjA3Mjk0MFowOTELMAkGA1UEBhMCRkkxDzANBgNV -BAoTBlNvbmVyYTEZMBcGA1UEAxMQU29uZXJhIENsYXNzMiBDQTCCASIwDQYJKoZI -hvcNAQEBBQADggEPADCCAQoCggEBAJAXSjWdyvANlsdE+hY3/Ei9vX+ALTU74W+o -Z6m/AxxNjG8yR9VBaKQTBME1DJqEQ/xcHf+Js+gXGM2RX/uJ4+q/Tl18GybTdXnt -5oTjV+WtKcT0OijnpXuENmmz/V52vaMtmdOQTiMofRhj8VQ7Jp12W5dCsv+u8E7s -3TmVToMGf+dJQMjFAbJUWmYdPfz56TwKnoG4cPABi+QjVHzIrviQHgCWctRUz2Ej -vOr7nQKV0ba5cTppCD8PtOFCx4j1P5iop7oc4HFx71hXgVB6XGt0Rg6DA5jDjqhu -8nYybieDwnPz3BjotJPqdURrBGAgcVeHnfO+oJAjPYok4doh28MCAwEAAaMzMDEw -DwYDVR0TAQH/BAUwAwEB/zARBgNVHQ4ECgQISqCqWITTXjwwCwYDVR0PBAQDAgEG -MA0GCSqGSIb3DQEBBQUAA4IBAQBazof5FnIVV0sd2ZvnoiYw7JNn39Yt0jSv9zil -zqsWuasvfDXLrNAPtEwr/IDva4yRXzZ299uzGxnq9LIR/WFxRL8oszodv7ND6J+/ -3DEIcbCdjdY0RzKQxmUk96BKfARzjzlvF4xytb1LyHr4e4PDKE6cCepnP7JnBBvD -FNr450kkkdAdavphOe9r5yF1BgfYErQhIHBCcYHaPJo2vqZbDWpsmh+Re/n570K6 -Tk6ezAyNlNzZRZxe7EJQY670XcSxEtzKO6gunRRaBXW37Ndj4ro1tgQIkejanZz2 -ZrUYrAqmVCY0M9IbwdR/GjqOC6oybtv8TyWf2TLHllpwrN9M ------END CERTIFICATE----- - # Issuer: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com # Subject: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com # Label: "XRamp Global CA Root" @@ -560,34 +461,6 @@ vEsXCS+0yx5DaMkHJ8HSXPfqIbloEpw8nL+e/IBcm2PN7EeqJSdnoDfzAIJ9VNep +OkuE6N36B9K -----END CERTIFICATE----- -# Issuer: CN=DST Root CA X3 O=Digital Signature Trust Co. -# Subject: CN=DST Root CA X3 O=Digital Signature Trust Co. -# Label: "DST Root CA X3" -# Serial: 91299735575339953335919266965803778155 -# MD5 Fingerprint: 41:03:52:dc:0f:f7:50:1b:16:f0:02:8e:ba:6f:45:c5 -# SHA1 Fingerprint: da:c9:02:4f:54:d8:f6:df:94:93:5f:b1:73:26:38:ca:6a:d7:7c:13 -# SHA256 Fingerprint: 06:87:26:03:31:a7:24:03:d9:09:f1:05:e6:9b:cf:0d:32:e1:bd:24:93:ff:c6:d9:20:6d:11:bc:d6:77:07:39 ------BEGIN CERTIFICATE----- -MIIDSjCCAjKgAwIBAgIQRK+wgNajJ7qJMDmGLvhAazANBgkqhkiG9w0BAQUFADA/ -MSQwIgYDVQQKExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMT -DkRTVCBSb290IENBIFgzMB4XDTAwMDkzMDIxMTIxOVoXDTIxMDkzMDE0MDExNVow -PzEkMCIGA1UEChMbRGlnaXRhbCBTaWduYXR1cmUgVHJ1c3QgQ28uMRcwFQYDVQQD -Ew5EU1QgUm9vdCBDQSBYMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB -AN+v6ZdQCINXtMxiZfaQguzH0yxrMMpb7NnDfcdAwRgUi+DoM3ZJKuM/IUmTrE4O -rz5Iy2Xu/NMhD2XSKtkyj4zl93ewEnu1lcCJo6m67XMuegwGMoOifooUMM0RoOEq -OLl5CjH9UL2AZd+3UWODyOKIYepLYYHsUmu5ouJLGiifSKOeDNoJjj4XLh7dIN9b -xiqKqy69cK3FCxolkHRyxXtqqzTWMIn/5WgTe1QLyNau7Fqckh49ZLOMxt+/yUFw -7BZy1SbsOFU5Q9D8/RhcQPGX69Wam40dutolucbY38EVAjqr2m7xPi71XAicPNaD -aeQQmxkqtilX4+U9m5/wAl0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNV -HQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMSnsaR7LHH62+FLkHX/xBVghYkQMA0GCSqG -SIb3DQEBBQUAA4IBAQCjGiybFwBcqR7uKGY3Or+Dxz9LwwmglSBd49lZRNI+DT69 -ikugdB/OEIKcdBodfpga3csTS7MgROSR6cz8faXbauX+5v3gTt23ADq1cEmv8uXr -AvHRAosZy5Q6XkjEGB5YGV8eAlrwDPGxrancWYaLbumR9YbK+rlmM6pZW87ipxZz -R8srzJmwN0jP41ZL9c8PDHIyh8bwRLtTcm1D9SZImlJnt1ir/md2cXjbDaJWFBM5 -JDGFoqgCWjBH4d1QB7wCCZAA62RjYJsWvIjJEubSfZGL+T0yjWW06XyxV3bqxbYo -Ob8VZRzI9neWagqNdwvYkQsEjgfbKbYK7p2CNTUQ ------END CERTIFICATE----- - # Issuer: CN=SwissSign Gold CA - G2 O=SwissSign AG # Subject: CN=SwissSign Gold CA - G2 O=SwissSign AG # Label: "SwissSign Gold CA - G2" @@ -763,37 +636,6 @@ BA6+C4OmF4O5MBKgxTMVBbkN+8cFduPYSo38NBejxiEovjBFMR7HeL5YYTisO+IB ZQ== -----END CERTIFICATE----- -# Issuer: CN=Network Solutions Certificate Authority O=Network Solutions L.L.C. -# Subject: CN=Network Solutions Certificate Authority O=Network Solutions L.L.C. -# Label: "Network Solutions Certificate Authority" -# Serial: 116697915152937497490437556386812487904 -# MD5 Fingerprint: d3:f3:a6:16:c0:fa:6b:1d:59:b1:2d:96:4d:0e:11:2e -# SHA1 Fingerprint: 74:f8:a3:c3:ef:e7:b3:90:06:4b:83:90:3c:21:64:60:20:e5:df:ce -# SHA256 Fingerprint: 15:f0:ba:00:a3:ac:7a:f3:ac:88:4c:07:2b:10:11:a0:77:bd:77:c0:97:f4:01:64:b2:f8:59:8a:bd:83:86:0c ------BEGIN CERTIFICATE----- -MIID5jCCAs6gAwIBAgIQV8szb8JcFuZHFhfjkDFo4DANBgkqhkiG9w0BAQUFADBi -MQswCQYDVQQGEwJVUzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMu -MTAwLgYDVQQDEydOZXR3b3JrIFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3Jp -dHkwHhcNMDYxMjAxMDAwMDAwWhcNMjkxMjMxMjM1OTU5WjBiMQswCQYDVQQGEwJV -UzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMuMTAwLgYDVQQDEydO -ZXR3b3JrIFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEiMA0GCSqG -SIb3DQEBAQUAA4IBDwAwggEKAoIBAQDkvH6SMG3G2I4rC7xGzuAnlt7e+foS0zwz -c7MEL7xxjOWftiJgPl9dzgn/ggwbmlFQGiaJ3dVhXRncEg8tCqJDXRfQNJIg6nPP -OCwGJgl6cvf6UDL4wpPTaaIjzkGxzOTVHzbRijr4jGPiFFlp7Q3Tf2vouAPlT2rl -mGNpSAW+Lv8ztumXWWn4Zxmuk2GWRBXTcrA/vGp97Eh/jcOrqnErU2lBUzS1sLnF -BgrEsEX1QV1uiUV7PTsmjHTC5dLRfbIR1PtYMiKagMnc/Qzpf14Dl847ABSHJ3A4 -qY5usyd2mFHgBeMhqxrVhSI8KbWaFsWAqPS7azCPL0YCorEMIuDTAgMBAAGjgZcw -gZQwHQYDVR0OBBYEFCEwyfsA106Y2oeqKtCnLrFAMadMMA4GA1UdDwEB/wQEAwIB -BjAPBgNVHRMBAf8EBTADAQH/MFIGA1UdHwRLMEkwR6BFoEOGQWh0dHA6Ly9jcmwu -bmV0c29sc3NsLmNvbS9OZXR3b3JrU29sdXRpb25zQ2VydGlmaWNhdGVBdXRob3Jp -dHkuY3JsMA0GCSqGSIb3DQEBBQUAA4IBAQC7rkvnt1frf6ott3NHhWrB5KUd5Oc8 -6fRZZXe1eltajSU24HqXLjjAV2CDmAaDn7l2em5Q4LqILPxFzBiwmZVRDuwduIj/ -h1AcgsLj4DKAv6ALR8jDMe+ZZzKATxcheQxpXN5eNK4CtSbqUN9/GGUsyfJj4akH -/nxxH2szJGoeBfcFaMBqEssuXmHLrijTfsK0ZpEmXzwuJF/LWA/rKOyvEZbz3Htv -wKeI8lN3s2Berq4o2jUsbzRF0ybh3uxbTydrFny9RAQYgrOJeRcQcT16ohZO9QHN -pGxlaKFJdlxDydi8NmdspZS11My5vWo1ViHe2MPr+8ukYEywVaCge1ey ------END CERTIFICATE----- - # Issuer: CN=COMODO ECC Certification Authority O=COMODO CA Limited # Subject: CN=COMODO ECC Certification Authority O=COMODO CA Limited # Label: "COMODO ECC Certification Authority" @@ -848,36 +690,6 @@ t0QmwCbAr1UwnjvVNioZBPRcHv/PLLf/0P2HQBHVESO7SMAhqaQoLf0V+LBOK/Qw WyH8EZE0vkHve52Xdf+XlcCWWC/qu0bXu+TZLg== -----END CERTIFICATE----- -# Issuer: CN=Cybertrust Global Root O=Cybertrust, Inc -# Subject: CN=Cybertrust Global Root O=Cybertrust, Inc -# Label: "Cybertrust Global Root" -# Serial: 4835703278459682877484360 -# MD5 Fingerprint: 72:e4:4a:87:e3:69:40:80:77:ea:bc:e3:f4:ff:f0:e1 -# SHA1 Fingerprint: 5f:43:e5:b1:bf:f8:78:8c:ac:1c:c7:ca:4a:9a:c6:22:2b:cc:34:c6 -# SHA256 Fingerprint: 96:0a:df:00:63:e9:63:56:75:0c:29:65:dd:0a:08:67:da:0b:9c:bd:6e:77:71:4a:ea:fb:23:49:ab:39:3d:a3 ------BEGIN CERTIFICATE----- -MIIDoTCCAomgAwIBAgILBAAAAAABD4WqLUgwDQYJKoZIhvcNAQEFBQAwOzEYMBYG -A1UEChMPQ3liZXJ0cnVzdCwgSW5jMR8wHQYDVQQDExZDeWJlcnRydXN0IEdsb2Jh -bCBSb290MB4XDTA2MTIxNTA4MDAwMFoXDTIxMTIxNTA4MDAwMFowOzEYMBYGA1UE -ChMPQ3liZXJ0cnVzdCwgSW5jMR8wHQYDVQQDExZDeWJlcnRydXN0IEdsb2JhbCBS -b290MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA+Mi8vRRQZhP/8NN5 -7CPytxrHjoXxEnOmGaoQ25yiZXRadz5RfVb23CO21O1fWLE3TdVJDm71aofW0ozS -J8bi/zafmGWgE07GKmSb1ZASzxQG9Dvj1Ci+6A74q05IlG2OlTEQXO2iLb3VOm2y -HLtgwEZLAfVJrn5GitB0jaEMAs7u/OePuGtm839EAL9mJRQr3RAwHQeWP032a7iP -t3sMpTjr3kfb1V05/Iin89cqdPHoWqI7n1C6poxFNcJQZZXcY4Lv3b93TZxiyWNz -FtApD0mpSPCzqrdsxacwOUBdrsTiXSZT8M4cIwhhqJQZugRiQOwfOHB3EgZxpzAY -XSUnpQIDAQABo4GlMIGiMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/ -MB0GA1UdDgQWBBS2CHsNesysIEyGVjJez6tuhS1wVzA/BgNVHR8EODA2MDSgMqAw -hi5odHRwOi8vd3d3Mi5wdWJsaWMtdHJ1c3QuY29tL2NybC9jdC9jdHJvb3QuY3Js -MB8GA1UdIwQYMBaAFLYIew16zKwgTIZWMl7Pq26FLXBXMA0GCSqGSIb3DQEBBQUA -A4IBAQBW7wojoFROlZfJ+InaRcHUowAl9B8Tq7ejhVhpwjCt2BWKLePJzYFa+HMj -Wqd8BfP9IjsO0QbE2zZMcwSO5bAi5MXzLqXZI+O4Tkogp24CJJ8iYGd7ix1yCcUx -XOl5n4BHPa2hCwcUPUf/A2kaDAtE52Mlp3+yybh2hO0j9n0Hq0V+09+zv+mKts2o -omcrUtW3ZfA5TGOgkXmTUg9U3YO7n9GPp1Nzw8v/MOx8BLjYRB+TX3EJIrduPuoc -A06dGiBh+4E37F78CkWr1+cXVdCg6mCbpvbjjFspwgZgFJ0tl0ypkxWdYcQBX0jW -WL1WMRJOEcgh4LMRkWXbtKaIOM5V ------END CERTIFICATE----- - # Issuer: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority # Subject: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority # Label: "ePKI Root Certification Authority" @@ -947,67 +759,6 @@ i/nDhDwTqn6Sm1dTk/pwwpEOMfmbZ13pljheX7NzTogVZ96edhBiIL5VaZVDADlN 9u6wWk5JRFRYX0KD -----END CERTIFICATE----- -# Issuer: CN=GeoTrust Primary Certification Authority - G2 O=GeoTrust Inc. OU=(c) 2007 GeoTrust Inc. - For authorized use only -# Subject: CN=GeoTrust Primary Certification Authority - G2 O=GeoTrust Inc. OU=(c) 2007 GeoTrust Inc. - For authorized use only -# Label: "GeoTrust Primary Certification Authority - G2" -# Serial: 80682863203381065782177908751794619243 -# MD5 Fingerprint: 01:5e:d8:6b:bd:6f:3d:8e:a1:31:f8:12:e0:98:73:6a -# SHA1 Fingerprint: 8d:17:84:d5:37:f3:03:7d:ec:70:fe:57:8b:51:9a:99:e6:10:d7:b0 -# SHA256 Fingerprint: 5e:db:7a:c4:3b:82:a0:6a:87:61:e8:d7:be:49:79:eb:f2:61:1f:7d:d7:9b:f9:1c:1c:6b:56:6a:21:9e:d7:66 ------BEGIN CERTIFICATE----- -MIICrjCCAjWgAwIBAgIQPLL0SAoA4v7rJDteYD7DazAKBggqhkjOPQQDAzCBmDEL -MAkGA1UEBhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsTMChj -KSAyMDA3IEdlb1RydXN0IEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTE2 -MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFyeSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0 -eSAtIEcyMB4XDTA3MTEwNTAwMDAwMFoXDTM4MDExODIzNTk1OVowgZgxCzAJBgNV -BAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAoYykgMjAw -NyBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0BgNV -BAMTLUdlb1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBH -MjB2MBAGByqGSM49AgEGBSuBBAAiA2IABBWx6P0DFUPlrOuHNxFi79KDNlJ9RVcL -So17VDs6bl8VAsBQps8lL33KSLjHUGMcKiEIfJo22Av+0SbFWDEwKCXzXV2juLal -tJLtbCyf691DiaI8S0iRHVDsJt/WYC69IaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAO -BgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBVfNVdRVfslsq0DafwBo/q+EVXVMAoG -CCqGSM49BAMDA2cAMGQCMGSWWaboCd6LuvpaiIjwH5HTRqjySkwCY/tsXzjbLkGT -qQ7mndwxHLKgpxgceeHHNgIwOlavmnRs9vuD4DPTCF+hnMJbn0bWtsuRBmOiBucz -rD6ogRLQy7rQkgu2npaqBA+K ------END CERTIFICATE----- - -# Issuer: CN=VeriSign Universal Root Certification Authority O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2008 VeriSign, Inc. - For authorized use only -# Subject: CN=VeriSign Universal Root Certification Authority O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2008 VeriSign, Inc. - For authorized use only -# Label: "VeriSign Universal Root Certification Authority" -# Serial: 85209574734084581917763752644031726877 -# MD5 Fingerprint: 8e:ad:b5:01:aa:4d:81:e4:8c:1d:d1:e1:14:00:95:19 -# SHA1 Fingerprint: 36:79:ca:35:66:87:72:30:4d:30:a5:fb:87:3b:0f:a7:7b:b7:0d:54 -# SHA256 Fingerprint: 23:99:56:11:27:a5:71:25:de:8c:ef:ea:61:0d:df:2f:a0:78:b5:c8:06:7f:4e:82:82:90:bf:b8:60:e8:4b:3c ------BEGIN CERTIFICATE----- -MIIEuTCCA6GgAwIBAgIQQBrEZCGzEyEDDrvkEhrFHTANBgkqhkiG9w0BAQsFADCB -vTELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQL -ExZWZXJpU2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwOCBWZXJp -U2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MTgwNgYDVQQDEy9W -ZXJpU2lnbiBVbml2ZXJzYWwgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAe -Fw0wODA0MDIwMDAwMDBaFw0zNzEyMDEyMzU5NTlaMIG9MQswCQYDVQQGEwJVUzEX -MBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRydXN0 -IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAyMDA4IFZlcmlTaWduLCBJbmMuIC0gRm9y -IGF1dGhvcml6ZWQgdXNlIG9ubHkxODA2BgNVBAMTL1ZlcmlTaWduIFVuaXZlcnNh -bCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEF -AAOCAQ8AMIIBCgKCAQEAx2E3XrEBNNti1xWb/1hajCMj1mCOkdeQmIN65lgZOIzF -9uVkhbSicfvtvbnazU0AtMgtc6XHaXGVHzk8skQHnOgO+k1KxCHfKWGPMiJhgsWH -H26MfF8WIFFE0XBPV+rjHOPMee5Y2A7Cs0WTwCznmhcrewA3ekEzeOEz4vMQGn+H -LL729fdC4uW/h2KJXwBL38Xd5HVEMkE6HnFuacsLdUYI0crSK5XQz/u5QGtkjFdN -/BMReYTtXlT2NJ8IAfMQJQYXStrxHXpma5hgZqTZ79IugvHw7wnqRMkVauIDbjPT -rJ9VAMf2CGqUuV/c4DPxhGD5WycRtPwW8rtWaoAljQIDAQABo4GyMIGvMA8GA1Ud -EwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMG0GCCsGAQUFBwEMBGEwX6FdoFsw -WTBXMFUWCWltYWdlL2dpZjAhMB8wBwYFKw4DAhoEFI/l0xqGrI2Oa8PPgGrUSBgs -exkuMCUWI2h0dHA6Ly9sb2dvLnZlcmlzaWduLmNvbS92c2xvZ28uZ2lmMB0GA1Ud -DgQWBBS2d/ppSEefUxLVwuoHMnYH0ZcHGTANBgkqhkiG9w0BAQsFAAOCAQEASvj4 -sAPmLGd75JR3Y8xuTPl9Dg3cyLk1uXBPY/ok+myDjEedO2Pzmvl2MpWRsXe8rJq+ -seQxIcaBlVZaDrHC1LGmWazxY8u4TB1ZkErvkBYoH1quEPuBUDgMbMzxPcP1Y+Oz -4yHJJDnp/RVmRvQbEdBNc6N9Rvk97ahfYtTxP/jgdFcrGJ2BtMQo2pSXpXDrrB2+ -BxHw1dvd5Yzw1TKwg+ZX4o+/vqGqvz0dtdQ46tewXDpPaj+PwGZsY6rp2aQW9IHR -lRQOfc2VNNnSj3BzgXucfr2YYdhFh5iQxeuGMMY1v/D/w1WIg0vvBZIGcfK4mJO3 -7M2CYfE45k+XmCpajQ== ------END CERTIFICATE----- - # Issuer: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services) # Subject: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services) # Label: "NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny" @@ -1243,105 +994,6 @@ naM8THLCV8Sg1Mw4J87VBp6iSNnpn86CcDaTmjvfliHjWbcM2pE38P1ZWrOZyGls QyYBNWNgVYkDOnXYukrZVP/u3oDYLdE41V4tC5h9Pmzb/CaIxw== -----END CERTIFICATE----- -# Issuer: CN=Chambers of Commerce Root - 2008 O=AC Camerfirma S.A. -# Subject: CN=Chambers of Commerce Root - 2008 O=AC Camerfirma S.A. -# Label: "Chambers of Commerce Root - 2008" -# Serial: 11806822484801597146 -# MD5 Fingerprint: 5e:80:9e:84:5a:0e:65:0b:17:02:f3:55:18:2a:3e:d7 -# SHA1 Fingerprint: 78:6a:74:ac:76:ab:14:7f:9c:6a:30:50:ba:9e:a8:7e:fe:9a:ce:3c -# SHA256 Fingerprint: 06:3e:4a:fa:c4:91:df:d3:32:f3:08:9b:85:42:e9:46:17:d8:93:d7:fe:94:4e:10:a7:93:7e:e2:9d:96:93:c0 ------BEGIN CERTIFICATE----- -MIIHTzCCBTegAwIBAgIJAKPaQn6ksa7aMA0GCSqGSIb3DQEBBQUAMIGuMQswCQYD -VQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0 -IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3 -MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xKTAnBgNVBAMTIENoYW1iZXJz -IG9mIENvbW1lcmNlIFJvb3QgLSAyMDA4MB4XDTA4MDgwMTEyMjk1MFoXDTM4MDcz -MTEyMjk1MFowga4xCzAJBgNVBAYTAkVVMUMwQQYDVQQHEzpNYWRyaWQgKHNlZSBj -dXJyZW50IGFkZHJlc3MgYXQgd3d3LmNhbWVyZmlybWEuY29tL2FkZHJlc3MpMRIw -EAYDVQQFEwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENhbWVyZmlybWEgUy5BLjEp -MCcGA1UEAxMgQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdCAtIDIwMDgwggIiMA0G -CSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCvAMtwNyuAWko6bHiUfaN/Gh/2NdW9 -28sNRHI+JrKQUrpjOyhYb6WzbZSm891kDFX29ufyIiKAXuFixrYp4YFs8r/lfTJq -VKAyGVn+H4vXPWCGhSRv4xGzdz4gljUha7MI2XAuZPeEklPWDrCQiorjh40G072Q -DuKZoRuGDtqaCrsLYVAGUvGef3bsyw/QHg3PmTA9HMRFEFis1tPo1+XqxQEHd9ZR -5gN/ikilTWh1uem8nk4ZcfUyS5xtYBkL+8ydddy/Js2Pk3g5eXNeJQ7KXOt3EgfL -ZEFHcpOrUMPrCXZkNNI5t3YRCQ12RcSprj1qr7V9ZS+UWBDsXHyvfuK2GNnQm05a -Sd+pZgvMPMZ4fKecHePOjlO+Bd5gD2vlGts/4+EhySnB8esHnFIbAURRPHsl18Tl -UlRdJQfKFiC4reRB7noI/plvg6aRArBsNlVq5331lubKgdaX8ZSD6e2wsWsSaR6s -+12pxZjptFtYer49okQ6Y1nUCyXeG0+95QGezdIp1Z8XGQpvvwyQ0wlf2eOKNcx5 -Wk0ZN5K3xMGtr/R5JJqyAQuxr1yW84Ay+1w9mPGgP0revq+ULtlVmhduYJ1jbLhj -ya6BXBg14JC7vjxPNyK5fuvPnnchpj04gftI2jE9K+OJ9dC1vX7gUMQSibMjmhAx -hduub+84Mxh2EQIDAQABo4IBbDCCAWgwEgYDVR0TAQH/BAgwBgEB/wIBDDAdBgNV -HQ4EFgQU+SSsD7K1+HnA+mCIG8TZTQKeFxkwgeMGA1UdIwSB2zCB2IAU+SSsD7K1 -+HnA+mCIG8TZTQKeFxmhgbSkgbEwga4xCzAJBgNVBAYTAkVVMUMwQQYDVQQHEzpN -YWRyaWQgKHNlZSBjdXJyZW50IGFkZHJlc3MgYXQgd3d3LmNhbWVyZmlybWEuY29t -L2FkZHJlc3MpMRIwEAYDVQQFEwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENhbWVy -ZmlybWEgUy5BLjEpMCcGA1UEAxMgQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdCAt -IDIwMDiCCQCj2kJ+pLGu2jAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRV -HSAAMCowKAYIKwYBBQUHAgEWHGh0dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20w -DQYJKoZIhvcNAQEFBQADggIBAJASryI1wqM58C7e6bXpeHxIvj99RZJe6dqxGfwW -PJ+0W2aeaufDuV2I6A+tzyMP3iU6XsxPpcG1Lawk0lgH3qLPaYRgM+gQDROpI9CF -5Y57pp49chNyM/WqfcZjHwj0/gF/JM8rLFQJ3uIrbZLGOU8W6jx+ekbURWpGqOt1 -glanq6B8aBMz9p0w8G8nOSQjKpD9kCk18pPfNKXG9/jvjA9iSnyu0/VU+I22mlaH -FoI6M6taIgj3grrqLuBHmrS1RaMFO9ncLkVAO+rcf+g769HsJtg1pDDFOqxXnrN2 -pSB7+R5KBWIBpih1YJeSDW4+TTdDDZIVnBgizVGZoCkaPF+KMjNbMMeJL0eYD6MD -xvbxrN8y8NmBGuScvfaAFPDRLLmF9dijscilIeUcE5fuDr3fKanvNFNb0+RqE4QG -tjICxFKuItLcsiFCGtpA8CnJ7AoMXOLQusxI0zcKzBIKinmwPQN/aUv0NCB9szTq -jktk9T79syNnFQ0EuPAtwQlRPLJsFfClI9eDdOTlLsn+mCdCxqvGnrDQWzilm1De -fhiYtUU79nm06PcaewaD+9CL2rvHvRirCG88gGtAPxkZumWK5r7VXNM21+9AUiRg -OGcEMeyP84LG3rlV8zsxkVrctQgVrXYlCg17LofiDKYGvCYQbTed7N14jHyAxfDZ -d0jQ ------END CERTIFICATE----- - -# Issuer: CN=Global Chambersign Root - 2008 O=AC Camerfirma S.A. -# Subject: CN=Global Chambersign Root - 2008 O=AC Camerfirma S.A. -# Label: "Global Chambersign Root - 2008" -# Serial: 14541511773111788494 -# MD5 Fingerprint: 9e:80:ff:78:01:0c:2e:c1:36:bd:fe:96:90:6e:08:f3 -# SHA1 Fingerprint: 4a:bd:ee:ec:95:0d:35:9c:89:ae:c7:52:a1:2c:5b:29:f6:d6:aa:0c -# SHA256 Fingerprint: 13:63:35:43:93:34:a7:69:80:16:a0:d3:24:de:72:28:4e:07:9d:7b:52:20:bb:8f:bd:74:78:16:ee:be:ba:ca ------BEGIN CERTIFICATE----- -MIIHSTCCBTGgAwIBAgIJAMnN0+nVfSPOMA0GCSqGSIb3DQEBBQUAMIGsMQswCQYD -VQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0 -IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3 -MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xJzAlBgNVBAMTHkdsb2JhbCBD -aGFtYmVyc2lnbiBSb290IC0gMjAwODAeFw0wODA4MDExMjMxNDBaFw0zODA3MzEx -MjMxNDBaMIGsMQswCQYDVQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUgY3Vy -cmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAG -A1UEBRMJQTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xJzAl -BgNVBAMTHkdsb2JhbCBDaGFtYmVyc2lnbiBSb290IC0gMjAwODCCAiIwDQYJKoZI -hvcNAQEBBQADggIPADCCAgoCggIBAMDfVtPkOpt2RbQT2//BthmLN0EYlVJH6xed -KYiONWwGMi5HYvNJBL99RDaxccy9Wglz1dmFRP+RVyXfXjaOcNFccUMd2drvXNL7 -G706tcuto8xEpw2uIRU/uXpbknXYpBI4iRmKt4DS4jJvVpyR1ogQC7N0ZJJ0YPP2 -zxhPYLIj0Mc7zmFLmY/CDNBAspjcDahOo7kKrmCgrUVSY7pmvWjg+b4aqIG7HkF4 -ddPB/gBVsIdU6CeQNR1MM62X/JcumIS/LMmjv9GYERTtY/jKmIhYF5ntRQOXfjyG -HoiMvvKRhI9lNNgATH23MRdaKXoKGCQwoze1eqkBfSbW+Q6OWfH9GzO1KTsXO0G2 -Id3UwD2ln58fQ1DJu7xsepeY7s2MH/ucUa6LcL0nn3HAa6x9kGbo1106DbDVwo3V -yJ2dwW3Q0L9R5OP4wzg2rtandeavhENdk5IMagfeOx2YItaswTXbo6Al/3K1dh3e -beksZixShNBFks4c5eUzHdwHU1SjqoI7mjcv3N2gZOnm3b2u/GSFHTynyQbehP9r -6GsaPMWis0L7iwk+XwhSx2LE1AVxv8Rk5Pihg+g+EpuoHtQ2TS9x9o0o9oOpE9Jh -wZG7SMA0j0GMS0zbaRL/UJScIINZc+18ofLx/d33SdNDWKBWY8o9PeU1VlnpDsog -zCtLkykPAgMBAAGjggFqMIIBZjASBgNVHRMBAf8ECDAGAQH/AgEMMB0GA1UdDgQW -BBS5CcqcHtvTbDprru1U8VuTBjUuXjCB4QYDVR0jBIHZMIHWgBS5CcqcHtvTbDpr -ru1U8VuTBjUuXqGBsqSBrzCBrDELMAkGA1UEBhMCRVUxQzBBBgNVBAcTOk1hZHJp -ZCAoc2VlIGN1cnJlbnQgYWRkcmVzcyBhdCB3d3cuY2FtZXJmaXJtYS5jb20vYWRk -cmVzcykxEjAQBgNVBAUTCUE4Mjc0MzI4NzEbMBkGA1UEChMSQUMgQ2FtZXJmaXJt -YSBTLkEuMScwJQYDVQQDEx5HbG9iYWwgQ2hhbWJlcnNpZ24gUm9vdCAtIDIwMDiC -CQDJzdPp1X0jzjAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRVHSAAMCow -KAYIKwYBBQUHAgEWHGh0dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20wDQYJKoZI -hvcNAQEFBQADggIBAICIf3DekijZBZRG/5BXqfEv3xoNa/p8DhxJJHkn2EaqbylZ -UohwEurdPfWbU1Rv4WCiqAm57OtZfMY18dwY6fFn5a+6ReAJ3spED8IXDneRRXoz -X1+WLGiLwUePmJs9wOzL9dWCkoQ10b42OFZyMVtHLaoXpGNR6woBrX/sdZ7LoR/x -fxKxueRkf2fWIyr0uDldmOghp+G9PUIadJpwr2hsUF1Jz//7Dl3mLEfXgTpZALVz -a2Mg9jFFCDkO9HB+QHBaP9BrQql0PSgvAm11cpUJjUhjxsYjV5KTXjXBjfkK9yyd -Yhz2rXzdpjEetrHHfoUm+qRqtdpjMNHvkzeyZi99Bffnt0uYlDXA2TopwZ2yUDMd -SqlapskD7+3056huirRXhOukP9DuqqqHW2Pok+JrqNS4cnhrG+055F3Lm6qH1U9O -AP7Zap88MQ8oAgF9mOinsKJknnn4SPIVqczmyETrP3iZ8ntxPjzxmKfFGBI/5rso -M0LpRQp8bfKGeS/Fghl9CYl8slR2iK7ewfPM4W7bMdaTrpmg7yVqc5iJWzouE4ge -v8CSlDQb4ye3ix5vQv/n6TebUB0tovkC7stYWDpxvGjjqsGvHCgfotwjZT+B6q6Z -09gwzxMNTxXJhLynSC34MCN32EZLeW32jO06f2ARePTpm67VVMB0gNELQp/B ------END CERTIFICATE----- - # Issuer: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc. # Subject: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc. # Label: "Go Daddy Root Certificate Authority - G2" @@ -1640,78 +1292,6 @@ t/2jioSgrGK+KwmHNPBqAbubKVY8/gA3zyNs8U6qtnRGEmyR7jTV7JqR50S+kDFy SjnRBUkLp7Y3gaVdjKozXoEofKd9J+sAro03 -----END CERTIFICATE----- -# Issuer: CN=EC-ACC O=Agencia Catalana de Certificacio (NIF Q-0801176-I) OU=Serveis Publics de Certificacio/Vegeu https://www.catcert.net/verarrel (c)03/Jerarquia Entitats de Certificacio Catalanes -# Subject: CN=EC-ACC O=Agencia Catalana de Certificacio (NIF Q-0801176-I) OU=Serveis Publics de Certificacio/Vegeu https://www.catcert.net/verarrel (c)03/Jerarquia Entitats de Certificacio Catalanes -# Label: "EC-ACC" -# Serial: -23701579247955709139626555126524820479 -# MD5 Fingerprint: eb:f5:9d:29:0d:61:f9:42:1f:7c:c2:ba:6d:e3:15:09 -# SHA1 Fingerprint: 28:90:3a:63:5b:52:80:fa:e6:77:4c:0b:6d:a7:d6:ba:a6:4a:f2:e8 -# SHA256 Fingerprint: 88:49:7f:01:60:2f:31:54:24:6a:e2:8c:4d:5a:ef:10:f1:d8:7e:bb:76:62:6f:4a:e0:b7:f9:5b:a7:96:87:99 ------BEGIN CERTIFICATE----- -MIIFVjCCBD6gAwIBAgIQ7is969Qh3hSoYqwE893EATANBgkqhkiG9w0BAQUFADCB -8zELMAkGA1UEBhMCRVMxOzA5BgNVBAoTMkFnZW5jaWEgQ2F0YWxhbmEgZGUgQ2Vy -dGlmaWNhY2lvIChOSUYgUS0wODAxMTc2LUkpMSgwJgYDVQQLEx9TZXJ2ZWlzIFB1 -YmxpY3MgZGUgQ2VydGlmaWNhY2lvMTUwMwYDVQQLEyxWZWdldSBodHRwczovL3d3 -dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbCAoYykwMzE1MDMGA1UECxMsSmVyYXJxdWlh -IEVudGl0YXRzIGRlIENlcnRpZmljYWNpbyBDYXRhbGFuZXMxDzANBgNVBAMTBkVD -LUFDQzAeFw0wMzAxMDcyMzAwMDBaFw0zMTAxMDcyMjU5NTlaMIHzMQswCQYDVQQG -EwJFUzE7MDkGA1UEChMyQWdlbmNpYSBDYXRhbGFuYSBkZSBDZXJ0aWZpY2FjaW8g -KE5JRiBRLTA4MDExNzYtSSkxKDAmBgNVBAsTH1NlcnZlaXMgUHVibGljcyBkZSBD -ZXJ0aWZpY2FjaW8xNTAzBgNVBAsTLFZlZ2V1IGh0dHBzOi8vd3d3LmNhdGNlcnQu -bmV0L3ZlcmFycmVsIChjKTAzMTUwMwYDVQQLEyxKZXJhcnF1aWEgRW50aXRhdHMg -ZGUgQ2VydGlmaWNhY2lvIENhdGFsYW5lczEPMA0GA1UEAxMGRUMtQUNDMIIBIjAN -BgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsyLHT+KXQpWIR4NA9h0X84NzJB5R -85iKw5K4/0CQBXCHYMkAqbWUZRkiFRfCQ2xmRJoNBD45b6VLeqpjt4pEndljkYRm -4CgPukLjbo73FCeTae6RDqNfDrHrZqJyTxIThmV6PttPB/SnCWDaOkKZx7J/sxaV -HMf5NLWUhdWZXqBIoH7nF2W4onW4HvPlQn2v7fOKSGRdghST2MDk/7NQcvJ29rNd -QlB50JQ+awwAvthrDk4q7D7SzIKiGGUzE3eeml0aE9jD2z3Il3rucO2n5nzbcc8t -lGLfbdb1OL4/pYUKGbio2Al1QnDE6u/LDsg0qBIimAy4E5S2S+zw0JDnJwIDAQAB -o4HjMIHgMB0GA1UdEQQWMBSBEmVjX2FjY0BjYXRjZXJ0Lm5ldDAPBgNVHRMBAf8E -BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUoMOLRKo3pUW/l4Ba0fF4 -opvpXY0wfwYDVR0gBHgwdjB0BgsrBgEEAfV4AQMBCjBlMCwGCCsGAQUFBwIBFiBo -dHRwczovL3d3dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbDA1BggrBgEFBQcCAjApGidW -ZWdldSBodHRwczovL3d3dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbCAwDQYJKoZIhvcN -AQEFBQADggEBAKBIW4IB9k1IuDlVNZyAelOZ1Vr/sXE7zDkJlF7W2u++AVtd0x7Y -/X1PzaBB4DSTv8vihpw3kpBWHNzrKQXlxJ7HNd+KDM3FIUPpqojlNcAZQmNaAl6k -SBg6hW/cnbw/nZzBh7h6YQjpdwt/cKt63dmXLGQehb+8dJahw3oS7AwaboMMPOhy -Rp/7SNVel+axofjk70YllJyJ22k4vuxcDlbHZVHlUIiIv0LVKz3l+bqeLrPK9HOS -Agu+TGbrIP65y7WZf+a2E/rKS03Z7lNGBjvGTq2TWoF+bCpLagVFjPIhpDGQh2xl -nJ2lYJU6Un/10asIbvPuW/mIPX64b24D5EI= ------END CERTIFICATE----- - -# Issuer: CN=Hellenic Academic and Research Institutions RootCA 2011 O=Hellenic Academic and Research Institutions Cert. Authority -# Subject: CN=Hellenic Academic and Research Institutions RootCA 2011 O=Hellenic Academic and Research Institutions Cert. Authority -# Label: "Hellenic Academic and Research Institutions RootCA 2011" -# Serial: 0 -# MD5 Fingerprint: 73:9f:4c:4b:73:5b:79:e9:fa:ba:1c:ef:6e:cb:d5:c9 -# SHA1 Fingerprint: fe:45:65:9b:79:03:5b:98:a1:61:b5:51:2e:ac:da:58:09:48:22:4d -# SHA256 Fingerprint: bc:10:4f:15:a4:8b:e7:09:dc:a5:42:a7:e1:d4:b9:df:6f:05:45:27:e8:02:ea:a9:2d:59:54:44:25:8a:fe:71 ------BEGIN CERTIFICATE----- -MIIEMTCCAxmgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBlTELMAkGA1UEBhMCR1Ix -RDBCBgNVBAoTO0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1 -dGlvbnMgQ2VydC4gQXV0aG9yaXR5MUAwPgYDVQQDEzdIZWxsZW5pYyBBY2FkZW1p -YyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25zIFJvb3RDQSAyMDExMB4XDTExMTIw -NjEzNDk1MloXDTMxMTIwMTEzNDk1MlowgZUxCzAJBgNVBAYTAkdSMUQwQgYDVQQK -EztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25zIENl -cnQuIEF1dGhvcml0eTFAMD4GA1UEAxM3SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl -c2VhcmNoIEluc3RpdHV0aW9ucyBSb290Q0EgMjAxMTCCASIwDQYJKoZIhvcNAQEB -BQADggEPADCCAQoCggEBAKlTAOMupvaO+mDYLZU++CwqVE7NuYRhlFhPjz2L5EPz -dYmNUeTDN9KKiE15HrcS3UN4SoqS5tdI1Q+kOilENbgH9mgdVc04UfCMJDGFr4PJ -fel3r+0ae50X+bOdOFAPplp5kYCvN66m0zH7tSYJnTxa71HFK9+WXesyHgLacEns -bgzImjeN9/E2YEsmLIKe0HjzDQ9jpFEw4fkrJxIH2Oq9GGKYsFk3fb7u8yBRQlqD -75O6aRXxYp2fmTmCobd0LovUxQt7L/DICto9eQqakxylKHJzkUOap9FNhYS5qXSP -FEDH3N6sQWRstBmbAmNtJGSPRLIl6s5ddAxjMlyNh+UCAwEAAaOBiTCBhjAPBgNV -HRMBAf8EBTADAQH/MAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQUppFC/RNhSiOeCKQp -5dgTBCPuQSUwRwYDVR0eBEAwPqA8MAWCAy5ncjAFggMuZXUwBoIELmVkdTAGggQu -b3JnMAWBAy5ncjAFgQMuZXUwBoEELmVkdTAGgQQub3JnMA0GCSqGSIb3DQEBBQUA -A4IBAQAf73lB4XtuP7KMhjdCSk4cNx6NZrokgclPEg8hwAOXhiVtXdMiKahsog2p -6z0GW5k6x8zDmjR/qw7IThzh+uTczQ2+vyT+bOdrwg3IBp5OjWEopmr95fZi6hg8 -TqBTnbI6nOulnJEWtk2C4AwFSKls9cz4y51JtPACpf1wA+2KIaWuE4ZJwzNzvoc7 -dIsXRSZMFpGD/md9zU1jZ/rzAxKWeAaNsWftjj++n08C9bMJL/NMh98qy5V8Acys -Nnq/onN694/BtZqhFLKPM58N7yLcZnuEvUUXBj08yrl3NI/K6s8/MT7jiOOASSXI -l7WdmplNsDz4SgCbZN2fOUvRJ9e4 ------END CERTIFICATE----- - # Issuer: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 # Subject: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 # Label: "Actalis Authentication Root CA" @@ -1753,35 +1333,6 @@ LysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9vwGYT7JZVEc+NHt4bVaT LnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg== -----END CERTIFICATE----- -# Issuer: O=Trustis Limited OU=Trustis FPS Root CA -# Subject: O=Trustis Limited OU=Trustis FPS Root CA -# Label: "Trustis FPS Root CA" -# Serial: 36053640375399034304724988975563710553 -# MD5 Fingerprint: 30:c9:e7:1e:6b:e6:14:eb:65:b2:16:69:20:31:67:4d -# SHA1 Fingerprint: 3b:c0:38:0b:33:c3:f6:a6:0c:86:15:22:93:d9:df:f5:4b:81:c0:04 -# SHA256 Fingerprint: c1:b4:82:99:ab:a5:20:8f:e9:63:0a:ce:55:ca:68:a0:3e:da:5a:51:9c:88:02:a0:d3:a6:73:be:8f:8e:55:7d ------BEGIN CERTIFICATE----- -MIIDZzCCAk+gAwIBAgIQGx+ttiD5JNM2a/fH8YygWTANBgkqhkiG9w0BAQUFADBF -MQswCQYDVQQGEwJHQjEYMBYGA1UEChMPVHJ1c3RpcyBMaW1pdGVkMRwwGgYDVQQL -ExNUcnVzdGlzIEZQUyBSb290IENBMB4XDTAzMTIyMzEyMTQwNloXDTI0MDEyMTEx -MzY1NFowRTELMAkGA1UEBhMCR0IxGDAWBgNVBAoTD1RydXN0aXMgTGltaXRlZDEc -MBoGA1UECxMTVHJ1c3RpcyBGUFMgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQAD -ggEPADCCAQoCggEBAMVQe547NdDfxIzNjpvto8A2mfRC6qc+gIMPpqdZh8mQRUN+ -AOqGeSoDvT03mYlmt+WKVoaTnGhLaASMk5MCPjDSNzoiYYkchU59j9WvezX2fihH -iTHcDnlkH5nSW7r+f2C/revnPDgpai/lkQtV/+xvWNUtyd5MZnGPDNcE2gfmHhjj -vSkCqPoc4Vu5g6hBSLwacY3nYuUtsuvffM/bq1rKMfFMIvMFE/eC+XN5DL7XSxzA -0RU8k0Fk0ea+IxciAIleH2ulrG6nS4zto3Lmr2NNL4XSFDWaLk6M6jKYKIahkQlB -OrTh4/L68MkKokHdqeMDx4gVOxzUGpTXn2RZEm0CAwEAAaNTMFEwDwYDVR0TAQH/ -BAUwAwEB/zAfBgNVHSMEGDAWgBS6+nEleYtXQSUhhgtx67JkDoshZzAdBgNVHQ4E -FgQUuvpxJXmLV0ElIYYLceuyZA6LIWcwDQYJKoZIhvcNAQEFBQADggEBAH5Y//01 -GX2cGE+esCu8jowU/yyg2kdbw++BLa8F6nRIW/M+TgfHbcWzk88iNVy2P3UnXwmW -zaD+vkAMXBJV+JOCyinpXj9WV4s4NvdFGkwozZ5BuO1WTISkQMi4sKUraXAEasP4 -1BIy+Q7DsdwyhEQsb8tGD+pmQQ9P8Vilpg0ND2HepZ5dfWWhPBfnqFVO76DH7cZE -f1T1o+CP8HxVIo8ptoGj4W1OLBuAZ+ytIJ8MYmHVl/9D7S3B2l0pKoU/rGXuhg8F -jZBf3+6f9L/uHfuY5H+QK4R4EA5sSVPvFVtlRkpdr7r7OnIdzfYliB6XzCGcKQEN -ZetX2fNXlrtIzYE= ------END CERTIFICATE----- - # Issuer: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 # Subject: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 # Label: "Buypass Class 2 Root CA" @@ -2600,27 +2151,6 @@ zzuqQhFkoJ2UOQIReVx7Hfpkue4WQrO/isIJxOzksU0CMQDpKmFHjFJKS04YcPbW RNZu9YO6bVi9JNlWSOrvxKJGgYhqOkbRqZtNyWHa0V1Xahg= -----END CERTIFICATE----- -# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 -# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 -# Label: "GlobalSign ECC Root CA - R4" -# Serial: 14367148294922964480859022125800977897474 -# MD5 Fingerprint: 20:f0:27:68:d1:7e:a0:9d:0e:e6:2a:ca:df:5c:89:8e -# SHA1 Fingerprint: 69:69:56:2e:40:80:f4:24:a1:e7:19:9f:14:ba:f3:ee:58:ab:6a:bb -# SHA256 Fingerprint: be:c9:49:11:c2:95:56:76:db:6c:0a:55:09:86:d7:6e:3b:a0:05:66:7c:44:2c:97:62:b4:fb:b7:73:de:22:8c ------BEGIN CERTIFICATE----- -MIIB4TCCAYegAwIBAgIRKjikHJYKBN5CsiilC+g0mAIwCgYIKoZIzj0EAwIwUDEk -MCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI0MRMwEQYDVQQKEwpH -bG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWduMB4XDTEyMTExMzAwMDAwMFoX -DTM4MDExOTAzMTQwN1owUDEkMCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBD -QSAtIFI0MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWdu -MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEuMZ5049sJQ6fLjkZHAOkrprlOQcJ -FspjsbmG+IpXwVfOQvpzofdlQv8ewQCybnMO/8ch5RikqtlxP6jUuc6MHaNCMEAw -DgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFFSwe61F -uOJAf/sKbvu+M8k8o4TVMAoGCCqGSM49BAMCA0gAMEUCIQDckqGgE6bPA7DmxCGX -kPoUVy0D7O48027KqGx2vKLeuwIgJ6iFJzWbVsaj8kfSt24bAgAXqmemFZHe+pTs -ewv4n4Q= ------END CERTIFICATE----- - # Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R5 # Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R5 # Label: "GlobalSign ECC Root CA - R5" @@ -2643,86 +2173,6 @@ KoZIzj0EAwMDaAAwZQIxAOVpEslu28YxuglB4Zf4+/2a4n0Sye18ZNPLBSWLVtmg xwy8p2Fp8fc74SrL+SvzZpA3 -----END CERTIFICATE----- -# Issuer: CN=Staat der Nederlanden Root CA - G3 O=Staat der Nederlanden -# Subject: CN=Staat der Nederlanden Root CA - G3 O=Staat der Nederlanden -# Label: "Staat der Nederlanden Root CA - G3" -# Serial: 10003001 -# MD5 Fingerprint: 0b:46:67:07:db:10:2f:19:8c:35:50:60:d1:0b:f4:37 -# SHA1 Fingerprint: d8:eb:6b:41:51:92:59:e0:f3:e7:85:00:c0:3d:b6:88:97:c9:ee:fc -# SHA256 Fingerprint: 3c:4f:b0:b9:5a:b8:b3:00:32:f4:32:b8:6f:53:5f:e1:72:c1:85:d0:fd:39:86:58:37:cf:36:18:7f:a6:f4:28 ------BEGIN CERTIFICATE----- -MIIFdDCCA1ygAwIBAgIEAJiiOTANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJO -TDEeMBwGA1UECgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSswKQYDVQQDDCJTdGFh -dCBkZXIgTmVkZXJsYW5kZW4gUm9vdCBDQSAtIEczMB4XDTEzMTExNDExMjg0MloX -DTI4MTExMzIzMDAwMFowWjELMAkGA1UEBhMCTkwxHjAcBgNVBAoMFVN0YWF0IGRl -ciBOZWRlcmxhbmRlbjErMCkGA1UEAwwiU3RhYXQgZGVyIE5lZGVybGFuZGVuIFJv -b3QgQ0EgLSBHMzCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL4yolQP -cPssXFnrbMSkUeiFKrPMSjTysF/zDsccPVMeiAho2G89rcKezIJnByeHaHE6n3WW -IkYFsO2tx1ueKt6c/DrGlaf1F2cY5y9JCAxcz+bMNO14+1Cx3Gsy8KL+tjzk7FqX -xz8ecAgwoNzFs21v0IJyEavSgWhZghe3eJJg+szeP4TrjTgzkApyI/o1zCZxMdFy -KJLZWyNtZrVtB0LrpjPOktvA9mxjeM3KTj215VKb8b475lRgsGYeCasH/lSJEULR -9yS6YHgamPfJEf0WwTUaVHXvQ9Plrk7O53vDxk5hUUurmkVLoR9BvUhTFXFkC4az -5S6+zqQbwSmEorXLCCN2QyIkHxcE1G6cxvx/K2Ya7Irl1s9N9WMJtxU51nus6+N8 -6U78dULI7ViVDAZCopz35HCz33JvWjdAidiFpNfxC95DGdRKWCyMijmev4SH8RY7 -Ngzp07TKbBlBUgmhHbBqv4LvcFEhMtwFdozL92TkA1CvjJFnq8Xy7ljY3r735zHP -bMk7ccHViLVlvMDoFxcHErVc0qsgk7TmgoNwNsXNo42ti+yjwUOH5kPiNL6VizXt -BznaqB16nzaeErAMZRKQFWDZJkBE41ZgpRDUajz9QdwOWke275dhdU/Z/seyHdTt -XUmzqWrLZoQT1Vyg3N9udwbRcXXIV2+vD3dbAgMBAAGjQjBAMA8GA1UdEwEB/wQF -MAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRUrfrHkleuyjWcLhL75Lpd -INyUVzANBgkqhkiG9w0BAQsFAAOCAgEAMJmdBTLIXg47mAE6iqTnB/d6+Oea31BD -U5cqPco8R5gu4RV78ZLzYdqQJRZlwJ9UXQ4DO1t3ApyEtg2YXzTdO2PCwyiBwpwp -LiniyMMB8jPqKqrMCQj3ZWfGzd/TtiunvczRDnBfuCPRy5FOCvTIeuXZYzbB1N/8 -Ipf3YF3qKS9Ysr1YvY2WTxB1v0h7PVGHoTx0IsL8B3+A3MSs/mrBcDCw6Y5p4ixp -gZQJut3+TcCDjJRYwEYgr5wfAvg1VUkvRtTA8KCWAg8zxXHzniN9lLf9OtMJgwYh -/WA9rjLA0u6NpvDntIJ8CsxwyXmA+P5M9zWEGYox+wrZ13+b8KKaa8MFSu1BYBQw -0aoRQm7TIwIEC8Zl3d1Sd9qBa7Ko+gE4uZbqKmxnl4mUnrzhVNXkanjvSr0rmj1A -fsbAddJu+2gw7OyLnflJNZoaLNmzlTnVHpL3prllL+U9bTpITAjc5CgSKL59NVzq -4BZ+Extq1z7XnvwtdbLBFNUjA9tbbws+eC8N3jONFrdI54OagQ97wUNNVQQXOEpR -1VmiiXTTn74eS9fGbbeIJG9gkaSChVtWQbzQRKtqE77RLFi3EjNYsjdj3BP1lB0/ -QFH1T/U67cjF68IeHRaVesd+QnGTbksVtzDfqu1XhUisHWrdOWnk4Xl4vs4Fv6EM -94B7IWcnMFk= ------END CERTIFICATE----- - -# Issuer: CN=Staat der Nederlanden EV Root CA O=Staat der Nederlanden -# Subject: CN=Staat der Nederlanden EV Root CA O=Staat der Nederlanden -# Label: "Staat der Nederlanden EV Root CA" -# Serial: 10000013 -# MD5 Fingerprint: fc:06:af:7b:e8:1a:f1:9a:b4:e8:d2:70:1f:c0:f5:ba -# SHA1 Fingerprint: 76:e2:7e:c1:4f:db:82:c1:c0:a6:75:b5:05:be:3d:29:b4:ed:db:bb -# SHA256 Fingerprint: 4d:24:91:41:4c:fe:95:67:46:ec:4c:ef:a6:cf:6f:72:e2:8a:13:29:43:2f:9d:8a:90:7a:c4:cb:5d:ad:c1:5a ------BEGIN CERTIFICATE----- -MIIFcDCCA1igAwIBAgIEAJiWjTANBgkqhkiG9w0BAQsFADBYMQswCQYDVQQGEwJO -TDEeMBwGA1UECgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSkwJwYDVQQDDCBTdGFh -dCBkZXIgTmVkZXJsYW5kZW4gRVYgUm9vdCBDQTAeFw0xMDEyMDgxMTE5MjlaFw0y -MjEyMDgxMTEwMjhaMFgxCzAJBgNVBAYTAk5MMR4wHAYDVQQKDBVTdGFhdCBkZXIg -TmVkZXJsYW5kZW4xKTAnBgNVBAMMIFN0YWF0IGRlciBOZWRlcmxhbmRlbiBFViBS -b290IENBMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA48d+ifkkSzrS -M4M1LGns3Amk41GoJSt5uAg94JG6hIXGhaTK5skuU6TJJB79VWZxXSzFYGgEt9nC -UiY4iKTWO0Cmws0/zZiTs1QUWJZV1VD+hq2kY39ch/aO5ieSZxeSAgMs3NZmdO3d -Z//BYY1jTw+bbRcwJu+r0h8QoPnFfxZpgQNH7R5ojXKhTbImxrpsX23Wr9GxE46p -rfNeaXUmGD5BKyF/7otdBwadQ8QpCiv8Kj6GyzyDOvnJDdrFmeK8eEEzduG/L13l -pJhQDBXd4Pqcfzho0LKmeqfRMb1+ilgnQ7O6M5HTp5gVXJrm0w912fxBmJc+qiXb -j5IusHsMX/FjqTf5m3VpTCgmJdrV8hJwRVXj33NeN/UhbJCONVrJ0yPr08C+eKxC -KFhmpUZtcALXEPlLVPxdhkqHz3/KRawRWrUgUY0viEeXOcDPusBCAUCZSCELa6fS -/ZbV0b5GnUngC6agIk440ME8MLxwjyx1zNDFjFE7PZQIZCZhfbnDZY8UnCHQqv0X -cgOPvZuM5l5Tnrmd74K74bzickFbIZTTRTeU0d8JOV3nI6qaHcptqAqGhYqCvkIH -1vI4gnPah1vlPNOePqc7nvQDs/nxfRN0Av+7oeX6AHkcpmZBiFxgV6YuCcS6/ZrP -px9Aw7vMWgpVSzs4dlG4Y4uElBbmVvMCAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB -/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFP6rAJCYniT8qcwaivsnuL8wbqg7 -MA0GCSqGSIb3DQEBCwUAA4ICAQDPdyxuVr5Os7aEAJSrR8kN0nbHhp8dB9O2tLsI -eK9p0gtJ3jPFrK3CiAJ9Brc1AsFgyb/E6JTe1NOpEyVa/m6irn0F3H3zbPB+po3u -2dfOWBfoqSmuc0iH55vKbimhZF8ZE/euBhD/UcabTVUlT5OZEAFTdfETzsemQUHS -v4ilf0X8rLiltTMMgsT7B/Zq5SWEXwbKwYY5EdtYzXc7LMJMD16a4/CrPmEbUCTC -wPTxGfARKbalGAKb12NMcIxHowNDXLldRqANb/9Zjr7dn3LDWyvfjFvO5QxGbJKy -CqNMVEIYFRIYvdr8unRu/8G2oGTYqV9Vrp9canaW2HNnh/tNf1zuacpzEPuKqf2e -vTY4SUmH9A4U8OmHuD+nT3pajnnUk+S7aFKErGzp85hwVXIy+TSrK0m1zSBi5Dp6 -Z2Orltxtrpfs/J92VoguZs9btsmksNcFuuEnL5O7Jiqik7Ab846+HUCjuTaPPoIa -Gl6I6lD4WeKDRikL40Rc4ZW2aZCaFG+XroHPaO+Zmr615+F/+PoTRxZMzG0IQOeL -eG9QgkRQP2YGiqtDhFZKDyAthg710tvSeopLzaXoTvFeJiUBWSOgftL2fiFX1ye8 -FVdMpEbB4IMeDExNH08GGeL5qPQ6gqGyeUN51q1veieQA6TqJIc/2b3Z6fJfUEkc -7uzXLg== ------END CERTIFICATE----- - # Issuer: CN=IdenTrust Commercial Root CA 1 O=IdenTrust # Subject: CN=IdenTrust Commercial Root CA 1 O=IdenTrust # Label: "IdenTrust Commercial Root CA 1" @@ -3330,116 +2780,6 @@ T8p+ck0LcIymSLumoRT2+1hEmRSuqguTaaApJUqlyyvdimYHFngVV3Eb7PVHhPOe MTd61X8kreS8/f3MboPoDKi3QWwH3b08hpcv0g== -----END CERTIFICATE----- -# Issuer: CN=TrustCor RootCert CA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority -# Subject: CN=TrustCor RootCert CA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority -# Label: "TrustCor RootCert CA-1" -# Serial: 15752444095811006489 -# MD5 Fingerprint: 6e:85:f1:dc:1a:00:d3:22:d5:b2:b2:ac:6b:37:05:45 -# SHA1 Fingerprint: ff:bd:cd:e7:82:c8:43:5e:3c:6f:26:86:5c:ca:a8:3a:45:5b:c3:0a -# SHA256 Fingerprint: d4:0e:9c:86:cd:8f:e4:68:c1:77:69:59:f4:9e:a7:74:fa:54:86:84:b6:c4:06:f3:90:92:61:f4:dc:e2:57:5c ------BEGIN CERTIFICATE----- -MIIEMDCCAxigAwIBAgIJANqb7HHzA7AZMA0GCSqGSIb3DQEBCwUAMIGkMQswCQYD -VQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEgQ2l0eTEk -MCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYDVQQLDB5U -cnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxHzAdBgNVBAMMFlRydXN0Q29y -IFJvb3RDZXJ0IENBLTEwHhcNMTYwMjA0MTIzMjE2WhcNMjkxMjMxMTcyMzE2WjCB -pDELMAkGA1UEBhMCUEExDzANBgNVBAgMBlBhbmFtYTEUMBIGA1UEBwwLUGFuYW1h -IENpdHkxJDAiBgNVBAoMG1RydXN0Q29yIFN5c3RlbXMgUy4gZGUgUi5MLjEnMCUG -A1UECwweVHJ1c3RDb3IgQ2VydGlmaWNhdGUgQXV0aG9yaXR5MR8wHQYDVQQDDBZU -cnVzdENvciBSb290Q2VydCBDQS0xMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB -CgKCAQEAv463leLCJhJrMxnHQFgKq1mqjQCj/IDHUHuO1CAmujIS2CNUSSUQIpid -RtLByZ5OGy4sDjjzGiVoHKZaBeYei0i/mJZ0PmnK6bV4pQa81QBeCQryJ3pS/C3V -seq0iWEk8xoT26nPUu0MJLq5nux+AHT6k61sKZKuUbS701e/s/OojZz0JEsq1pme -9J7+wH5COucLlVPat2gOkEz7cD+PSiyU8ybdY2mplNgQTsVHCJCZGxdNuWxu72CV -EY4hgLW9oHPY0LJ3xEXqWib7ZnZ2+AYfYW0PVcWDtxBWcgYHpfOxGgMFZA6dWorW -hnAbJN7+KIor0Gqw/Hqi3LJ5DotlDwIDAQABo2MwYTAdBgNVHQ4EFgQU7mtJPHo/ -DeOxCbeKyKsZn3MzUOcwHwYDVR0jBBgwFoAU7mtJPHo/DeOxCbeKyKsZn3MzUOcw -DwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYwDQYJKoZIhvcNAQELBQAD -ggEBACUY1JGPE+6PHh0RU9otRCkZoB5rMZ5NDp6tPVxBb5UrJKF5mDo4Nvu7Zp5I -/5CQ7z3UuJu0h3U/IJvOcs+hVcFNZKIZBqEHMwwLKeXx6quj7LUKdJDHfXLy11yf -ke+Ri7fc7Waiz45mO7yfOgLgJ90WmMCV1Aqk5IGadZQ1nJBfiDcGrVmVCrDRZ9MZ -yonnMlo2HD6CqFqTvsbQZJG2z9m2GM/bftJlo6bEjhcxwft+dtvTheNYsnd6djts -L1Ac59v2Z3kf9YKVmgenFK+P3CghZwnS1k1aHBkcjndcw5QkPTJrS37UeJSDvjdN -zl/HHk484IkzlQsPpTLWPFp5LBk= ------END CERTIFICATE----- - -# Issuer: CN=TrustCor RootCert CA-2 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority -# Subject: CN=TrustCor RootCert CA-2 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority -# Label: "TrustCor RootCert CA-2" -# Serial: 2711694510199101698 -# MD5 Fingerprint: a2:e1:f8:18:0b:ba:45:d5:c7:41:2a:bb:37:52:45:64 -# SHA1 Fingerprint: b8:be:6d:cb:56:f1:55:b9:63:d4:12:ca:4e:06:34:c7:94:b2:1c:c0 -# SHA256 Fingerprint: 07:53:e9:40:37:8c:1b:d5:e3:83:6e:39:5d:ae:a5:cb:83:9e:50:46:f1:bd:0e:ae:19:51:cf:10:fe:c7:c9:65 ------BEGIN CERTIFICATE----- -MIIGLzCCBBegAwIBAgIIJaHfyjPLWQIwDQYJKoZIhvcNAQELBQAwgaQxCzAJBgNV -BAYTAlBBMQ8wDQYDVQQIDAZQYW5hbWExFDASBgNVBAcMC1BhbmFtYSBDaXR5MSQw -IgYDVQQKDBtUcnVzdENvciBTeXN0ZW1zIFMuIGRlIFIuTC4xJzAlBgNVBAsMHlRy -dXN0Q29yIENlcnRpZmljYXRlIEF1dGhvcml0eTEfMB0GA1UEAwwWVHJ1c3RDb3Ig -Um9vdENlcnQgQ0EtMjAeFw0xNjAyMDQxMjMyMjNaFw0zNDEyMzExNzI2MzlaMIGk -MQswCQYDVQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEg -Q2l0eTEkMCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYD -VQQLDB5UcnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxHzAdBgNVBAMMFlRy -dXN0Q29yIFJvb3RDZXJ0IENBLTIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIK -AoICAQCnIG7CKqJiJJWQdsg4foDSq8GbZQWU9MEKENUCrO2fk8eHyLAnK0IMPQo+ -QVqedd2NyuCb7GgypGmSaIwLgQ5WoD4a3SwlFIIvl9NkRvRUqdw6VC0xK5mC8tkq -1+9xALgxpL56JAfDQiDyitSSBBtlVkxs1Pu2YVpHI7TYabS3OtB0PAx1oYxOdqHp -2yqlO/rOsP9+aij9JxzIsekp8VduZLTQwRVtDr4uDkbIXvRR/u8OYzo7cbrPb1nK -DOObXUm4TOJXsZiKQlecdu/vvdFoqNL0Cbt3Nb4lggjEFixEIFapRBF37120Hape -az6LMvYHL1cEksr1/p3C6eizjkxLAjHZ5DxIgif3GIJ2SDpxsROhOdUuxTTCHWKF -3wP+TfSvPd9cW436cOGlfifHhi5qjxLGhF5DUVCcGZt45vz27Ud+ez1m7xMTiF88 -oWP7+ayHNZ/zgp6kPwqcMWmLmaSISo5uZk3vFsQPeSghYA2FFn3XVDjxklb9tTNM -g9zXEJ9L/cb4Qr26fHMC4P99zVvh1Kxhe1fVSntb1IVYJ12/+CtgrKAmrhQhJ8Z3 -mjOAPF5GP/fDsaOGM8boXg25NSyqRsGFAnWAoOsk+xWq5Gd/bnc/9ASKL3x74xdh -8N0JqSDIvgmk0H5Ew7IwSjiqqewYmgeCK9u4nBit2uBGF6zPXQIDAQABo2MwYTAd -BgNVHQ4EFgQU2f4hQG6UnrybPZx9mCAZ5YwwYrIwHwYDVR0jBBgwFoAU2f4hQG6U -nrybPZx9mCAZ5YwwYrIwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYw -DQYJKoZIhvcNAQELBQADggIBAJ5Fngw7tu/hOsh80QA9z+LqBrWyOrsGS2h60COX -dKcs8AjYeVrXWoSK2BKaG9l9XE1wxaX5q+WjiYndAfrs3fnpkpfbsEZC89NiqpX+ -MWcUaViQCqoL7jcjx1BRtPV+nuN79+TMQjItSQzL/0kMmx40/W5ulop5A7Zv2wnL -/V9lFDfhOPXzYRZY5LVtDQsEGz9QLX+zx3oaFoBg+Iof6Rsqxvm6ARppv9JYx1RX -CI/hOWB3S6xZhBqI8d3LT3jX5+EzLfzuQfogsL7L9ziUwOHQhQ+77Sxzq+3+knYa -ZH9bDTMJBzN7Bj8RpFxwPIXAz+OQqIN3+tvmxYxoZxBnpVIt8MSZj3+/0WvitUfW -2dCFmU2Umw9Lje4AWkcdEQOsQRivh7dvDDqPys/cA8GiCcjl/YBeyGBCARsaU1q7 -N6a3vLqE6R5sGtRk2tRD/pOLS/IseRYQ1JMLiI+h2IYURpFHmygk71dSTlxCnKr3 -Sewn6EAes6aJInKc9Q0ztFijMDvd1GpUk74aTfOTlPf8hAs/hCBcNANExdqtvArB -As8e5ZTZ845b2EzwnexhF7sUMlQMAimTHpKG9n/v55IFDlndmQguLvqcAFLTxWYp -5KeXRKQOKIETNcX2b2TmQcTVL8w0RSXPQQCWPUouwpaYT05KnJe32x+SMsj/D1Fu -1uwJ ------END CERTIFICATE----- - -# Issuer: CN=TrustCor ECA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority -# Subject: CN=TrustCor ECA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority -# Label: "TrustCor ECA-1" -# Serial: 9548242946988625984 -# MD5 Fingerprint: 27:92:23:1d:0a:f5:40:7c:e9:e6:6b:9d:d8:f5:e7:6c -# SHA1 Fingerprint: 58:d1:df:95:95:67:6b:63:c0:f0:5b:1c:17:4d:8b:84:0b:c8:78:bd -# SHA256 Fingerprint: 5a:88:5d:b1:9c:01:d9:12:c5:75:93:88:93:8c:af:bb:df:03:1a:b2:d4:8e:91:ee:15:58:9b:42:97:1d:03:9c ------BEGIN CERTIFICATE----- -MIIEIDCCAwigAwIBAgIJAISCLF8cYtBAMA0GCSqGSIb3DQEBCwUAMIGcMQswCQYD -VQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEgQ2l0eTEk -MCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYDVQQLDB5U -cnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxFzAVBgNVBAMMDlRydXN0Q29y -IEVDQS0xMB4XDTE2MDIwNDEyMzIzM1oXDTI5MTIzMTE3MjgwN1owgZwxCzAJBgNV -BAYTAlBBMQ8wDQYDVQQIDAZQYW5hbWExFDASBgNVBAcMC1BhbmFtYSBDaXR5MSQw -IgYDVQQKDBtUcnVzdENvciBTeXN0ZW1zIFMuIGRlIFIuTC4xJzAlBgNVBAsMHlRy -dXN0Q29yIENlcnRpZmljYXRlIEF1dGhvcml0eTEXMBUGA1UEAwwOVHJ1c3RDb3Ig -RUNBLTEwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDPj+ARtZ+odnbb -3w9U73NjKYKtR8aja+3+XzP4Q1HpGjORMRegdMTUpwHmspI+ap3tDvl0mEDTPwOA -BoJA6LHip1GnHYMma6ve+heRK9jGrB6xnhkB1Zem6g23xFUfJ3zSCNV2HykVh0A5 -3ThFEXXQmqc04L/NyFIduUd+Dbi7xgz2c1cWWn5DkR9VOsZtRASqnKmcp0yJF4Ou -owReUoCLHhIlERnXDH19MURB6tuvsBzvgdAsxZohmz3tQjtQJvLsznFhBmIhVE5/ -wZ0+fyCMgMsq2JdiyIMzkX2woloPV+g7zPIlstR8L+xNxqE6FXrntl019fZISjZF -ZtS6mFjBAgMBAAGjYzBhMB0GA1UdDgQWBBREnkj1zG1I1KBLf/5ZJC+Dl5mahjAf -BgNVHSMEGDAWgBREnkj1zG1I1KBLf/5ZJC+Dl5mahjAPBgNVHRMBAf8EBTADAQH/ -MA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQsFAAOCAQEABT41XBVwm8nHc2Fv -civUwo/yQ10CzsSUuZQRg2dd4mdsdXa/uwyqNsatR5Nj3B5+1t4u/ukZMjgDfxT2 -AHMsWbEhBuH7rBiVDKP/mZb3Kyeb1STMHd3BOuCYRLDE5D53sXOpZCz2HAF8P11F -hcCF5yWPldwX8zyfGm6wyuMdKulMY/okYWLW2n62HGz1Ah3UKt1VkOsqEUc8Ll50 -soIipX1TH0XsJ5F95yIW6MBoNtjG8U+ARDL54dHRHareqKucBK+tIA5kmE2la8BI -WJZpTdwHjFGTot+fDz2LYLSCjaoITmJF4PkL0uDgPFveXHEnJcLmA4GLEFPjx1Wi -tJ/X5g== ------END CERTIFICATE----- - # Issuer: CN=SSL.com Root Certification Authority RSA O=SSL Corporation # Subject: CN=SSL.com Root Certification Authority RSA O=SSL Corporation # Label: "SSL.com Root Certification Authority RSA" @@ -3635,126 +2975,6 @@ rYy0UGYwEAYJKwYBBAGCNxUBBAMCAQAwCgYIKoZIzj0EAwMDaAAwZQIwJsdpW9zV Mgj/mkkCtojeFK9dbJlxjRo/i9fgojaGHAeCOnZT/cKi7e97sIBPWA9LUzm9 -----END CERTIFICATE----- -# Issuer: CN=GTS Root R1 O=Google Trust Services LLC -# Subject: CN=GTS Root R1 O=Google Trust Services LLC -# Label: "GTS Root R1" -# Serial: 146587175971765017618439757810265552097 -# MD5 Fingerprint: 82:1a:ef:d4:d2:4a:f2:9f:e2:3d:97:06:14:70:72:85 -# SHA1 Fingerprint: e1:c9:50:e6:ef:22:f8:4c:56:45:72:8b:92:20:60:d7:d5:a7:a3:e8 -# SHA256 Fingerprint: 2a:57:54:71:e3:13:40:bc:21:58:1c:bd:2c:f1:3e:15:84:63:20:3e:ce:94:bc:f9:d3:cc:19:6b:f0:9a:54:72 ------BEGIN CERTIFICATE----- -MIIFWjCCA0KgAwIBAgIQbkepxUtHDA3sM9CJuRz04TANBgkqhkiG9w0BAQwFADBH -MQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExM -QzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIy -MDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNl -cnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwggIiMA0GCSqGSIb3DQEB -AQUAA4ICDwAwggIKAoICAQC2EQKLHuOhd5s73L+UPreVp0A8of2C+X0yBoJx9vaM -f/vo27xqLpeXo4xL+Sv2sfnOhB2x+cWX3u+58qPpvBKJXqeqUqv4IyfLpLGcY9vX -mX7wCl7raKb0xlpHDU0QM+NOsROjyBhsS+z8CZDfnWQpJSMHobTSPS5g4M/SCYe7 -zUjwTcLCeoiKu7rPWRnWr4+wB7CeMfGCwcDfLqZtbBkOtdh+JhpFAz2weaSUKK0P -fyblqAj+lug8aJRT7oM6iCsVlgmy4HqMLnXWnOunVmSPlk9orj2XwoSPwLxAwAtc -vfaHszVsrBhQf4TgTM2S0yDpM7xSma8ytSmzJSq0SPly4cpk9+aCEI3oncKKiPo4 -Zor8Y/kB+Xj9e1x3+naH+uzfsQ55lVe0vSbv1gHR6xYKu44LtcXFilWr06zqkUsp -zBmkMiVOKvFlRNACzqrOSbTqn3yDsEB750Orp2yjj32JgfpMpf/VjsPOS+C12LOO -Rc92wO1AK/1TD7Cn1TsNsYqiA94xrcx36m97PtbfkSIS5r762DL8EGMUUXLeXdYW -k70paDPvOmbsB4om3xPXV2V4J95eSRQAogB/mqghtqmxlbCluQ0WEdrHbEg8QOB+ -DVrNVjzRlwW5y0vtOUucxD/SVRNuJLDWcfr0wbrM7Rv1/oFB2ACYPTrIrnqYNxgF -lQIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV -HQ4EFgQU5K8rJnEaK0gnhS9SZizv8IkTcT4wDQYJKoZIhvcNAQEMBQADggIBADiW -Cu49tJYeX++dnAsznyvgyv3SjgofQXSlfKqE1OXyHuY3UjKcC9FhHb8owbZEKTV1 -d5iyfNm9dKyKaOOpMQkpAWBz40d8U6iQSifvS9efk+eCNs6aaAyC58/UEBZvXw6Z -XPYfcX3v73svfuo21pdwCxXu11xWajOl40k4DLh9+42FpLFZXvRq4d2h9mREruZR -gyFmxhE+885H7pwoHyXa/6xmld01D1zvICxi/ZG6qcz8WpyTgYMpl0p8WnK0OdC3 -d8t5/Wk6kjftbjhlRn7pYL15iJdfOBL07q9bgsiG1eGZbYwE8na6SfZu6W0eX6Dv -J4J2QPim01hcDyxC2kLGe4g0x8HYRZvBPsVhHdljUEn2NIVq4BjFbkerQUIpm/Zg -DdIx02OYI5NaAIFItO/Nis3Jz5nu2Z6qNuFoS3FJFDYoOj0dzpqPJeaAcWErtXvM -+SUWgeExX6GjfhaknBZqlxi9dnKlC54dNuYvoS++cJEPqOba+MSSQGwlfnuzCdyy -F62ARPBopY+Udf90WuioAnwMCeKpSwughQtiue+hMZL77/ZRBIls6Kl0obsXs7X9 -SQ98POyDGCBDTtWTurQ0sR8WNh8M5mQ5Fkzc4P4dyKliPUDqysU0ArSuiYgzNdws -E3PYJ/HQcu51OyLemGhmW/HGY0dVHLqlCFF1pkgl ------END CERTIFICATE----- - -# Issuer: CN=GTS Root R2 O=Google Trust Services LLC -# Subject: CN=GTS Root R2 O=Google Trust Services LLC -# Label: "GTS Root R2" -# Serial: 146587176055767053814479386953112547951 -# MD5 Fingerprint: 44:ed:9a:0e:a4:09:3b:00:f2:ae:4c:a3:c6:61:b0:8b -# SHA1 Fingerprint: d2:73:96:2a:2a:5e:39:9f:73:3f:e1:c7:1e:64:3f:03:38:34:fc:4d -# SHA256 Fingerprint: c4:5d:7b:b0:8e:6d:67:e6:2e:42:35:11:0b:56:4e:5f:78:fd:92:ef:05:8c:84:0a:ea:4e:64:55:d7:58:5c:60 ------BEGIN CERTIFICATE----- -MIIFWjCCA0KgAwIBAgIQbkepxlqz5yDFMJo/aFLybzANBgkqhkiG9w0BAQwFADBH -MQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExM -QzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIy -MDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNl -cnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwggIiMA0GCSqGSIb3DQEB -AQUAA4ICDwAwggIKAoICAQDO3v2m++zsFDQ8BwZabFn3GTXd98GdVarTzTukk3Lv -CvptnfbwhYBboUhSnznFt+4orO/LdmgUud+tAWyZH8QiHZ/+cnfgLFuv5AS/T3Kg -GjSY6Dlo7JUle3ah5mm5hRm9iYz+re026nO8/4Piy33B0s5Ks40FnotJk9/BW9Bu -XvAuMC6C/Pq8tBcKSOWIm8Wba96wyrQD8Nr0kLhlZPdcTK3ofmZemde4wj7I0BOd -re7kRXuJVfeKH2JShBKzwkCX44ofR5GmdFrS+LFjKBC4swm4VndAoiaYecb+3yXu -PuWgf9RhD1FLPD+M2uFwdNjCaKH5wQzpoeJ/u1U8dgbuak7MkogwTZq9TwtImoS1 -mKPV+3PBV2HdKFZ1E66HjucMUQkQdYhMvI35ezzUIkgfKtzra7tEscszcTJGr61K -8YzodDqs5xoic4DSMPclQsciOzsSrZYuxsN2B6ogtzVJV+mSSeh2FnIxZyuWfoqj -x5RWIr9qS34BIbIjMt/kmkRtWVtd9QCgHJvGeJeNkP+byKq0rxFROV7Z+2et1VsR -nTKaG73VululycslaVNVJ1zgyjbLiGH7HrfQy+4W+9OmTN6SpdTi3/UGVN4unUu0 -kzCqgc7dGtxRcw1PcOnlthYhGXmy5okLdWTK1au8CcEYof/UVKGFPP0UJAOyh9Ok -twIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV -HQ4EFgQUu//KjiOfT5nK2+JopqUVJxce2Q4wDQYJKoZIhvcNAQEMBQADggIBALZp -8KZ3/p7uC4Gt4cCpx/k1HUCCq+YEtN/L9x0Pg/B+E02NjO7jMyLDOfxA325BS0JT -vhaI8dI4XsRomRyYUpOM52jtG2pzegVATX9lO9ZY8c6DR2Dj/5epnGB3GFW1fgiT -z9D2PGcDFWEJ+YF59exTpJ/JjwGLc8R3dtyDovUMSRqodt6Sm2T4syzFJ9MHwAiA -pJiS4wGWAqoC7o87xdFtCjMwc3i5T1QWvwsHoaRc5svJXISPD+AVdyx+Jn7axEvb -pxZ3B7DNdehyQtaVhJ2Gg/LkkM0JR9SLA3DaWsYDQvTtN6LwG1BUSw7YhN4ZKJmB -R64JGz9I0cNv4rBgF/XuIwKl2gBbbZCr7qLpGzvpx0QnRY5rn/WkhLx3+WuXrD5R -RaIRpsyF7gpo8j5QOHokYh4XIDdtak23CZvJ/KRY9bb7nE4Yu5UC56GtmwfuNmsk -0jmGwZODUNKBRqhfYlcsu2xkiAhu7xNUX90txGdj08+JN7+dIPT7eoOboB6BAFDC -5AwiWVIQ7UNWhwD4FFKnHYuTjKJNRn8nxnGbJN7k2oaLDX5rIMHAnuFl2GqjpuiF -izoHCBy69Y9Vmhh1fuXsgWbRIXOhNUQLgD1bnF5vKheW0YMjiGZt5obicDIvUiLn -yOd/xCxgXS/Dr55FBcOEArf9LAhST4Ldo/DUhgkC ------END CERTIFICATE----- - -# Issuer: CN=GTS Root R3 O=Google Trust Services LLC -# Subject: CN=GTS Root R3 O=Google Trust Services LLC -# Label: "GTS Root R3" -# Serial: 146587176140553309517047991083707763997 -# MD5 Fingerprint: 1a:79:5b:6b:04:52:9c:5d:c7:74:33:1b:25:9a:f9:25 -# SHA1 Fingerprint: 30:d4:24:6f:07:ff:db:91:89:8a:0b:e9:49:66:11:eb:8c:5e:46:e5 -# SHA256 Fingerprint: 15:d5:b8:77:46:19:ea:7d:54:ce:1c:a6:d0:b0:c4:03:e0:37:a9:17:f1:31:e8:a0:4e:1e:6b:7a:71:ba:bc:e5 ------BEGIN CERTIFICATE----- -MIICDDCCAZGgAwIBAgIQbkepx2ypcyRAiQ8DVd2NHTAKBggqhkjOPQQDAzBHMQsw -CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU -MBIGA1UEAxMLR1RTIFJvb3QgUjMwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw -MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp -Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjMwdjAQBgcqhkjOPQIBBgUrgQQA -IgNiAAQfTzOHMymKoYTey8chWEGJ6ladK0uFxh1MJ7x/JlFyb+Kf1qPKzEUURout -736GjOyxfi//qXGdGIRFBEFVbivqJn+7kAHjSxm65FSWRQmx1WyRRK2EE46ajA2A -DDL24CejQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud -DgQWBBTB8Sa6oC2uhYHP0/EqEr24Cmf9vDAKBggqhkjOPQQDAwNpADBmAjEAgFuk -fCPAlaUs3L6JbyO5o91lAFJekazInXJ0glMLfalAvWhgxeG4VDvBNhcl2MG9AjEA -njWSdIUlUfUk7GRSJFClH9voy8l27OyCbvWFGFPouOOaKaqW04MjyaR7YbPMAuhd ------END CERTIFICATE----- - -# Issuer: CN=GTS Root R4 O=Google Trust Services LLC -# Subject: CN=GTS Root R4 O=Google Trust Services LLC -# Label: "GTS Root R4" -# Serial: 146587176229350439916519468929765261721 -# MD5 Fingerprint: 5d:b6:6a:c4:60:17:24:6a:1a:99:a8:4b:ee:5e:b4:26 -# SHA1 Fingerprint: 2a:1d:60:27:d9:4a:b1:0a:1c:4d:91:5c:cd:33:a0:cb:3e:2d:54:cb -# SHA256 Fingerprint: 71:cc:a5:39:1f:9e:79:4b:04:80:25:30:b3:63:e1:21:da:8a:30:43:bb:26:66:2f:ea:4d:ca:7f:c9:51:a4:bd ------BEGIN CERTIFICATE----- -MIICCjCCAZGgAwIBAgIQbkepyIuUtui7OyrYorLBmTAKBggqhkjOPQQDAzBHMQsw -CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU -MBIGA1UEAxMLR1RTIFJvb3QgUjQwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw -MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp -Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjQwdjAQBgcqhkjOPQIBBgUrgQQA -IgNiAATzdHOnaItgrkO4NcWBMHtLSZ37wWHO5t5GvWvVYRg1rkDdc/eJkTBa6zzu -hXyiQHY7qca4R9gq55KRanPpsXI5nymfopjTX15YhmUPoYRlBtHci8nHc8iMai/l -xKvRHYqjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud -DgQWBBSATNbrdP9JNqPV2Py1PsVq8JQdjDAKBggqhkjOPQQDAwNnADBkAjBqUFJ0 -CMRw3J5QdCHojXohw0+WbhXRIjVhLfoIN+4Zba3bssx9BzT1YBkstTTZbyACMANx -sbqjYAuG7ZoIapVon+Kz4ZNkfF6Tpt95LY2F45TPI11xzPKwTdb+mciUqXWi4w== ------END CERTIFICATE----- - # Issuer: CN=UCA Global G2 Root O=UniTrust # Subject: CN=UCA Global G2 Root O=UniTrust # Label: "UCA Global G2 Root" @@ -4323,3 +3543,1047 @@ LBT/DShycpWbXgnbiUSYqqFJu3FS8r/2/yehNq+4tneI3TqkbZs0kNwUXTC/t+sX dh2ajcQGjTa3FPOdVGm3jjzVpG2Tgbet9r1ke8LJaDmgkpzNNIaRkPpkUZ3+/uul 9XXeifdy -----END CERTIFICATE----- + +# Issuer: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres +# Subject: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres +# Label: "AC RAIZ FNMT-RCM SERVIDORES SEGUROS" +# Serial: 131542671362353147877283741781055151509 +# MD5 Fingerprint: 19:36:9c:52:03:2f:d2:d1:bb:23:cc:dd:1e:12:55:bb +# SHA1 Fingerprint: 62:ff:d9:9e:c0:65:0d:03:ce:75:93:d2:ed:3f:2d:32:c9:e3:e5:4a +# SHA256 Fingerprint: 55:41:53:b1:3d:2c:f9:dd:b7:53:bf:be:1a:4e:0a:e0:8d:0a:a4:18:70:58:fe:60:a2:b8:62:b2:e4:b8:7b:cb +-----BEGIN CERTIFICATE----- +MIICbjCCAfOgAwIBAgIQYvYybOXE42hcG2LdnC6dlTAKBggqhkjOPQQDAzB4MQsw +CQYDVQQGEwJFUzERMA8GA1UECgwIRk5NVC1SQ00xDjAMBgNVBAsMBUNlcmVzMRgw +FgYDVQRhDA9WQVRFUy1RMjgyNjAwNEoxLDAqBgNVBAMMI0FDIFJBSVogRk5NVC1S +Q00gU0VSVklET1JFUyBTRUdVUk9TMB4XDTE4MTIyMDA5MzczM1oXDTQzMTIyMDA5 +MzczM1oweDELMAkGA1UEBhMCRVMxETAPBgNVBAoMCEZOTVQtUkNNMQ4wDAYDVQQL +DAVDZXJlczEYMBYGA1UEYQwPVkFURVMtUTI4MjYwMDRKMSwwKgYDVQQDDCNBQyBS +QUlaIEZOTVQtUkNNIFNFUlZJRE9SRVMgU0VHVVJPUzB2MBAGByqGSM49AgEGBSuB +BAAiA2IABPa6V1PIyqvfNkpSIeSX0oNnnvBlUdBeh8dHsVnyV0ebAAKTRBdp20LH +sbI6GA60XYyzZl2hNPk2LEnb80b8s0RpRBNm/dfF/a82Tc4DTQdxz69qBdKiQ1oK +Um8BA06Oi6NCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYD +VR0OBBYEFAG5L++/EYZg8k/QQW6rcx/n0m5JMAoGCCqGSM49BAMDA2kAMGYCMQCu +SuMrQMN0EfKVrRYj3k4MGuZdpSRea0R7/DjiT8ucRRcRTBQnJlU5dUoDzBOQn5IC +MQD6SmxgiHPz7riYYqnOK8LZiqZwMR2vsJRM60/G49HzYqc8/5MuB1xJAWdpEgJy +v+c= +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign Root R46 O=GlobalSign nv-sa +# Subject: CN=GlobalSign Root R46 O=GlobalSign nv-sa +# Label: "GlobalSign Root R46" +# Serial: 1552617688466950547958867513931858518042577 +# MD5 Fingerprint: c4:14:30:e4:fa:66:43:94:2a:6a:1b:24:5f:19:d0:ef +# SHA1 Fingerprint: 53:a2:b0:4b:ca:6b:d6:45:e6:39:8a:8e:c4:0d:d2:bf:77:c3:a2:90 +# SHA256 Fingerprint: 4f:a3:12:6d:8d:3a:11:d1:c4:85:5a:4f:80:7c:ba:d6:cf:91:9d:3a:5a:88:b0:3b:ea:2c:63:72:d9:3c:40:c9 +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgISEdK7udcjGJ5AXwqdLdDfJWfRMA0GCSqGSIb3DQEBDAUA +MEYxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYD +VQQDExNHbG9iYWxTaWduIFJvb3QgUjQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMy +MDAwMDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYt +c2ExHDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBSNDYwggIiMA0GCSqGSIb3DQEB +AQUAA4ICDwAwggIKAoICAQCsrHQy6LNl5brtQyYdpokNRbopiLKkHWPd08EsCVeJ +OaFV6Wc0dwxu5FUdUiXSE2te4R2pt32JMl8Nnp8semNgQB+msLZ4j5lUlghYruQG +vGIFAha/r6gjA7aUD7xubMLL1aa7DOn2wQL7Id5m3RerdELv8HQvJfTqa1VbkNud +316HCkD7rRlr+/fKYIje2sGP1q7Vf9Q8g+7XFkyDRTNrJ9CG0Bwta/OrffGFqfUo +0q3v84RLHIf8E6M6cqJaESvWJ3En7YEtbWaBkoe0G1h6zD8K+kZPTXhc+CtI4wSE +y132tGqzZfxCnlEmIyDLPRT5ge1lFgBPGmSXZgjPjHvjK8Cd+RTyG/FWaha/LIWF +zXg4mutCagI0GIMXTpRW+LaCtfOW3T3zvn8gdz57GSNrLNRyc0NXfeD412lPFzYE ++cCQYDdF3uYM2HSNrpyibXRdQr4G9dlkbgIQrImwTDsHTUB+JMWKmIJ5jqSngiCN +I/onccnfxkF0oE32kRbcRoxfKWMxWXEM2G/CtjJ9++ZdU6Z+Ffy7dXxd7Pj2Fxzs +x2sZy/N78CsHpdlseVR2bJ0cpm4O6XkMqCNqo98bMDGfsVR7/mrLZqrcZdCinkqa +ByFrgY/bxFn63iLABJzjqls2k+g9vXqhnQt2sQvHnf3PmKgGwvgqo6GDoLclcqUC +4wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV +HQ4EFgQUA1yrc4GHqMywptWU4jaWSf8FmSwwDQYJKoZIhvcNAQEMBQADggIBAHx4 +7PYCLLtbfpIrXTncvtgdokIzTfnvpCo7RGkerNlFo048p9gkUbJUHJNOxO97k4Vg +JuoJSOD1u8fpaNK7ajFxzHmuEajwmf3lH7wvqMxX63bEIaZHU1VNaL8FpO7XJqti +2kM3S+LGteWygxk6x9PbTZ4IevPuzz5i+6zoYMzRx6Fcg0XERczzF2sUyQQCPtIk +pnnpHs6i58FZFZ8d4kuaPp92CC1r2LpXFNqD6v6MVenQTqnMdzGxRBF6XLE+0xRF +FRhiJBPSy03OXIPBNvIQtQ6IbbjhVp+J3pZmOUdkLG5NrmJ7v2B0GbhWrJKsFjLt +rWhV/pi60zTe9Mlhww6G9kuEYO4Ne7UyWHmRVSyBQ7N0H3qqJZ4d16GLuc1CLgSk +ZoNNiTW2bKg2SnkheCLQQrzRQDGQob4Ez8pn7fXwgNNgyYMqIgXQBztSvwyeqiv5 +u+YfjyW6hY0XHgL+XVAEV8/+LbzvXMAaq7afJMbfc2hIkCwU9D9SGuTSyxTDYWnP +4vkYxboznxSjBF25cfe1lNj2M8FawTSLfJvdkzrnE6JwYZ+vj+vYxXX4M2bUdGc6 +N3ec592kD3ZDZopD8p/7DEJ4Y9HiD2971KE9dJeFt0g5QdYg/NA6s/rob8SKunE3 +vouXsXgxT7PntgMTzlSdriVZzH81Xwj3QEUxeCp6 +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign Root E46 O=GlobalSign nv-sa +# Subject: CN=GlobalSign Root E46 O=GlobalSign nv-sa +# Label: "GlobalSign Root E46" +# Serial: 1552617690338932563915843282459653771421763 +# MD5 Fingerprint: b5:b8:66:ed:de:08:83:e3:c9:e2:01:34:06:ac:51:6f +# SHA1 Fingerprint: 39:b4:6c:d5:fe:80:06:eb:e2:2f:4a:bb:08:33:a0:af:db:b9:dd:84 +# SHA256 Fingerprint: cb:b9:c4:4d:84:b8:04:3e:10:50:ea:31:a6:9f:51:49:55:d7:bf:d2:e2:c6:b4:93:01:01:9a:d6:1d:9f:50:58 +-----BEGIN CERTIFICATE----- +MIICCzCCAZGgAwIBAgISEdK7ujNu1LzmJGjFDYQdmOhDMAoGCCqGSM49BAMDMEYx +CzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYDVQQD +ExNHbG9iYWxTaWduIFJvb3QgRTQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMyMDAw +MDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYtc2Ex +HDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBFNDYwdjAQBgcqhkjOPQIBBgUrgQQA +IgNiAAScDrHPt+ieUnd1NPqlRqetMhkytAepJ8qUuwzSChDH2omwlwxwEwkBjtjq +R+q+soArzfwoDdusvKSGN+1wCAB16pMLey5SnCNoIwZD7JIvU4Tb+0cUB+hflGdd +yXqBPCCjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud +DgQWBBQxCpCPtsad0kRLgLWi5h+xEk8blTAKBggqhkjOPQQDAwNoADBlAjEA31SQ +7Zvvi5QCkxeCmb6zniz2C5GMn0oUsfZkvLtoURMMA/cVi4RguYv/Uo7njLwcAjA8 ++RHUjE7AwWHCFUyqqx0LMV87HOIAl0Qx5v5zli/altP+CAezNIm8BZ/3Hobui3A= +-----END CERTIFICATE----- + +# Issuer: CN=GLOBALTRUST 2020 O=e-commerce monitoring GmbH +# Subject: CN=GLOBALTRUST 2020 O=e-commerce monitoring GmbH +# Label: "GLOBALTRUST 2020" +# Serial: 109160994242082918454945253 +# MD5 Fingerprint: 8a:c7:6f:cb:6d:e3:cc:a2:f1:7c:83:fa:0e:78:d7:e8 +# SHA1 Fingerprint: d0:67:c1:13:51:01:0c:aa:d0:c7:6a:65:37:31:16:26:4f:53:71:a2 +# SHA256 Fingerprint: 9a:29:6a:51:82:d1:d4:51:a2:e3:7f:43:9b:74:da:af:a2:67:52:33:29:f9:0f:9a:0d:20:07:c3:34:e2:3c:9a +-----BEGIN CERTIFICATE----- +MIIFgjCCA2qgAwIBAgILWku9WvtPilv6ZeUwDQYJKoZIhvcNAQELBQAwTTELMAkG +A1UEBhMCQVQxIzAhBgNVBAoTGmUtY29tbWVyY2UgbW9uaXRvcmluZyBHbWJIMRkw +FwYDVQQDExBHTE9CQUxUUlVTVCAyMDIwMB4XDTIwMDIxMDAwMDAwMFoXDTQwMDYx +MDAwMDAwMFowTTELMAkGA1UEBhMCQVQxIzAhBgNVBAoTGmUtY29tbWVyY2UgbW9u +aXRvcmluZyBHbWJIMRkwFwYDVQQDExBHTE9CQUxUUlVTVCAyMDIwMIICIjANBgkq +hkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAri5WrRsc7/aVj6B3GyvTY4+ETUWiD59b +RatZe1E0+eyLinjF3WuvvcTfk0Uev5E4C64OFudBc/jbu9G4UeDLgztzOG53ig9Z +YybNpyrOVPu44sB8R85gfD+yc/LAGbaKkoc1DZAoouQVBGM+uq/ufF7MpotQsjj3 +QWPKzv9pj2gOlTblzLmMCcpL3TGQlsjMH/1WljTbjhzqLL6FLmPdqqmV0/0plRPw +yJiT2S0WR5ARg6I6IqIoV6Lr/sCMKKCmfecqQjuCgGOlYx8ZzHyyZqjC0203b+J+ +BlHZRYQfEs4kUmSFC0iAToexIiIwquuuvuAC4EDosEKAA1GqtH6qRNdDYfOiaxaJ +SaSjpCuKAsR49GiKweR6NrFvG5Ybd0mN1MkGco/PU+PcF4UgStyYJ9ORJitHHmkH +r96i5OTUawuzXnzUJIBHKWk7buis/UDr2O1xcSvy6Fgd60GXIsUf1DnQJ4+H4xj0 +4KlGDfV0OoIu0G4skaMxXDtG6nsEEFZegB31pWXogvziB4xiRfUg3kZwhqG8k9Me +dKZssCz3AwyIDMvUclOGvGBG85hqwvG/Q/lwIHfKN0F5VVJjjVsSn8VoxIidrPIw +q7ejMZdnrY8XD2zHc+0klGvIg5rQmjdJBKuxFshsSUktq6HQjJLyQUp5ISXbY9e2 +nKd+Qmn7OmMCAwEAAaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AQYwHQYDVR0OBBYEFNwuH9FhN3nkq9XVsxJxaD1qaJwiMB8GA1UdIwQYMBaAFNwu +H9FhN3nkq9XVsxJxaD1qaJwiMA0GCSqGSIb3DQEBCwUAA4ICAQCR8EICaEDuw2jA +VC/f7GLDw56KoDEoqoOOpFaWEhCGVrqXctJUMHytGdUdaG/7FELYjQ7ztdGl4wJC +XtzoRlgHNQIw4Lx0SsFDKv/bGtCwr2zD/cuz9X9tAy5ZVp0tLTWMstZDFyySCstd +6IwPS3BD0IL/qMy/pJTAvoe9iuOTe8aPmxadJ2W8esVCgmxcB9CpwYhgROmYhRZf ++I/KARDOJcP5YBugxZfD0yyIMaK9MOzQ0MAS8cE54+X1+NZK3TTN+2/BT+MAi1bi +kvcoskJ3ciNnxz8RFbLEAwW+uxF7Cr+obuf/WEPPm2eggAe2HcqtbepBEX4tdJP7 +wry+UUTF72glJ4DjyKDUEuzZpTcdN3y0kcra1LGWge9oXHYQSa9+pTeAsRxSvTOB +TI/53WXZFM2KJVj04sWDpQmQ1GwUY7VA3+vA/MRYfg0UFodUJ25W5HCEuGwyEn6C +MUO+1918oa2u1qsgEu8KwxCMSZY13At1XrFP1U80DhEgB3VDRemjEdqso5nCtnkn +4rnvyOL2NSl6dPrFf4IFYqYK6miyeUcGbvJXqBUzxvd4Sj1Ce2t+/vdG6tHrju+I +aFvowdlxfv1k7/9nR4hYJS8+hge9+6jlgqispdNpQ80xiEmEU5LAsTkbOYMBMMTy +qfrQA71yN2BWHzZ8vTmR9W0Nv3vXkg== +-----END CERTIFICATE----- + +# Issuer: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz +# Subject: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz +# Label: "ANF Secure Server Root CA" +# Serial: 996390341000653745 +# MD5 Fingerprint: 26:a6:44:5a:d9:af:4e:2f:b2:1d:b6:65:b0:4e:e8:96 +# SHA1 Fingerprint: 5b:6e:68:d0:cc:15:b6:a0:5f:1e:c1:5f:ae:02:fc:6b:2f:5d:6f:74 +# SHA256 Fingerprint: fb:8f:ec:75:91:69:b9:10:6b:1e:51:16:44:c6:18:c5:13:04:37:3f:6c:06:43:08:8d:8b:ef:fd:1b:99:75:99 +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Subject: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Label: "Certum EC-384 CA" +# Serial: 160250656287871593594747141429395092468 +# MD5 Fingerprint: b6:65:b3:96:60:97:12:a1:ec:4e:e1:3d:a3:c6:c9:f1 +# SHA1 Fingerprint: f3:3e:78:3c:ac:df:f4:a2:cc:ac:67:55:69:56:d7:e5:16:3c:e1:ed +# SHA256 Fingerprint: 6b:32:80:85:62:53:18:aa:50:d1:73:c9:8d:8b:da:09:d5:7e:27:41:3d:11:4c:f7:87:a0:f5:d0:6c:03:0c:f6 +-----BEGIN CERTIFICATE----- +MIICZTCCAeugAwIBAgIQeI8nXIESUiClBNAt3bpz9DAKBggqhkjOPQQDAzB0MQsw +CQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBTLkEuMScw +JQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAXBgNVBAMT +EENlcnR1bSBFQy0zODQgQ0EwHhcNMTgwMzI2MDcyNDU0WhcNNDMwMzI2MDcyNDU0 +WjB0MQswCQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBT +LkEuMScwJQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAX +BgNVBAMTEENlcnR1bSBFQy0zODQgQ0EwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAATE +KI6rGFtqvm5kN2PkzeyrOvfMobgOgknXhimfoZTy42B4mIF4Bk3y7JoOV2CDn7Tm +Fy8as10CW4kjPMIRBSqniBMY81CE1700LCeJVf/OTOffph8oxPBUw7l8t1Ot68Kj +QjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI0GZnQkdjrzife81r1HfS+8 +EF9LMA4GA1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNoADBlAjADVS2m5hjEfO/J +UG7BJw+ch69u1RsIGL2SKcHvlJF40jocVYli5RsJHrpka/F2tNQCMQC0QoSZ/6vn +nvuRlydd3LBbMHHOXjgaatkl5+r3YZJW+OraNsKHZZYuciUvf9/DE8k= +-----END CERTIFICATE----- + +# Issuer: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Subject: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Label: "Certum Trusted Root CA" +# Serial: 40870380103424195783807378461123655149 +# MD5 Fingerprint: 51:e1:c2:e7:fe:4c:84:af:59:0e:2f:f4:54:6f:ea:29 +# SHA1 Fingerprint: c8:83:44:c0:18:ae:9f:cc:f1:87:b7:8f:22:d1:c5:d7:45:84:ba:e5 +# SHA256 Fingerprint: fe:76:96:57:38:55:77:3e:37:a9:5e:7a:d4:d9:cc:96:c3:01:57:c1:5d:31:76:5b:a9:b1:57:04:e1:ae:78:fd +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique +# Subject: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique +# Label: "TunTrust Root CA" +# Serial: 108534058042236574382096126452369648152337120275 +# MD5 Fingerprint: 85:13:b9:90:5b:36:5c:b6:5e:b8:5a:f8:e0:31:57:b4 +# SHA1 Fingerprint: cf:e9:70:84:0f:e0:73:0f:9d:f6:0c:7f:2c:4b:ee:20:46:34:9c:bb +# SHA256 Fingerprint: 2e:44:10:2a:b5:8c:b8:54:19:45:1c:8e:19:d9:ac:f3:66:2c:af:bc:61:4b:6a:53:96:0a:30:f7:d0:e2:eb:41 +-----BEGIN CERTIFICATE----- +MIIFszCCA5ugAwIBAgIUEwLV4kBMkkaGFmddtLu7sms+/BMwDQYJKoZIhvcNAQEL +BQAwYTELMAkGA1UEBhMCVE4xNzA1BgNVBAoMLkFnZW5jZSBOYXRpb25hbGUgZGUg +Q2VydGlmaWNhdGlvbiBFbGVjdHJvbmlxdWUxGTAXBgNVBAMMEFR1blRydXN0IFJv +b3QgQ0EwHhcNMTkwNDI2MDg1NzU2WhcNNDQwNDI2MDg1NzU2WjBhMQswCQYDVQQG +EwJUTjE3MDUGA1UECgwuQWdlbmNlIE5hdGlvbmFsZSBkZSBDZXJ0aWZpY2F0aW9u +IEVsZWN0cm9uaXF1ZTEZMBcGA1UEAwwQVHVuVHJ1c3QgUm9vdCBDQTCCAiIwDQYJ +KoZIhvcNAQEBBQADggIPADCCAgoCggIBAMPN0/y9BFPdDCA61YguBUtB9YOCfvdZ +n56eY+hz2vYGqU8ftPkLHzmMmiDQfgbU7DTZhrx1W4eI8NLZ1KMKsmwb60ksPqxd +2JQDoOw05TDENX37Jk0bbjBU2PWARZw5rZzJJQRNmpA+TkBuimvNKWfGzC3gdOgF +VwpIUPp6Q9p+7FuaDmJ2/uqdHYVy7BG7NegfJ7/Boce7SBbdVtfMTqDhuazb1YMZ +GoXRlJfXyqNlC/M4+QKu3fZnz8k/9YosRxqZbwUN/dAdgjH8KcwAWJeRTIAAHDOF +li/LQcKLEITDCSSJH7UP2dl3RxiSlGBcx5kDPP73lad9UKGAwqmDrViWVSHbhlnU +r8a83YFuB9tgYv7sEG7aaAH0gxupPqJbI9dkxt/con3YS7qC0lH4Zr8GRuR5KiY2 +eY8fTpkdso8MDhz/yV3A/ZAQprE38806JG60hZC/gLkMjNWb1sjxVj8agIl6qeIb +MlEsPvLfe/ZdeikZjuXIvTZxi11Mwh0/rViizz1wTaZQmCXcI/m4WEEIcb9PuISg +jwBUFfyRbVinljvrS5YnzWuioYasDXxU5mZMZl+QviGaAkYt5IPCgLnPSz7ofzwB +7I9ezX/SKEIBlYrilz0QIX32nRzFNKHsLA4KUiwSVXAkPcvCFDVDXSdOvsC9qnyW +5/yeYa1E0wCXAgMBAAGjYzBhMB0GA1UdDgQWBBQGmpsfU33x9aTI04Y+oXNZtPdE +ITAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFAaamx9TffH1pMjThj6hc1m0 +90QhMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAqgVutt0Vyb+z +xiD2BkewhpMl0425yAA/l/VSJ4hxyXT968pk21vvHl26v9Hr7lxpuhbI87mP0zYu +QEkHDVneixCwSQXi/5E/S7fdAo74gShczNxtr18UnH1YeA32gAm56Q6XKRm4t+v4 +FstVEuTGfbvE7Pi1HE4+Z7/FXxttbUcoqgRYYdZ2vyJ/0Adqp2RT8JeNnYA/u8EH +22Wv5psymsNUk8QcCMNE+3tjEUPRahphanltkE8pjkcFwRJpadbGNjHh/PqAulxP +xOu3Mqz4dWEX1xAZufHSCe96Qp1bWgvUxpVOKs7/B9dPfhgGiPEZtdmYu65xxBzn +dFlY7wyJz4sfdZMaBBSSSFCp61cpABbjNhzI+L/wM9VBD8TMPN3pM0MBkRArHtG5 +Xc0yGYuPjCB31yLEQtyEFpslbei0VXF/sHyz03FJuc9SpAQ/3D2gu68zngowYI7b +nV2UqL1g52KAdoGDDIzMMEZJ4gzSqK/rYXHv5yJiqfdcZGyfFoxnNidF9Ql7v/YQ +CvGwjVRDjAS6oz/v4jXH+XTgbzRB0L9zZVcg+ZtnemZoJE6AZb0QmQZZ8mWvuMZH +u/2QeItBcy6vVR/cO5JyboTT0GFMDcx2V+IthSIVNg3rAZ3r2OvEhJn7wAzMMujj +d9qDRIueVSjAi1jTkD5OGwDxFa2DK5o= +-----END CERTIFICATE----- + +# Issuer: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Subject: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Label: "HARICA TLS RSA Root CA 2021" +# Serial: 76817823531813593706434026085292783742 +# MD5 Fingerprint: 65:47:9b:58:86:dd:2c:f0:fc:a2:84:1f:1e:96:c4:91 +# SHA1 Fingerprint: 02:2d:05:82:fa:88:ce:14:0c:06:79:de:7f:14:10:e9:45:d7:a5:6d +# SHA256 Fingerprint: d9:5d:0e:8e:da:79:52:5b:f9:be:b1:1b:14:d2:10:0d:32:94:98:5f:0c:62:d9:fa:bd:9c:d9:99:ec:cb:7b:1d +-----BEGIN CERTIFICATE----- +MIIFpDCCA4ygAwIBAgIQOcqTHO9D88aOk8f0ZIk4fjANBgkqhkiG9w0BAQsFADBs +MQswCQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl +c2VhcmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBSU0Eg +Um9vdCBDQSAyMDIxMB4XDTIxMDIxOTEwNTUzOFoXDTQ1MDIxMzEwNTUzN1owbDEL +MAkGA1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNl +YXJjaCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgUlNBIFJv +b3QgQ0EgMjAyMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAIvC569l +mwVnlskNJLnQDmT8zuIkGCyEf3dRywQRNrhe7Wlxp57kJQmXZ8FHws+RFjZiPTgE +4VGC/6zStGndLuwRo0Xua2s7TL+MjaQenRG56Tj5eg4MmOIjHdFOY9TnuEFE+2uv +a9of08WRiFukiZLRgeaMOVig1mlDqa2YUlhu2wr7a89o+uOkXjpFc5gH6l8Cct4M +pbOfrqkdtx2z/IpZ525yZa31MJQjB/OCFks1mJxTuy/K5FrZx40d/JiZ+yykgmvw +Kh+OC19xXFyuQnspiYHLA6OZyoieC0AJQTPb5lh6/a6ZcMBaD9YThnEvdmn8kN3b +LW7R8pv1GmuebxWMevBLKKAiOIAkbDakO/IwkfN4E8/BPzWr8R0RI7VDIp4BkrcY +AuUR0YLbFQDMYTfBKnya4dC6s1BG7oKsnTH4+yPiAwBIcKMJJnkVU2DzOFytOOqB +AGMUuTNe3QvboEUHGjMJ+E20pwKmafTCWQWIZYVWrkvL4N48fS0ayOn7H6NhStYq +E613TBoYm5EPWNgGVMWX+Ko/IIqmhaZ39qb8HOLubpQzKoNQhArlT4b4UEV4AIHr +W2jjJo3Me1xR9BQsQL4aYB16cmEdH2MtiKrOokWQCPxrvrNQKlr9qEgYRtaQQJKQ +CoReaDH46+0N0x3GfZkYVVYnZS6NRcUk7M7jAgMBAAGjQjBAMA8GA1UdEwEB/wQF +MAMBAf8wHQYDVR0OBBYEFApII6ZgpJIKM+qTW8VX6iVNvRLuMA4GA1UdDwEB/wQE +AwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAPpBIqm5iFSVmewzVjIuJndftTgfvnNAU +X15QvWiWkKQUEapobQk1OUAJ2vQJLDSle1mESSmXdMgHHkdt8s4cUCbjnj1AUz/3 +f5Z2EMVGpdAgS1D0NTsY9FVqQRtHBmg8uwkIYtlfVUKqrFOFrJVWNlar5AWMxaja +H6NpvVMPxP/cyuN+8kyIhkdGGvMA9YCRotxDQpSbIPDRzbLrLFPCU3hKTwSUQZqP +JzLB5UkZv/HywouoCjkxKLR9YjYsTewfM7Z+d21+UPCfDtcRj88YxeMn/ibvBZ3P +zzfF0HvaO7AWhAw6k9a+F9sPPg4ZeAnHqQJyIkv3N3a6dcSFA1pj1bF1BcK5vZSt +jBWZp5N99sXzqnTPBIWUmAD04vnKJGW/4GKvyMX6ssmeVkjaef2WdhW+o45WxLM0 +/L5H9MG0qPzVMIho7suuyWPEdr6sOBjhXlzPrjoiUevRi7PzKzMHVIf6tLITe7pT +BGIBnfHAT+7hOtSLIBD6Alfm78ELt5BGnBkpjNxvoEppaZS3JGWg/6w/zgH7IS79 +aPib8qXPMThcFarmlwDB31qlpzmq6YR/PFGoOtmUW4y/Twhx5duoXNTSpv4Ao8YW +xw/ogM4cKGR0GQjTQuPOAF1/sdwTsOEFy9EgqoZ0njnnkf3/W9b3raYvAwtt41dU +63ZTGI0RmLo= +-----END CERTIFICATE----- + +# Issuer: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Subject: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Label: "HARICA TLS ECC Root CA 2021" +# Serial: 137515985548005187474074462014555733966 +# MD5 Fingerprint: ae:f7:4c:e5:66:35:d1:b7:9b:8c:22:93:74:d3:4b:b0 +# SHA1 Fingerprint: bc:b0:c1:9d:e9:98:92:70:19:38:57:e9:8d:a7:b4:5d:6e:ee:01:48 +# SHA256 Fingerprint: 3f:99:cc:47:4a:cf:ce:4d:fe:d5:87:94:66:5e:47:8d:15:47:73:9f:2e:78:0f:1b:b4:ca:9b:13:30:97:d4:01 +-----BEGIN CERTIFICATE----- +MIICVDCCAdugAwIBAgIQZ3SdjXfYO2rbIvT/WeK/zjAKBggqhkjOPQQDAzBsMQsw +CQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2Vh +cmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBFQ0MgUm9v +dCBDQSAyMDIxMB4XDTIxMDIxOTExMDExMFoXDTQ1MDIxMzExMDEwOVowbDELMAkG +A1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJj +aCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgRUNDIFJvb3Qg +Q0EgMjAyMTB2MBAGByqGSM49AgEGBSuBBAAiA2IABDgI/rGgltJ6rK9JOtDA4MM7 +KKrxcm1lAEeIhPyaJmuqS7psBAqIXhfyVYf8MLA04jRYVxqEU+kw2anylnTDUR9Y +STHMmE5gEYd103KUkE+bECUqqHgtvpBBWJAVcqeht6NCMEAwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUyRtTgRL+BNUW0aq8mm+3oJUZbsowDgYDVR0PAQH/BAQD +AgGGMAoGCCqGSM49BAMDA2cAMGQCMBHervjcToiwqfAircJRQO9gcS3ujwLEXQNw +SaSS6sUUiHCm0w2wqsosQJz76YJumgIwK0eaB8bRwoF8yguWGEEbo/QwCZ61IygN +nxS2PFOiTAZpffpskcYqSUXm7LcT4Tps +-----END CERTIFICATE----- + +# Issuer: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068 +# Subject: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068 +# Label: "Autoridad de Certificacion Firmaprofesional CIF A62634068" +# Serial: 1977337328857672817 +# MD5 Fingerprint: 4e:6e:9b:54:4c:ca:b7:fa:48:e4:90:b1:15:4b:1c:a3 +# SHA1 Fingerprint: 0b:be:c2:27:22:49:cb:39:aa:db:35:5c:53:e3:8c:ae:78:ff:b6:fe +# SHA256 Fingerprint: 57:de:05:83:ef:d2:b2:6e:03:61:da:99:da:9d:f4:64:8d:ef:7e:e8:44:1c:3b:72:8a:fa:9b:cd:e0:f9:b2:6a +-----BEGIN CERTIFICATE----- +MIIGFDCCA/ygAwIBAgIIG3Dp0v+ubHEwDQYJKoZIhvcNAQELBQAwUTELMAkGA1UE +BhMCRVMxQjBABgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1h +cHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2ODAeFw0xNDA5MjMxNTIyMDdaFw0zNjA1 +MDUxNTIyMDdaMFExCzAJBgNVBAYTAkVTMUIwQAYDVQQDDDlBdXRvcmlkYWQgZGUg +Q2VydGlmaWNhY2lvbiBGaXJtYXByb2Zlc2lvbmFsIENJRiBBNjI2MzQwNjgwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKlmuO6vj78aI14H9M2uDDUtd9 +thDIAl6zQyrET2qyyhxdKJp4ERppWVevtSBC5IsP5t9bpgOSL/UR5GLXMnE42QQM +cas9UX4PB99jBVzpv5RvwSmCwLTaUbDBPLutN0pcyvFLNg4kq7/DhHf9qFD0sefG +L9ItWY16Ck6WaVICqjaY7Pz6FIMMNx/Jkjd/14Et5cS54D40/mf0PmbR0/RAz15i +NA9wBj4gGFrO93IbJWyTdBSTo3OxDqqHECNZXyAFGUftaI6SEspd/NYrspI8IM/h +X68gvqB2f3bl7BqGYTM+53u0P6APjqK5am+5hyZvQWyIplD9amML9ZMWGxmPsu2b +m8mQ9QEM3xk9Dz44I8kvjwzRAv4bVdZO0I08r0+k8/6vKtMFnXkIoctXMbScyJCy +Z/QYFpM6/EfY0XiWMR+6KwxfXZmtY4laJCB22N/9q06mIqqdXuYnin1oKaPnirja +EbsXLZmdEyRG98Xi2J+Of8ePdG1asuhy9azuJBCtLxTa/y2aRnFHvkLfuwHb9H/T +KI8xWVvTyQKmtFLKbpf7Q8UIJm+K9Lv9nyiqDdVF8xM6HdjAeI9BZzwelGSuewvF +6NkBiDkal4ZkQdU7hwxu+g/GvUgUvzlN1J5Bto+WHWOWk9mVBngxaJ43BjuAiUVh +OSPHG0SjFeUc+JIwuwIDAQABo4HvMIHsMB0GA1UdDgQWBBRlzeurNR4APn7VdMAc +tHNHDhpkLzASBgNVHRMBAf8ECDAGAQH/AgEBMIGmBgNVHSAEgZ4wgZswgZgGBFUd +IAAwgY8wLwYIKwYBBQUHAgEWI2h0dHA6Ly93d3cuZmlybWFwcm9mZXNpb25hbC5j +b20vY3BzMFwGCCsGAQUFBwICMFAeTgBQAGEAcwBlAG8AIABkAGUAIABsAGEAIABC +AG8AbgBhAG4AbwB2AGEAIAA0ADcAIABCAGEAcgBjAGUAbABvAG4AYQAgADAAOAAw +ADEANzAOBgNVHQ8BAf8EBAMCAQYwDQYJKoZIhvcNAQELBQADggIBAHSHKAIrdx9m +iWTtj3QuRhy7qPj4Cx2Dtjqn6EWKB7fgPiDL4QjbEwj4KKE1soCzC1HA01aajTNF +Sa9J8OA9B3pFE1r/yJfY0xgsfZb43aJlQ3CTkBW6kN/oGbDbLIpgD7dvlAceHabJ +hfa9NPhAeGIQcDq+fUs5gakQ1JZBu/hfHAsdCPKxsIl68veg4MSPi3i1O1ilI45P +Vf42O+AMt8oqMEEgtIDNrvx2ZnOorm7hfNoD6JQg5iKj0B+QXSBTFCZX2lSX3xZE +EAEeiGaPcjiT3SC3NL7X8e5jjkd5KAb881lFJWAiMxujX6i6KtoaPc1A6ozuBRWV +1aUsIC+nmCjuRfzxuIgALI9C2lHVnOUTaHFFQ4ueCyE8S1wF3BqfmI7avSKecs2t +CsvMo2ebKHTEm9caPARYpoKdrcd7b/+Alun4jWq9GJAd/0kakFI3ky88Al2CdgtR +5xbHV/g4+afNmyJU72OwFW1TZQNKXkqgsqeOSQBZONXH9IBk9W6VULgRfhVwOEqw +f9DEMnDAGf/JOC0ULGb0QkTmVXYbgBVX/8Cnp6o5qtjTcNAuuuuUavpfNIbnYrX9 +ivAwhZTJryQCL2/W3Wf+47BVTwSYT6RBVuKT0Gro1vP7ZeDOdcQxWQzugsgMYDNK +GbqEZycPvEJdvSRUDewdcAZfpLz6IHxV +-----END CERTIFICATE----- + +# Issuer: CN=vTrus ECC Root CA O=iTrusChina Co.,Ltd. +# Subject: CN=vTrus ECC Root CA O=iTrusChina Co.,Ltd. +# Label: "vTrus ECC Root CA" +# Serial: 630369271402956006249506845124680065938238527194 +# MD5 Fingerprint: de:4b:c1:f5:52:8c:9b:43:e1:3e:8f:55:54:17:8d:85 +# SHA1 Fingerprint: f6:9c:db:b0:fc:f6:02:13:b6:52:32:a6:a3:91:3f:16:70:da:c3:e1 +# SHA256 Fingerprint: 30:fb:ba:2c:32:23:8e:2a:98:54:7a:f9:79:31:e5:50:42:8b:9b:3f:1c:8e:eb:66:33:dc:fa:86:c5:b2:7d:d3 +-----BEGIN CERTIFICATE----- +MIICDzCCAZWgAwIBAgIUbmq8WapTvpg5Z6LSa6Q75m0c1towCgYIKoZIzj0EAwMw +RzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28uLEx0ZC4xGjAY +BgNVBAMTEXZUcnVzIEVDQyBSb290IENBMB4XDTE4MDczMTA3MjY0NFoXDTQzMDcz +MTA3MjY0NFowRzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28u +LEx0ZC4xGjAYBgNVBAMTEXZUcnVzIEVDQyBSb290IENBMHYwEAYHKoZIzj0CAQYF +K4EEACIDYgAEZVBKrox5lkqqHAjDo6LN/llWQXf9JpRCux3NCNtzslt188+cToL0 +v/hhJoVs1oVbcnDS/dtitN9Ti72xRFhiQgnH+n9bEOf+QP3A2MMrMudwpremIFUd +e4BdS49nTPEQo0IwQDAdBgNVHQ4EFgQUmDnNvtiyjPeyq+GtJK97fKHbH88wDwYD +VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwCgYIKoZIzj0EAwMDaAAwZQIw +V53dVvHH4+m4SVBrm2nDb+zDfSXkV5UTQJtS0zvzQBm8JsctBp61ezaf9SXUY2sA +AjEA6dPGnlaaKsyh2j/IZivTWJwghfqrkYpwcBE4YGQLYgmRWAD5Tfs0aNoJrSEG +GJTO +-----END CERTIFICATE----- + +# Issuer: CN=vTrus Root CA O=iTrusChina Co.,Ltd. +# Subject: CN=vTrus Root CA O=iTrusChina Co.,Ltd. +# Label: "vTrus Root CA" +# Serial: 387574501246983434957692974888460947164905180485 +# MD5 Fingerprint: b8:c9:37:df:fa:6b:31:84:64:c5:ea:11:6a:1b:75:fc +# SHA1 Fingerprint: 84:1a:69:fb:f5:cd:1a:25:34:13:3d:e3:f8:fc:b8:99:d0:c9:14:b7 +# SHA256 Fingerprint: 8a:71:de:65:59:33:6f:42:6c:26:e5:38:80:d0:0d:88:a1:8d:a4:c6:a9:1f:0d:cb:61:94:e2:06:c5:c9:63:87 +-----BEGIN CERTIFICATE----- +MIIFVjCCAz6gAwIBAgIUQ+NxE9izWRRdt86M/TX9b7wFjUUwDQYJKoZIhvcNAQEL +BQAwQzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28uLEx0ZC4x +FjAUBgNVBAMTDXZUcnVzIFJvb3QgQ0EwHhcNMTgwNzMxMDcyNDA1WhcNNDMwNzMx +MDcyNDA1WjBDMQswCQYDVQQGEwJDTjEcMBoGA1UEChMTaVRydXNDaGluYSBDby4s +THRkLjEWMBQGA1UEAxMNdlRydXMgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEBBQAD +ggIPADCCAgoCggIBAL1VfGHTuB0EYgWgrmy3cLRB6ksDXhA/kFocizuwZotsSKYc +IrrVQJLuM7IjWcmOvFjai57QGfIvWcaMY1q6n6MLsLOaXLoRuBLpDLvPbmyAhykU +AyyNJJrIZIO1aqwTLDPxn9wsYTwaP3BVm60AUn/PBLn+NvqcwBauYv6WTEN+VRS+ +GrPSbcKvdmaVayqwlHeFXgQPYh1jdfdr58tbmnDsPmcF8P4HCIDPKNsFxhQnL4Z9 +8Cfe/+Z+M0jnCx5Y0ScrUw5XSmXX+6KAYPxMvDVTAWqXcoKv8R1w6Jz1717CbMdH +flqUhSZNO7rrTOiwCcJlwp2dCZtOtZcFrPUGoPc2BX70kLJrxLT5ZOrpGgrIDajt +J8nU57O5q4IikCc9Kuh8kO+8T/3iCiSn3mUkpF3qwHYw03dQ+A0Em5Q2AXPKBlim +0zvc+gRGE1WKyURHuFE5Gi7oNOJ5y1lKCn+8pu8fA2dqWSslYpPZUxlmPCdiKYZN +pGvu/9ROutW04o5IWgAZCfEF2c6Rsffr6TlP9m8EQ5pV9T4FFL2/s1m02I4zhKOQ +UqqzApVg+QxMaPnu1RcN+HFXtSXkKe5lXa/R7jwXC1pDxaWG6iSe4gUH3DRCEpHW +OXSuTEGC2/KmSNGzm/MzqvOmwMVO9fSddmPmAsYiS8GVP1BkLFTltvA8Kc9XAgMB +AAGjQjBAMB0GA1UdDgQWBBRUYnBj8XWEQ1iO0RYgscasGrz2iTAPBgNVHRMBAf8E +BTADAQH/MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAKbqSSaet +8PFww+SX8J+pJdVrnjT+5hpk9jprUrIQeBqfTNqK2uwcN1LgQkv7bHbKJAs5EhWd +nxEt/Hlk3ODg9d3gV8mlsnZwUKT+twpw1aA08XXXTUm6EdGz2OyC/+sOxL9kLX1j +bhd47F18iMjrjld22VkE+rxSH0Ws8HqA7Oxvdq6R2xCOBNyS36D25q5J08FsEhvM +Kar5CKXiNxTKsbhm7xqC5PD48acWabfbqWE8n/Uxy+QARsIvdLGx14HuqCaVvIiv +TDUHKgLKeBRtRytAVunLKmChZwOgzoy8sHJnxDHO2zTlJQNgJXtxmOTAGytfdELS +S8VZCAeHvsXDf+eW2eHcKJfWjwXj9ZtOyh1QRwVTsMo554WgicEFOwE30z9J4nfr +I8iIZjs9OXYhRvHsXyO466JmdXTBQPfYaJqT4i2pLr0cox7IdMakLXogqzu4sEb9 +b91fUlV1YvCXoHzXOP0l382gmxDPi7g4Xl7FtKYCNqEeXxzP4padKar9mK5S4fNB +UvupLnKWnyfjqnN9+BojZns7q2WwMgFLFT49ok8MKzWixtlnEjUwzXYuFrOZnk1P +Ti07NEPhmg4NpGaXutIcSkwsKouLgU9xGqndXHt7CMUADTdA43x7VF8vhV929ven +sBxXVsFy6K2ir40zSbofitzmdHxghm+Hl3s= +-----END CERTIFICATE----- + +# Issuer: CN=ISRG Root X2 O=Internet Security Research Group +# Subject: CN=ISRG Root X2 O=Internet Security Research Group +# Label: "ISRG Root X2" +# Serial: 87493402998870891108772069816698636114 +# MD5 Fingerprint: d3:9e:c4:1e:23:3c:a6:df:cf:a3:7e:6d:e0:14:e6:e5 +# SHA1 Fingerprint: bd:b1:b9:3c:d5:97:8d:45:c6:26:14:55:f8:db:95:c7:5a:d1:53:af +# SHA256 Fingerprint: 69:72:9b:8e:15:a8:6e:fc:17:7a:57:af:b7:17:1d:fc:64:ad:d2:8c:2f:ca:8c:f1:50:7e:34:45:3c:cb:14:70 +-----BEGIN CERTIFICATE----- +MIICGzCCAaGgAwIBAgIQQdKd0XLq7qeAwSxs6S+HUjAKBggqhkjOPQQDAzBPMQsw +CQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJuZXQgU2VjdXJpdHkgUmVzZWFyY2gg +R3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBYMjAeFw0yMDA5MDQwMDAwMDBaFw00 +MDA5MTcxNjAwMDBaME8xCzAJBgNVBAYTAlVTMSkwJwYDVQQKEyBJbnRlcm5ldCBT +ZWN1cml0eSBSZXNlYXJjaCBHcm91cDEVMBMGA1UEAxMMSVNSRyBSb290IFgyMHYw +EAYHKoZIzj0CAQYFK4EEACIDYgAEzZvVn4CDCuwJSvMWSj5cz3es3mcFDR0HttwW ++1qLFNvicWDEukWVEYmO6gbf9yoWHKS5xcUy4APgHoIYOIvXRdgKam7mAHf7AlF9 +ItgKbppbd9/w+kHsOdx1ymgHDB/qo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0T +AQH/BAUwAwEB/zAdBgNVHQ4EFgQUfEKWrt5LSDv6kviejM9ti6lyN5UwCgYIKoZI +zj0EAwMDaAAwZQIwe3lORlCEwkSHRhtFcP9Ymd70/aTSVaYgLXTWNLxBo1BfASdW +tL4ndQavEi51mI38AjEAi/V3bNTIZargCyzuFJ0nN6T5U6VR5CmD1/iQMVtCnwr1 +/q4AaOeMSQ+2b1tbFfLn +-----END CERTIFICATE----- + +# Issuer: CN=HiPKI Root CA - G1 O=Chunghwa Telecom Co., Ltd. +# Subject: CN=HiPKI Root CA - G1 O=Chunghwa Telecom Co., Ltd. +# Label: "HiPKI Root CA - G1" +# Serial: 60966262342023497858655262305426234976 +# MD5 Fingerprint: 69:45:df:16:65:4b:e8:68:9a:8f:76:5f:ff:80:9e:d3 +# SHA1 Fingerprint: 6a:92:e4:a8:ee:1b:ec:96:45:37:e3:29:57:49:cd:96:e3:e5:d2:60 +# SHA256 Fingerprint: f0:15:ce:3c:c2:39:bf:ef:06:4b:e9:f1:d2:c4:17:e1:a0:26:4a:0a:94:be:1f:0c:8d:12:18:64:eb:69:49:cc +-----BEGIN CERTIFICATE----- +MIIFajCCA1KgAwIBAgIQLd2szmKXlKFD6LDNdmpeYDANBgkqhkiG9w0BAQsFADBP +MQswCQYDVQQGEwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0 +ZC4xGzAZBgNVBAMMEkhpUEtJIFJvb3QgQ0EgLSBHMTAeFw0xOTAyMjIwOTQ2MDRa +Fw0zNzEyMzExNTU5NTlaME8xCzAJBgNVBAYTAlRXMSMwIQYDVQQKDBpDaHVuZ2h3 +YSBUZWxlY29tIENvLiwgTHRkLjEbMBkGA1UEAwwSSGlQS0kgUm9vdCBDQSAtIEcx +MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA9B5/UnMyDHPkvRN0o9Qw +qNCuS9i233VHZvR85zkEHmpwINJaR3JnVfSl6J3VHiGh8Ge6zCFovkRTv4354twv +Vcg3Px+kwJyz5HdcoEb+d/oaoDjq7Zpy3iu9lFc6uux55199QmQ5eiY29yTw1S+6 +lZgRZq2XNdZ1AYDgr/SEYYwNHl98h5ZeQa/rh+r4XfEuiAU+TCK72h8q3VJGZDnz +Qs7ZngyzsHeXZJzA9KMuH5UHsBffMNsAGJZMoYFL3QRtU6M9/Aes1MU3guvklQgZ +KILSQjqj2FPseYlgSGDIcpJQ3AOPgz+yQlda22rpEZfdhSi8MEyr48KxRURHH+CK +FgeW0iEPU8DtqX7UTuybCeyvQqww1r/REEXgphaypcXTT3OUM3ECoWqj1jOXTyFj +HluP2cFeRXF3D4FdXyGarYPM+l7WjSNfGz1BryB1ZlpK9p/7qxj3ccC2HTHsOyDr +y+K49a6SsvfhhEvyovKTmiKe0xRvNlS9H15ZFblzqMF8b3ti6RZsR1pl8w4Rm0bZ +/W3c1pzAtH2lsN0/Vm+h+fbkEkj9Bn8SV7apI09bA8PgcSojt/ewsTu8mL3WmKgM +a/aOEmem8rJY5AIJEzypuxC00jBF8ez3ABHfZfjcK0NVvxaXxA/VLGGEqnKG/uY6 +fsI/fe78LxQ+5oXdUG+3Se0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNV +HQ4EFgQU8ncX+l6o/vY9cdVouslGDDjYr7AwDgYDVR0PAQH/BAQDAgGGMA0GCSqG +SIb3DQEBCwUAA4ICAQBQUfB13HAE4/+qddRxosuej6ip0691x1TPOhwEmSKsxBHi +7zNKpiMdDg1H2DfHb680f0+BazVP6XKlMeJ45/dOlBhbQH3PayFUhuaVevvGyuqc +SE5XCV0vrPSltJczWNWseanMX/mF+lLFjfiRFOs6DRfQUsJ748JzjkZ4Bjgs6Fza +ZsT0pPBWGTMpWmWSBUdGSquEwx4noR8RkpkndZMPvDY7l1ePJlsMu5wP1G4wB9Tc +XzZoZjmDlicmisjEOf6aIW/Vcobpf2Lll07QJNBAsNB1CI69aO4I1258EHBGG3zg +iLKecoaZAeO/n0kZtCW+VmWuF2PlHt/o/0elv+EmBYTksMCv5wiZqAxeJoBF1Pho +L5aPruJKHJwWDBNvOIf2u8g0X5IDUXlwpt/L9ZlNec1OvFefQ05rLisY+GpzjLrF +Ne85akEez3GoorKGB1s6yeHvP2UEgEcyRHCVTjFnanRbEEV16rCf0OY1/k6fi8wr +kkVbbiVghUbN0aqwdmaTd5a+g744tiROJgvM7XpWGuDpWsZkrUx6AEhEL7lAuxM+ +vhV4nYWBSipX3tUZQ9rbyltHhoMLP7YNdnhzeSJesYAfz77RP1YQmCuVh6EfnWQU +YDksswBVLuT1sw5XxJFBAJw/6KXf6vb/yPCtbVKoF6ubYfwSUTXkJf2vqmqGOQ== +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 +# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4 +# Label: "GlobalSign ECC Root CA - R4" +# Serial: 159662223612894884239637590694 +# MD5 Fingerprint: 26:29:f8:6d:e1:88:bf:a2:65:7f:aa:c4:cd:0f:7f:fc +# SHA1 Fingerprint: 6b:a0:b0:98:e1:71:ef:5a:ad:fe:48:15:80:77:10:f4:bd:6f:0b:28 +# SHA256 Fingerprint: b0:85:d7:0b:96:4f:19:1a:73:e4:af:0d:54:ae:7a:0e:07:aa:fd:af:9b:71:dd:08:62:13:8a:b7:32:5a:24:a2 +-----BEGIN CERTIFICATE----- +MIIB3DCCAYOgAwIBAgINAgPlfvU/k/2lCSGypjAKBggqhkjOPQQDAjBQMSQwIgYD +VQQLExtHbG9iYWxTaWduIEVDQyBSb290IENBIC0gUjQxEzARBgNVBAoTCkdsb2Jh +bFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMTIxMTEzMDAwMDAwWhcNMzgw +MTE5MDMxNDA3WjBQMSQwIgYDVQQLExtHbG9iYWxTaWduIEVDQyBSb290IENBIC0g +UjQxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wWTAT +BgcqhkjOPQIBBggqhkjOPQMBBwNCAAS4xnnTj2wlDp8uORkcA6SumuU5BwkWymOx +uYb4ilfBV85C+nOh92VC/x7BALJucw7/xyHlGKSq2XE/qNS5zowdo0IwQDAOBgNV +HQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUVLB7rUW44kB/ ++wpu+74zyTyjhNUwCgYIKoZIzj0EAwIDRwAwRAIgIk90crlgr/HmnKAWBVBfw147 +bmF0774BxL4YSFlhgjICICadVGNA3jdgUM/I2O2dgq43mLyjj0xMqTQrbO/7lZsm +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R1 O=Google Trust Services LLC +# Subject: CN=GTS Root R1 O=Google Trust Services LLC +# Label: "GTS Root R1" +# Serial: 159662320309726417404178440727 +# MD5 Fingerprint: 05:fe:d0:bf:71:a8:a3:76:63:da:01:e0:d8:52:dc:40 +# SHA1 Fingerprint: e5:8c:1c:c4:91:3b:38:63:4b:e9:10:6e:e3:ad:8e:6b:9d:d9:81:4a +# SHA256 Fingerprint: d9:47:43:2a:bd:e7:b7:fa:90:fc:2e:6b:59:10:1b:12:80:e0:e1:c7:e4:e4:0f:a3:c6:88:7f:ff:57:a7:f4:cf +-----BEGIN CERTIFICATE----- +MIIFVzCCAz+gAwIBAgINAgPlk28xsBNJiGuiFzANBgkqhkiG9w0BAQwFADBHMQsw +CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU +MBIGA1UEAxMLR1RTIFJvb3QgUjEwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw +MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp +Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwggIiMA0GCSqGSIb3DQEBAQUA +A4ICDwAwggIKAoICAQC2EQKLHuOhd5s73L+UPreVp0A8of2C+X0yBoJx9vaMf/vo +27xqLpeXo4xL+Sv2sfnOhB2x+cWX3u+58qPpvBKJXqeqUqv4IyfLpLGcY9vXmX7w +Cl7raKb0xlpHDU0QM+NOsROjyBhsS+z8CZDfnWQpJSMHobTSPS5g4M/SCYe7zUjw +TcLCeoiKu7rPWRnWr4+wB7CeMfGCwcDfLqZtbBkOtdh+JhpFAz2weaSUKK0Pfybl +qAj+lug8aJRT7oM6iCsVlgmy4HqMLnXWnOunVmSPlk9orj2XwoSPwLxAwAtcvfaH +szVsrBhQf4TgTM2S0yDpM7xSma8ytSmzJSq0SPly4cpk9+aCEI3oncKKiPo4Zor8 +Y/kB+Xj9e1x3+naH+uzfsQ55lVe0vSbv1gHR6xYKu44LtcXFilWr06zqkUspzBmk +MiVOKvFlRNACzqrOSbTqn3yDsEB750Orp2yjj32JgfpMpf/VjsPOS+C12LOORc92 +wO1AK/1TD7Cn1TsNsYqiA94xrcx36m97PtbfkSIS5r762DL8EGMUUXLeXdYWk70p +aDPvOmbsB4om3xPXV2V4J95eSRQAogB/mqghtqmxlbCluQ0WEdrHbEg8QOB+DVrN +VjzRlwW5y0vtOUucxD/SVRNuJLDWcfr0wbrM7Rv1/oFB2ACYPTrIrnqYNxgFlQID +AQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E +FgQU5K8rJnEaK0gnhS9SZizv8IkTcT4wDQYJKoZIhvcNAQEMBQADggIBAJ+qQibb +C5u+/x6Wki4+omVKapi6Ist9wTrYggoGxval3sBOh2Z5ofmmWJyq+bXmYOfg6LEe +QkEzCzc9zolwFcq1JKjPa7XSQCGYzyI0zzvFIoTgxQ6KfF2I5DUkzps+GlQebtuy +h6f88/qBVRRiClmpIgUxPoLW7ttXNLwzldMXG+gnoot7TiYaelpkttGsN/H9oPM4 +7HLwEXWdyzRSjeZ2axfG34arJ45JK3VmgRAhpuo+9K4l/3wV3s6MJT/KYnAK9y8J +ZgfIPxz88NtFMN9iiMG1D53Dn0reWVlHxYciNuaCp+0KueIHoI17eko8cdLiA6Ef +MgfdG+RCzgwARWGAtQsgWSl4vflVy2PFPEz0tv/bal8xa5meLMFrUKTX5hgUvYU/ +Z6tGn6D/Qqc6f1zLXbBwHSs09dR2CQzreExZBfMzQsNhFRAbd03OIozUhfJFfbdT +6u9AWpQKXCBfTkBdYiJ23//OYb2MI3jSNwLgjt7RETeJ9r/tSQdirpLsQBqvFAnZ +0E6yove+7u7Y/9waLd64NnHi/Hm3lCXRSHNboTXns5lndcEZOitHTtNCjv0xyBZm +2tIMPNuzjsmhDYAPexZ3FL//2wmUspO8IFgV6dtxQ/PeEMMA3KgqlbbC1j+Qa3bb +bP6MvPJwNQzcmRk13NfIRmPVNnGuV/u3gm3c +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R2 O=Google Trust Services LLC +# Subject: CN=GTS Root R2 O=Google Trust Services LLC +# Label: "GTS Root R2" +# Serial: 159662449406622349769042896298 +# MD5 Fingerprint: 1e:39:c0:53:e6:1e:29:82:0b:ca:52:55:36:5d:57:dc +# SHA1 Fingerprint: 9a:44:49:76:32:db:de:fa:d0:bc:fb:5a:7b:17:bd:9e:56:09:24:94 +# SHA256 Fingerprint: 8d:25:cd:97:22:9d:bf:70:35:6b:da:4e:b3:cc:73:40:31:e2:4c:f0:0f:af:cf:d3:2d:c7:6e:b5:84:1c:7e:a8 +-----BEGIN CERTIFICATE----- +MIIFVzCCAz+gAwIBAgINAgPlrsWNBCUaqxElqjANBgkqhkiG9w0BAQwFADBHMQsw +CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU +MBIGA1UEAxMLR1RTIFJvb3QgUjIwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw +MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp +Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwggIiMA0GCSqGSIb3DQEBAQUA +A4ICDwAwggIKAoICAQDO3v2m++zsFDQ8BwZabFn3GTXd98GdVarTzTukk3LvCvpt +nfbwhYBboUhSnznFt+4orO/LdmgUud+tAWyZH8QiHZ/+cnfgLFuv5AS/T3KgGjSY +6Dlo7JUle3ah5mm5hRm9iYz+re026nO8/4Piy33B0s5Ks40FnotJk9/BW9BuXvAu +MC6C/Pq8tBcKSOWIm8Wba96wyrQD8Nr0kLhlZPdcTK3ofmZemde4wj7I0BOdre7k +RXuJVfeKH2JShBKzwkCX44ofR5GmdFrS+LFjKBC4swm4VndAoiaYecb+3yXuPuWg +f9RhD1FLPD+M2uFwdNjCaKH5wQzpoeJ/u1U8dgbuak7MkogwTZq9TwtImoS1mKPV ++3PBV2HdKFZ1E66HjucMUQkQdYhMvI35ezzUIkgfKtzra7tEscszcTJGr61K8Yzo +dDqs5xoic4DSMPclQsciOzsSrZYuxsN2B6ogtzVJV+mSSeh2FnIxZyuWfoqjx5RW +Ir9qS34BIbIjMt/kmkRtWVtd9QCgHJvGeJeNkP+byKq0rxFROV7Z+2et1VsRnTKa +G73VululycslaVNVJ1zgyjbLiGH7HrfQy+4W+9OmTN6SpdTi3/UGVN4unUu0kzCq +gc7dGtxRcw1PcOnlthYhGXmy5okLdWTK1au8CcEYof/UVKGFPP0UJAOyh9OktwID +AQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E +FgQUu//KjiOfT5nK2+JopqUVJxce2Q4wDQYJKoZIhvcNAQEMBQADggIBAB/Kzt3H +vqGf2SdMC9wXmBFqiN495nFWcrKeGk6c1SuYJF2ba3uwM4IJvd8lRuqYnrYb/oM8 +0mJhwQTtzuDFycgTE1XnqGOtjHsB/ncw4c5omwX4Eu55MaBBRTUoCnGkJE+M3DyC +B19m3H0Q/gxhswWV7uGugQ+o+MePTagjAiZrHYNSVc61LwDKgEDg4XSsYPWHgJ2u +NmSRXbBoGOqKYcl3qJfEycel/FVL8/B/uWU9J2jQzGv6U53hkRrJXRqWbTKH7QMg +yALOWr7Z6v2yTcQvG99fevX4i8buMTolUVVnjWQye+mew4K6Ki3pHrTgSAai/Gev +HyICc/sgCq+dVEuhzf9gR7A/Xe8bVr2XIZYtCtFenTgCR2y59PYjJbigapordwj6 +xLEokCZYCDzifqrXPW+6MYgKBesntaFJ7qBFVHvmJ2WZICGoo7z7GJa7Um8M7YNR +TOlZ4iBgxcJlkoKM8xAfDoqXvneCbT+PHV28SSe9zE8P4c52hgQjxcCMElv924Sg +JPFI/2R80L5cFtHvma3AH/vLrrw4IgYmZNralw4/KBVEqE8AyvCazM90arQ+POuV +7LXTWtiBmelDGDfrs7vRWGJB82bSj6p4lVQgw1oudCvV0b4YacCs1aTPObpRhANl +6WLAYv7YTVWW4tAR+kg0Eeye7QUd5MjWHYbL +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R3 O=Google Trust Services LLC +# Subject: CN=GTS Root R3 O=Google Trust Services LLC +# Label: "GTS Root R3" +# Serial: 159662495401136852707857743206 +# MD5 Fingerprint: 3e:e7:9d:58:02:94:46:51:94:e5:e0:22:4a:8b:e7:73 +# SHA1 Fingerprint: ed:e5:71:80:2b:c8:92:b9:5b:83:3c:d2:32:68:3f:09:cd:a0:1e:46 +# SHA256 Fingerprint: 34:d8:a7:3e:e2:08:d9:bc:db:0d:95:65:20:93:4b:4e:40:e6:94:82:59:6e:8b:6f:73:c8:42:6b:01:0a:6f:48 +-----BEGIN CERTIFICATE----- +MIICCTCCAY6gAwIBAgINAgPluILrIPglJ209ZjAKBggqhkjOPQQDAzBHMQswCQYD +VQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIG +A1UEAxMLR1RTIFJvb3QgUjMwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAw +WjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2Vz +IExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjMwdjAQBgcqhkjOPQIBBgUrgQQAIgNi +AAQfTzOHMymKoYTey8chWEGJ6ladK0uFxh1MJ7x/JlFyb+Kf1qPKzEUURout736G +jOyxfi//qXGdGIRFBEFVbivqJn+7kAHjSxm65FSWRQmx1WyRRK2EE46ajA2ADDL2 +4CejQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW +BBTB8Sa6oC2uhYHP0/EqEr24Cmf9vDAKBggqhkjOPQQDAwNpADBmAjEA9uEglRR7 +VKOQFhG/hMjqb2sXnh5GmCCbn9MN2azTL818+FsuVbu/3ZL3pAzcMeGiAjEA/Jdm +ZuVDFhOD3cffL74UOO0BzrEXGhF16b0DjyZ+hOXJYKaV11RZt+cRLInUue4X +-----END CERTIFICATE----- + +# Issuer: CN=GTS Root R4 O=Google Trust Services LLC +# Subject: CN=GTS Root R4 O=Google Trust Services LLC +# Label: "GTS Root R4" +# Serial: 159662532700760215368942768210 +# MD5 Fingerprint: 43:96:83:77:19:4d:76:b3:9d:65:52:e4:1d:22:a5:e8 +# SHA1 Fingerprint: 77:d3:03:67:b5:e0:0c:15:f6:0c:38:61:df:7c:e1:3b:92:46:4d:47 +# SHA256 Fingerprint: 34:9d:fa:40:58:c5:e2:63:12:3b:39:8a:e7:95:57:3c:4e:13:13:c8:3f:e6:8f:93:55:6c:d5:e8:03:1b:3c:7d +-----BEGIN CERTIFICATE----- +MIICCTCCAY6gAwIBAgINAgPlwGjvYxqccpBQUjAKBggqhkjOPQQDAzBHMQswCQYD +VQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIG +A1UEAxMLR1RTIFJvb3QgUjQwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAw +WjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2Vz +IExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjQwdjAQBgcqhkjOPQIBBgUrgQQAIgNi +AATzdHOnaItgrkO4NcWBMHtLSZ37wWHO5t5GvWvVYRg1rkDdc/eJkTBa6zzuhXyi +QHY7qca4R9gq55KRanPpsXI5nymfopjTX15YhmUPoYRlBtHci8nHc8iMai/lxKvR +HYqjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW +BBSATNbrdP9JNqPV2Py1PsVq8JQdjDAKBggqhkjOPQQDAwNpADBmAjEA6ED/g94D +9J+uHXqnLrmvT/aDHQ4thQEd0dlq7A/Cr8deVl5c1RxYIigL9zC2L7F8AjEA8GE8 +p/SgguMh1YQdc4acLa/KNJvxn7kjNuK8YAOdgLOaVsjh4rsUecrNIdSUtUlD +-----END CERTIFICATE----- + +# Issuer: CN=Telia Root CA v2 O=Telia Finland Oyj +# Subject: CN=Telia Root CA v2 O=Telia Finland Oyj +# Label: "Telia Root CA v2" +# Serial: 7288924052977061235122729490515358 +# MD5 Fingerprint: 0e:8f:ac:aa:82:df:85:b1:f4:dc:10:1c:fc:99:d9:48 +# SHA1 Fingerprint: b9:99:cd:d1:73:50:8a:c4:47:05:08:9c:8c:88:fb:be:a0:2b:40:cd +# SHA256 Fingerprint: 24:2b:69:74:2f:cb:1e:5b:2a:bf:98:89:8b:94:57:21:87:54:4e:5b:4d:99:11:78:65:73:62:1f:6a:74:b8:2c +-----BEGIN CERTIFICATE----- +MIIFdDCCA1ygAwIBAgIPAWdfJ9b+euPkrL4JWwWeMA0GCSqGSIb3DQEBCwUAMEQx +CzAJBgNVBAYTAkZJMRowGAYDVQQKDBFUZWxpYSBGaW5sYW5kIE95ajEZMBcGA1UE +AwwQVGVsaWEgUm9vdCBDQSB2MjAeFw0xODExMjkxMTU1NTRaFw00MzExMjkxMTU1 +NTRaMEQxCzAJBgNVBAYTAkZJMRowGAYDVQQKDBFUZWxpYSBGaW5sYW5kIE95ajEZ +MBcGA1UEAwwQVGVsaWEgUm9vdCBDQSB2MjCCAiIwDQYJKoZIhvcNAQEBBQADggIP +ADCCAgoCggIBALLQPwe84nvQa5n44ndp586dpAO8gm2h/oFlH0wnrI4AuhZ76zBq +AMCzdGh+sq/H1WKzej9Qyow2RCRj0jbpDIX2Q3bVTKFgcmfiKDOlyzG4OiIjNLh9 +vVYiQJ3q9HsDrWj8soFPmNB06o3lfc1jw6P23pLCWBnglrvFxKk9pXSW/q/5iaq9 +lRdU2HhE8Qx3FZLgmEKnpNaqIJLNwaCzlrI6hEKNfdWV5Nbb6WLEWLN5xYzTNTOD +n3WhUidhOPFZPY5Q4L15POdslv5e2QJltI5c0BE0312/UqeBAMN/mUWZFdUXyApT +7GPzmX3MaRKGwhfwAZ6/hLzRUssbkmbOpFPlob/E2wnW5olWK8jjfN7j/4nlNW4o +6GwLI1GpJQXrSPjdscr6bAhR77cYbETKJuFzxokGgeWKrLDiKca5JLNrRBH0pUPC +TEPlcDaMtjNXepUugqD0XBCzYYP2AgWGLnwtbNwDRm41k9V6lS/eINhbfpSQBGq6 +WT0EBXWdN6IOLj3rwaRSg/7Qa9RmjtzG6RJOHSpXqhC8fF6CfaamyfItufUXJ63R +DolUK5X6wK0dmBR4M0KGCqlztft0DbcbMBnEWg4cJ7faGND/isgFuvGqHKI3t+ZI +pEYslOqodmJHixBTB0hXbOKSTbauBcvcwUpej6w9GU7C7WB1K9vBykLVAgMBAAGj +YzBhMB8GA1UdIwQYMBaAFHKs5DN5qkWH9v2sHZ7Wxy+G2CQ5MB0GA1UdDgQWBBRy +rOQzeapFh/b9rB2e1scvhtgkOTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUw +AwEB/zANBgkqhkiG9w0BAQsFAAOCAgEAoDtZpwmUPjaE0n4vOaWWl/oRrfxn83EJ +8rKJhGdEr7nv7ZbsnGTbMjBvZ5qsfl+yqwE2foH65IRe0qw24GtixX1LDoJt0nZi +0f6X+J8wfBj5tFJ3gh1229MdqfDBmgC9bXXYfef6xzijnHDoRnkDry5023X4blMM +A8iZGok1GTzTyVR8qPAs5m4HeW9q4ebqkYJpCh3DflminmtGFZhb069GHWLIzoBS +SRE/yQQSwxN8PzuKlts8oB4KtItUsiRnDe+Cy748fdHif64W1lZYudogsYMVoe+K +TTJvQS8TUoKU1xrBeKJR3Stwbbca+few4GeXVtt8YVMJAygCQMez2P2ccGrGKMOF +6eLtGpOg3kuYooQ+BXcBlj37tCAPnHICehIv1aO6UXivKitEZU61/Qrowc15h2Er +3oBXRb9n8ZuRXqWk7FlIEA04x7D6w0RtBPV4UBySllva9bguulvP5fBqnUsvWHMt +Ty3EHD70sz+rFQ47GUGKpMFXEmZxTPpT41frYpUJnlTd0cI8Vzy9OK2YZLe4A5pT +VmBds9hCG1xLEooc6+t9xnppxyd/pPiL8uSUZodL6ZQHCRJ5irLrdATczvREWeAW +ysUsWNc8e89ihmpQfTU2Zqf7N+cox9jQraVplI/owd8k+BsHMYeB2F326CjYSlKA +rBPuUBQemMc= +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST BR Root CA 1 2020 O=D-Trust GmbH +# Subject: CN=D-TRUST BR Root CA 1 2020 O=D-Trust GmbH +# Label: "D-TRUST BR Root CA 1 2020" +# Serial: 165870826978392376648679885835942448534 +# MD5 Fingerprint: b5:aa:4b:d5:ed:f7:e3:55:2e:8f:72:0a:f3:75:b8:ed +# SHA1 Fingerprint: 1f:5b:98:f0:e3:b5:f7:74:3c:ed:e6:b0:36:7d:32:cd:f4:09:41:67 +# SHA256 Fingerprint: e5:9a:aa:81:60:09:c2:2b:ff:5b:25:ba:d3:7d:f3:06:f0:49:79:7c:1f:81:d8:5a:b0:89:e6:57:bd:8f:00:44 +-----BEGIN CERTIFICATE----- +MIIC2zCCAmCgAwIBAgIQfMmPK4TX3+oPyWWa00tNljAKBggqhkjOPQQDAzBIMQsw +CQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlELVRS +VVNUIEJSIFJvb3QgQ0EgMSAyMDIwMB4XDTIwMDIxMTA5NDUwMFoXDTM1MDIxMTA5 +NDQ1OVowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEiMCAG +A1UEAxMZRC1UUlVTVCBCUiBSb290IENBIDEgMjAyMDB2MBAGByqGSM49AgEGBSuB +BAAiA2IABMbLxyjR+4T1mu9CFCDhQ2tuda38KwOE1HaTJddZO0Flax7mNCq7dPYS +zuht56vkPE4/RAiLzRZxy7+SmfSk1zxQVFKQhYN4lGdnoxwJGT11NIXe7WB9xwy0 +QVK5buXuQqOCAQ0wggEJMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFHOREKv/ +VbNafAkl1bK6CKBrqx9tMA4GA1UdDwEB/wQEAwIBBjCBxgYDVR0fBIG+MIG7MD6g +PKA6hjhodHRwOi8vY3JsLmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X2JyX3Jvb3Rf +Y2FfMV8yMDIwLmNybDB5oHegdYZzbGRhcDovL2RpcmVjdG9yeS5kLXRydXN0Lm5l +dC9DTj1ELVRSVVNUJTIwQlIlMjBSb290JTIwQ0ElMjAxJTIwMjAyMCxPPUQtVHJ1 +c3QlMjBHbWJILEM9REU/Y2VydGlmaWNhdGVyZXZvY2F0aW9ubGlzdDAKBggqhkjO +PQQDAwNpADBmAjEAlJAtE/rhY/hhY+ithXhUkZy4kzg+GkHaQBZTQgjKL47xPoFW +wKrY7RjEsK70PvomAjEA8yjixtsrmfu3Ubgko6SUeho/5jbiA1czijDLgsfWFBHV +dWNbFJWcHwHP2NVypw87 +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST EV Root CA 1 2020 O=D-Trust GmbH +# Subject: CN=D-TRUST EV Root CA 1 2020 O=D-Trust GmbH +# Label: "D-TRUST EV Root CA 1 2020" +# Serial: 126288379621884218666039612629459926992 +# MD5 Fingerprint: 8c:2d:9d:70:9f:48:99:11:06:11:fb:e9:cb:30:c0:6e +# SHA1 Fingerprint: 61:db:8c:21:59:69:03:90:d8:7c:9c:12:86:54:cf:9d:3d:f4:dd:07 +# SHA256 Fingerprint: 08:17:0d:1a:a3:64:53:90:1a:2f:95:92:45:e3:47:db:0c:8d:37:ab:aa:bc:56:b8:1a:a1:00:dc:95:89:70:db +-----BEGIN CERTIFICATE----- +MIIC2zCCAmCgAwIBAgIQXwJB13qHfEwDo6yWjfv/0DAKBggqhkjOPQQDAzBIMQsw +CQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlELVRS +VVNUIEVWIFJvb3QgQ0EgMSAyMDIwMB4XDTIwMDIxMTEwMDAwMFoXDTM1MDIxMTA5 +NTk1OVowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEiMCAG +A1UEAxMZRC1UUlVTVCBFViBSb290IENBIDEgMjAyMDB2MBAGByqGSM49AgEGBSuB +BAAiA2IABPEL3YZDIBnfl4XoIkqbz52Yv7QFJsnL46bSj8WeeHsxiamJrSc8ZRCC +/N/DnU7wMyPE0jL1HLDfMxddxfCxivnvubcUyilKwg+pf3VlSSowZ/Rk99Yad9rD +wpdhQntJraOCAQ0wggEJMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFH8QARY3 +OqQo5FD4pPfsazK2/umLMA4GA1UdDwEB/wQEAwIBBjCBxgYDVR0fBIG+MIG7MD6g +PKA6hjhodHRwOi8vY3JsLmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X2V2X3Jvb3Rf +Y2FfMV8yMDIwLmNybDB5oHegdYZzbGRhcDovL2RpcmVjdG9yeS5kLXRydXN0Lm5l +dC9DTj1ELVRSVVNUJTIwRVYlMjBSb290JTIwQ0ElMjAxJTIwMjAyMCxPPUQtVHJ1 +c3QlMjBHbWJILEM9REU/Y2VydGlmaWNhdGVyZXZvY2F0aW9ubGlzdDAKBggqhkjO +PQQDAwNpADBmAjEAyjzGKnXCXnViOTYAYFqLwZOZzNnbQTs7h5kXO9XMT8oi96CA +y/m0sRtW9XLS/BnRAjEAkfcwkz8QRitxpNA7RJvAKQIFskF3UfN5Wp6OFKBOQtJb +gfM0agPnIjhQW+0ZT0MW +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert TLS ECC P384 Root G5 O=DigiCert, Inc. +# Subject: CN=DigiCert TLS ECC P384 Root G5 O=DigiCert, Inc. +# Label: "DigiCert TLS ECC P384 Root G5" +# Serial: 13129116028163249804115411775095713523 +# MD5 Fingerprint: d3:71:04:6a:43:1c:db:a6:59:e1:a8:a3:aa:c5:71:ed +# SHA1 Fingerprint: 17:f3:de:5e:9f:0f:19:e9:8e:f6:1f:32:26:6e:20:c4:07:ae:30:ee +# SHA256 Fingerprint: 01:8e:13:f0:77:25:32:cf:80:9b:d1:b1:72:81:86:72:83:fc:48:c6:e1:3b:e9:c6:98:12:85:4a:49:0c:1b:05 +-----BEGIN CERTIFICATE----- +MIICGTCCAZ+gAwIBAgIQCeCTZaz32ci5PhwLBCou8zAKBggqhkjOPQQDAzBOMQsw +CQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIEluYy4xJjAkBgNVBAMTHURp +Z2lDZXJ0IFRMUyBFQ0MgUDM4NCBSb290IEc1MB4XDTIxMDExNTAwMDAwMFoXDTQ2 +MDExNDIzNTk1OVowTjELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDkRpZ2lDZXJ0LCBJ +bmMuMSYwJAYDVQQDEx1EaWdpQ2VydCBUTFMgRUNDIFAzODQgUm9vdCBHNTB2MBAG +ByqGSM49AgEGBSuBBAAiA2IABMFEoc8Rl1Ca3iOCNQfN0MsYndLxf3c1TzvdlHJS +7cI7+Oz6e2tYIOyZrsn8aLN1udsJ7MgT9U7GCh1mMEy7H0cKPGEQQil8pQgO4CLp +0zVozptjn4S1mU1YoI71VOeVyaNCMEAwHQYDVR0OBBYEFMFRRVBZqz7nLFr6ICIS +B4CIfBFqMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MAoGCCqGSM49 +BAMDA2gAMGUCMQCJao1H5+z8blUD2WdsJk6Dxv3J+ysTvLd6jLRl0mlpYxNjOyZQ +LgGheQaRnUi/wr4CMEfDFXuxoJGZSZOoPHzoRgaLLPIxAJSdYsiJvRmEFOml+wG4 +DXZDjC5Ty3zfDBeWUA== +-----END CERTIFICATE----- + +# Issuer: CN=DigiCert TLS RSA4096 Root G5 O=DigiCert, Inc. +# Subject: CN=DigiCert TLS RSA4096 Root G5 O=DigiCert, Inc. +# Label: "DigiCert TLS RSA4096 Root G5" +# Serial: 11930366277458970227240571539258396554 +# MD5 Fingerprint: ac:fe:f7:34:96:a9:f2:b3:b4:12:4b:e4:27:41:6f:e1 +# SHA1 Fingerprint: a7:88:49:dc:5d:7c:75:8c:8c:de:39:98:56:b3:aa:d0:b2:a5:71:35 +# SHA256 Fingerprint: 37:1a:00:dc:05:33:b3:72:1a:7e:eb:40:e8:41:9e:70:79:9d:2b:0a:0f:2c:1d:80:69:31:65:f7:ce:c4:ad:75 +-----BEGIN CERTIFICATE----- +MIIFZjCCA06gAwIBAgIQCPm0eKj6ftpqMzeJ3nzPijANBgkqhkiG9w0BAQwFADBN +MQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIEluYy4xJTAjBgNVBAMT +HERpZ2lDZXJ0IFRMUyBSU0E0MDk2IFJvb3QgRzUwHhcNMjEwMTE1MDAwMDAwWhcN +NDYwMTE0MjM1OTU5WjBNMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQs +IEluYy4xJTAjBgNVBAMTHERpZ2lDZXJ0IFRMUyBSU0E0MDk2IFJvb3QgRzUwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCz0PTJeRGd/fxmgefM1eS87IE+ +ajWOLrfn3q/5B03PMJ3qCQuZvWxX2hhKuHisOjmopkisLnLlvevxGs3npAOpPxG0 +2C+JFvuUAT27L/gTBaF4HI4o4EXgg/RZG5Wzrn4DReW+wkL+7vI8toUTmDKdFqgp +wgscONyfMXdcvyej/Cestyu9dJsXLfKB2l2w4SMXPohKEiPQ6s+d3gMXsUJKoBZM +pG2T6T867jp8nVid9E6P/DsjyG244gXazOvswzH016cpVIDPRFtMbzCe88zdH5RD +nU1/cHAN1DrRN/BsnZvAFJNY781BOHW8EwOVfH/jXOnVDdXifBBiqmvwPXbzP6Po +sMH976pXTayGpxi0KcEsDr9kvimM2AItzVwv8n/vFfQMFawKsPHTDU9qTXeXAaDx +Zre3zu/O7Oyldcqs4+Fj97ihBMi8ez9dLRYiVu1ISf6nL3kwJZu6ay0/nTvEF+cd +Lvvyz6b84xQslpghjLSR6Rlgg/IwKwZzUNWYOwbpx4oMYIwo+FKbbuH2TbsGJJvX +KyY//SovcfXWJL5/MZ4PbeiPT02jP/816t9JXkGPhvnxd3lLG7SjXi/7RgLQZhNe +XoVPzthwiHvOAbWWl9fNff2C+MIkwcoBOU+NosEUQB+cZtUMCUbW8tDRSHZWOkPL +tgoRObqME2wGtZ7P6wIDAQABo0IwQDAdBgNVHQ4EFgQUUTMc7TZArxfTJc1paPKv +TiM+s0EwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcN +AQEMBQADggIBAGCmr1tfV9qJ20tQqcQjNSH/0GEwhJG3PxDPJY7Jv0Y02cEhJhxw +GXIeo8mH/qlDZJY6yFMECrZBu8RHANmfGBg7sg7zNOok992vIGCukihfNudd5N7H +PNtQOa27PShNlnx2xlv0wdsUpasZYgcYQF+Xkdycx6u1UQ3maVNVzDl92sURVXLF +O4uJ+DQtpBflF+aZfTCIITfNMBc9uPK8qHWgQ9w+iUuQrm0D4ByjoJYJu32jtyoQ +REtGBzRj7TG5BO6jm5qu5jF49OokYTurWGT/u4cnYiWB39yhL/btp/96j1EuMPik +AdKFOV8BmZZvWltwGUb+hmA+rYAQCd05JS9Yf7vSdPD3Rh9GOUrYU9DzLjtxpdRv +/PNn5AeP3SYZ4Y1b+qOTEZvpyDrDVWiakuFSdjjo4bq9+0/V77PnSIMx8IIh47a+ +p6tv75/fTM8BuGJqIz3nCU2AG3swpMPdB380vqQmsvZB6Akd4yCYqjdP//fx4ilw +MUc/dNAUFvohigLVigmUdy7yWSiLfFCSCmZ4OIN1xLVaqBHG5cGdZlXPU8Sv13WF +qUITVuwhd4GTWgzqltlJyqEI8pc7bZsEGCREjnwB8twl2F6GmrE52/WRMmrRpnCK +ovfepEWFJqgejF0pW8hL2JpqA15w8oVPbEtoL8pU9ozaMv7Da4M/OMZ+ +-----END CERTIFICATE----- + +# Issuer: CN=Certainly Root R1 O=Certainly +# Subject: CN=Certainly Root R1 O=Certainly +# Label: "Certainly Root R1" +# Serial: 188833316161142517227353805653483829216 +# MD5 Fingerprint: 07:70:d4:3e:82:87:a0:fa:33:36:13:f4:fa:33:e7:12 +# SHA1 Fingerprint: a0:50:ee:0f:28:71:f4:27:b2:12:6d:6f:50:96:25:ba:cc:86:42:af +# SHA256 Fingerprint: 77:b8:2c:d8:64:4c:43:05:f7:ac:c5:cb:15:6b:45:67:50:04:03:3d:51:c6:0c:62:02:a8:e0:c3:34:67:d3:a0 +-----BEGIN CERTIFICATE----- +MIIFRzCCAy+gAwIBAgIRAI4P+UuQcWhlM1T01EQ5t+AwDQYJKoZIhvcNAQELBQAw +PTELMAkGA1UEBhMCVVMxEjAQBgNVBAoTCUNlcnRhaW5seTEaMBgGA1UEAxMRQ2Vy +dGFpbmx5IFJvb3QgUjEwHhcNMjEwNDAxMDAwMDAwWhcNNDYwNDAxMDAwMDAwWjA9 +MQswCQYDVQQGEwJVUzESMBAGA1UEChMJQ2VydGFpbmx5MRowGAYDVQQDExFDZXJ0 +YWlubHkgUm9vdCBSMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANA2 +1B/q3avk0bbm+yLA3RMNansiExyXPGhjZjKcA7WNpIGD2ngwEc/csiu+kr+O5MQT +vqRoTNoCaBZ0vrLdBORrKt03H2As2/X3oXyVtwxwhi7xOu9S98zTm/mLvg7fMbed +aFySpvXl8wo0tf97ouSHocavFwDvA5HtqRxOcT3Si2yJ9HiG5mpJoM610rCrm/b0 +1C7jcvk2xusVtyWMOvwlDbMicyF0yEqWYZL1LwsYpfSt4u5BvQF5+paMjRcCMLT5 +r3gajLQ2EBAHBXDQ9DGQilHFhiZ5shGIXsXwClTNSaa/ApzSRKft43jvRl5tcdF5 +cBxGX1HpyTfcX35pe0HfNEXgO4T0oYoKNp43zGJS4YkNKPl6I7ENPT2a/Z2B7yyQ +wHtETrtJ4A5KVpK8y7XdeReJkd5hiXSSqOMyhb5OhaRLWcsrxXiOcVTQAjeZjOVJ +6uBUcqQRBi8LjMFbvrWhsFNunLhgkR9Za/kt9JQKl7XsxXYDVBtlUrpMklZRNaBA +2CnbrlJ2Oy0wQJuK0EJWtLeIAaSHO1OWzaMWj/Nmqhexx2DgwUMFDO6bW2BvBlyH +Wyf5QBGenDPBt+U1VwV/J84XIIwc/PH72jEpSe31C4SnT8H2TsIonPru4K8H+zMR +eiFPCyEQtkA6qyI6BJyLm4SGcprSp6XEtHWRqSsjAgMBAAGjQjBAMA4GA1UdDwEB +/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTgqj8ljZ9EXME66C6u +d0yEPmcM9DANBgkqhkiG9w0BAQsFAAOCAgEAuVevuBLaV4OPaAszHQNTVfSVcOQr +PbA56/qJYv331hgELyE03fFo8NWWWt7CgKPBjcZq91l3rhVkz1t5BXdm6ozTaw3d +8VkswTOlMIAVRQdFGjEitpIAq5lNOo93r6kiyi9jyhXWx8bwPWz8HA2YEGGeEaIi +1wrykXprOQ4vMMM2SZ/g6Q8CRFA3lFV96p/2O7qUpUzpvD5RtOjKkjZUbVwlKNrd +rRT90+7iIgXr0PK3aBLXWopBGsaSpVo7Y0VPv+E6dyIvXL9G+VoDhRNCX8reU9di +taY1BMJH/5n9hN9czulegChB8n3nHpDYT3Y+gjwN/KUD+nsa2UUeYNrEjvn8K8l7 +lcUq/6qJ34IxD3L/DCfXCh5WAFAeDJDBlrXYFIW7pw0WwfgHJBu6haEaBQmAupVj +yTrsJZ9/nbqkRxWbRHDxakvWOF5D8xh+UG7pWijmZeZ3Gzr9Hb4DJqPb1OG7fpYn +Kx3upPvaJVQTA945xsMfTZDsjxtK0hzthZU4UHlG1sGQUDGpXJpuHfUzVounmdLy +yCwzk5Iwx06MZTMQZBf9JBeW0Y3COmor6xOLRPIh80oat3df1+2IpHLlOR+Vnb5n +wXARPbv0+Em34yaXOp/SX3z7wJl8OSngex2/DaeP0ik0biQVy96QXr8axGbqwua6 +OV+KmalBWQewLK8= +-----END CERTIFICATE----- + +# Issuer: CN=Certainly Root E1 O=Certainly +# Subject: CN=Certainly Root E1 O=Certainly +# Label: "Certainly Root E1" +# Serial: 8168531406727139161245376702891150584 +# MD5 Fingerprint: 0a:9e:ca:cd:3e:52:50:c6:36:f3:4b:a3:ed:a7:53:e9 +# SHA1 Fingerprint: f9:e1:6d:dc:01:89:cf:d5:82:45:63:3e:c5:37:7d:c2:eb:93:6f:2b +# SHA256 Fingerprint: b4:58:5f:22:e4:ac:75:6a:4e:86:12:a1:36:1c:5d:9d:03:1a:93:fd:84:fe:bb:77:8f:a3:06:8b:0f:c4:2d:c2 +-----BEGIN CERTIFICATE----- +MIIB9zCCAX2gAwIBAgIQBiUzsUcDMydc+Y2aub/M+DAKBggqhkjOPQQDAzA9MQsw +CQYDVQQGEwJVUzESMBAGA1UEChMJQ2VydGFpbmx5MRowGAYDVQQDExFDZXJ0YWlu +bHkgUm9vdCBFMTAeFw0yMTA0MDEwMDAwMDBaFw00NjA0MDEwMDAwMDBaMD0xCzAJ +BgNVBAYTAlVTMRIwEAYDVQQKEwlDZXJ0YWlubHkxGjAYBgNVBAMTEUNlcnRhaW5s +eSBSb290IEUxMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAE3m/4fxzf7flHh4axpMCK ++IKXgOqPyEpeKn2IaKcBYhSRJHpcnqMXfYqGITQYUBsQ3tA3SybHGWCA6TS9YBk2 +QNYphwk8kXr2vBMj3VlOBF7PyAIcGFPBMdjaIOlEjeR2o0IwQDAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQU8ygYy2R17ikq6+2uI1g4 +hevIIgcwCgYIKoZIzj0EAwMDaAAwZQIxALGOWiDDshliTd6wT99u0nCK8Z9+aozm +ut6Dacpps6kFtZaSF4fC0urQe87YQVt8rgIwRt7qy12a7DLCZRawTDBcMPPaTnOG +BtjOiQRINzf43TNRnXCve1XYAS59BWQOhriR +-----END CERTIFICATE----- + +# Issuer: CN=E-Tugra Global Root CA RSA v3 O=E-Tugra EBG A.S. OU=E-Tugra Trust Center +# Subject: CN=E-Tugra Global Root CA RSA v3 O=E-Tugra EBG A.S. OU=E-Tugra Trust Center +# Label: "E-Tugra Global Root CA RSA v3" +# Serial: 75951268308633135324246244059508261641472512052 +# MD5 Fingerprint: 22:be:10:f6:c2:f8:03:88:73:5f:33:29:47:28:47:a4 +# SHA1 Fingerprint: e9:a8:5d:22:14:52:1c:5b:aa:0a:b4:be:24:6a:23:8a:c9:ba:e2:a9 +# SHA256 Fingerprint: ef:66:b0:b1:0a:3c:db:9f:2e:36:48:c7:6b:d2:af:18:ea:d2:bf:e6:f1:17:65:5e:28:c4:06:0d:a1:a3:f4:c2 +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=E-Tugra Global Root CA ECC v3 O=E-Tugra EBG A.S. OU=E-Tugra Trust Center +# Subject: CN=E-Tugra Global Root CA ECC v3 O=E-Tugra EBG A.S. OU=E-Tugra Trust Center +# Label: "E-Tugra Global Root CA ECC v3" +# Serial: 218504919822255052842371958738296604628416471745 +# MD5 Fingerprint: 46:bc:81:bb:f1:b5:1e:f7:4b:96:bc:14:e2:e7:27:64 +# SHA1 Fingerprint: 8a:2f:af:57:53:b1:b0:e6:a1:04:ec:5b:6a:69:71:6d:f6:1c:e2:84 +# SHA256 Fingerprint: 87:3f:46:85:fa:7f:56:36:25:25:2e:6d:36:bc:d7:f1:6f:c2:49:51:f2:64:e4:7e:1b:95:4f:49:08:cd:ca:13 +-----BEGIN CERTIFICATE----- +MIICpTCCAiqgAwIBAgIUJkYZdzHhT28oNt45UYbm1JeIIsEwCgYIKoZIzj0EAwMw +gYAxCzAJBgNVBAYTAlRSMQ8wDQYDVQQHEwZBbmthcmExGTAXBgNVBAoTEEUtVHVn +cmEgRUJHIEEuUy4xHTAbBgNVBAsTFEUtVHVncmEgVHJ1c3QgQ2VudGVyMSYwJAYD +VQQDEx1FLVR1Z3JhIEdsb2JhbCBSb290IENBIEVDQyB2MzAeFw0yMDAzMTgwOTQ2 +NThaFw00NTAzMTIwOTQ2NThaMIGAMQswCQYDVQQGEwJUUjEPMA0GA1UEBxMGQW5r +YXJhMRkwFwYDVQQKExBFLVR1Z3JhIEVCRyBBLlMuMR0wGwYDVQQLExRFLVR1Z3Jh +IFRydXN0IENlbnRlcjEmMCQGA1UEAxMdRS1UdWdyYSBHbG9iYWwgUm9vdCBDQSBF +Q0MgdjMwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAASOmCm/xxAeJ9urA8woLNheSBkQ +KczLWYHMjLiSF4mDKpL2w6QdTGLVn9agRtwcvHbB40fQWxPa56WzZkjnIZpKT4YK +fWzqTTKACrJ6CZtpS5iB4i7sAnCWH/31Rs7K3IKjYzBhMA8GA1UdEwEB/wQFMAMB +Af8wHwYDVR0jBBgwFoAU/4Ixcj75xGZsrTie0bBRiKWQzPUwHQYDVR0OBBYEFP+C +MXI++cRmbK04ntGwUYilkMz1MA4GA1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNp +ADBmAjEA5gVYaWHlLcoNy/EZCL3W/VGSGn5jVASQkZo1kTmZ+gepZpO6yGjUij/6 +7W4WAie3AjEA3VoXK3YdZUKWpqxdinlW2Iob35reX8dQj7FbcQwm32pAAOwzkSFx +vmjkI6TZraE3 +-----END CERTIFICATE----- + +# Issuer: CN=Security Communication RootCA3 O=SECOM Trust Systems CO.,LTD. +# Subject: CN=Security Communication RootCA3 O=SECOM Trust Systems CO.,LTD. +# Label: "Security Communication RootCA3" +# Serial: 16247922307909811815 +# MD5 Fingerprint: 1c:9a:16:ff:9e:5c:e0:4d:8a:14:01:f4:35:5d:29:26 +# SHA1 Fingerprint: c3:03:c8:22:74:92:e5:61:a2:9c:5f:79:91:2b:1e:44:13:91:30:3a +# SHA256 Fingerprint: 24:a5:5c:2a:b0:51:44:2d:06:17:76:65:41:23:9a:4a:d0:32:d7:c5:51:75:aa:34:ff:de:2f:bc:4f:5c:52:94 +-----BEGIN CERTIFICATE----- +MIIFfzCCA2egAwIBAgIJAOF8N0D9G/5nMA0GCSqGSIb3DQEBDAUAMF0xCzAJBgNV +BAYTAkpQMSUwIwYDVQQKExxTRUNPTSBUcnVzdCBTeXN0ZW1zIENPLixMVEQuMScw +JQYDVQQDEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTMwHhcNMTYwNjE2 +MDYxNzE2WhcNMzgwMTE4MDYxNzE2WjBdMQswCQYDVQQGEwJKUDElMCMGA1UEChMc +U0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UEAxMeU2VjdXJpdHkg +Q29tbXVuaWNhdGlvbiBSb290Q0EzMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIIC +CgKCAgEA48lySfcw3gl8qUCBWNO0Ot26YQ+TUG5pPDXC7ltzkBtnTCHsXzW7OT4r +CmDvu20rhvtxosis5FaU+cmvsXLUIKx00rgVrVH+hXShuRD+BYD5UpOzQD11EKzA +lrenfna84xtSGc4RHwsENPXY9Wk8d/Nk9A2qhd7gCVAEF5aEt8iKvE1y/By7z/MG +TfmfZPd+pmaGNXHIEYBMwXFAWB6+oHP2/D5Q4eAvJj1+XCO1eXDe+uDRpdYMQXF7 +9+qMHIjH7Iv10S9VlkZ8WjtYO/u62C21Jdp6Ts9EriGmnpjKIG58u4iFW/vAEGK7 +8vknR+/RiTlDxN/e4UG/VHMgly1s2vPUB6PmudhvrvyMGS7TZ2crldtYXLVqAvO4 +g160a75BflcJdURQVc1aEWEhCmHCqYj9E7wtiS/NYeCVvsq1e+F7NGcLH7YMx3we +GVPKp7FKFSBWFHA9K4IsD50VHUeAR/94mQ4xr28+j+2GaR57GIgUssL8gjMunEst ++3A7caoreyYn8xrC3PsXuKHqy6C0rtOUfnrQq8PsOC0RLoi/1D+tEjtCrI8Cbn3M +0V9hvqG8OmpI6iZVIhZdXw3/JzOfGAN0iltSIEdrRU0id4xVJ/CvHozJgyJUt5rQ +T9nO/NkuHJYosQLTA70lUhw0Zk8jq/R3gpYd0VcwCBEF/VfR2ccCAwEAAaNCMEAw +HQYDVR0OBBYEFGQUfPxYchamCik0FW8qy7z8r6irMA4GA1UdDwEB/wQEAwIBBjAP +BgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEBDAUAA4ICAQDcAiMI4u8hOscNtybS +YpOnpSNyByCCYN8Y11StaSWSntkUz5m5UoHPrmyKO1o5yGwBQ8IibQLwYs1OY0PA +FNr0Y/Dq9HHuTofjcan0yVflLl8cebsjqodEV+m9NU1Bu0soo5iyG9kLFwfl9+qd +9XbXv8S2gVj/yP9kaWJ5rW4OH3/uHWnlt3Jxs/6lATWUVCvAUm2PVcTJ0rjLyjQI +UYWg9by0F1jqClx6vWPGOi//lkkZhOpn2ASxYfQAW0q3nHE3GYV5v4GwxxMOdnE+ +OoAGrgYWp421wsTL/0ClXI2lyTrtcoHKXJg80jQDdwj98ClZXSEIx2C/pHF7uNke +gr4Jr2VvKKu/S7XuPghHJ6APbw+LP6yVGPO5DtxnVW5inkYO0QR4ynKudtml+LLf +iAlhi+8kTtFZP1rUPcmTPCtk9YENFpb3ksP+MW/oKjJ0DvRMmEoYDjBU1cXrvMUV +nuiZIesnKwkK2/HmcBhWuwzkvvnoEKQTkrgc4NtnHVMDpCKn3F2SEDzq//wbEBrD +2NCcnWXL0CsnMQMeNuE9dnUM/0Umud1RvCPHX9jYhxBAEg09ODfnRDwYwFMJZI// +1ZqmfHAuc1Uh6N//g7kdPjIe1qZ9LPFm6Vwdp6POXiUyK+OVrCoHzrQoeIY8Laad +TdJ0MN1kURXbg4NR16/9M51NZg== +-----END CERTIFICATE----- + +# Issuer: CN=Security Communication ECC RootCA1 O=SECOM Trust Systems CO.,LTD. +# Subject: CN=Security Communication ECC RootCA1 O=SECOM Trust Systems CO.,LTD. +# Label: "Security Communication ECC RootCA1" +# Serial: 15446673492073852651 +# MD5 Fingerprint: 7e:43:b0:92:68:ec:05:43:4c:98:ab:5d:35:2e:7e:86 +# SHA1 Fingerprint: b8:0e:26:a9:bf:d2:b2:3b:c0:ef:46:c9:ba:c7:bb:f6:1d:0d:41:41 +# SHA256 Fingerprint: e7:4f:bd:a5:5b:d5:64:c4:73:a3:6b:44:1a:a7:99:c8:a6:8e:07:74:40:e8:28:8b:9f:a1:e5:0e:4b:ba:ca:11 +-----BEGIN CERTIFICATE----- +MIICODCCAb6gAwIBAgIJANZdm7N4gS7rMAoGCCqGSM49BAMDMGExCzAJBgNVBAYT +AkpQMSUwIwYDVQQKExxTRUNPTSBUcnVzdCBTeXN0ZW1zIENPLixMVEQuMSswKQYD +VQQDEyJTZWN1cml0eSBDb21tdW5pY2F0aW9uIEVDQyBSb290Q0ExMB4XDTE2MDYx +NjA1MTUyOFoXDTM4MDExODA1MTUyOFowYTELMAkGA1UEBhMCSlAxJTAjBgNVBAoT +HFNFQ09NIFRydXN0IFN5c3RlbXMgQ08uLExURC4xKzApBgNVBAMTIlNlY3VyaXR5 +IENvbW11bmljYXRpb24gRUNDIFJvb3RDQTEwdjAQBgcqhkjOPQIBBgUrgQQAIgNi +AASkpW9gAwPDvTH00xecK4R1rOX9PVdu12O/5gSJko6BnOPpR27KkBLIE+Cnnfdl +dB9sELLo5OnvbYUymUSxXv3MdhDYW72ixvnWQuRXdtyQwjWpS4g8EkdtXP9JTxpK +ULGjQjBAMB0GA1UdDgQWBBSGHOf+LaVKiwj+KBH6vqNm+GBZLzAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjAVXUI9/Lbu +9zuxNuie9sRGKEkz0FhDKmMpzE2xtHqiuQ04pV1IKv3LsnNdo4gIxwwCMQDAqy0O +be0YottT6SXbVQjgUMzfRGEWgqtJsLKB7HOHeLRMsmIbEvoWTSVLY70eN9k= +-----END CERTIFICATE----- + +# Issuer: CN=BJCA Global Root CA1 O=BEIJING CERTIFICATE AUTHORITY +# Subject: CN=BJCA Global Root CA1 O=BEIJING CERTIFICATE AUTHORITY +# Label: "BJCA Global Root CA1" +# Serial: 113562791157148395269083148143378328608 +# MD5 Fingerprint: 42:32:99:76:43:33:36:24:35:07:82:9b:28:f9:d0:90 +# SHA1 Fingerprint: d5:ec:8d:7b:4c:ba:79:f4:e7:e8:cb:9d:6b:ae:77:83:10:03:21:6a +# SHA256 Fingerprint: f3:89:6f:88:fe:7c:0a:88:27:66:a7:fa:6a:d2:74:9f:b5:7a:7f:3e:98:fb:76:9c:1f:a7:b0:9c:2c:44:d5:ae +-----BEGIN CERTIFICATE----- +MIIFdDCCA1ygAwIBAgIQVW9l47TZkGobCdFsPsBsIDANBgkqhkiG9w0BAQsFADBU +MQswCQYDVQQGEwJDTjEmMCQGA1UECgwdQkVJSklORyBDRVJUSUZJQ0FURSBBVVRI +T1JJVFkxHTAbBgNVBAMMFEJKQ0EgR2xvYmFsIFJvb3QgQ0ExMB4XDTE5MTIxOTAz +MTYxN1oXDTQ0MTIxMjAzMTYxN1owVDELMAkGA1UEBhMCQ04xJjAkBgNVBAoMHUJF +SUpJTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZMR0wGwYDVQQDDBRCSkNBIEdsb2Jh +bCBSb290IENBMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAPFmCL3Z +xRVhy4QEQaVpN3cdwbB7+sN3SJATcmTRuHyQNZ0YeYjjlwE8R4HyDqKYDZ4/N+AZ +spDyRhySsTphzvq3Rp4Dhtczbu33RYx2N95ulpH3134rhxfVizXuhJFyV9xgw8O5 +58dnJCNPYwpj9mZ9S1WnP3hkSWkSl+BMDdMJoDIwOvqfwPKcxRIqLhy1BDPapDgR +at7GGPZHOiJBhyL8xIkoVNiMpTAK+BcWyqw3/XmnkRd4OJmtWO2y3syJfQOcs4ll +5+M7sSKGjwZteAf9kRJ/sGsciQ35uMt0WwfCyPQ10WRjeulumijWML3mG90Vr4Tq +nMfK9Q7q8l0ph49pczm+LiRvRSGsxdRpJQaDrXpIhRMsDQa4bHlW/KNnMoH1V6XK +V0Jp6VwkYe/iMBhORJhVb3rCk9gZtt58R4oRTklH2yiUAguUSiz5EtBP6DF+bHq/ +pj+bOT0CFqMYs2esWz8sgytnOYFcuX6U1WTdno9uruh8W7TXakdI136z1C2OVnZO +z2nxbkRs1CTqjSShGL+9V/6pmTW12xB3uD1IutbB5/EjPtffhZ0nPNRAvQoMvfXn +jSXWgXSHRtQpdaJCbPdzied9v3pKH9MiyRVVz99vfFXQpIsHETdfg6YmV6YBW37+ +WGgHqel62bno/1Afq8K0wM7o6v0PvY1NuLxxAgMBAAGjQjBAMB0GA1UdDgQWBBTF +7+3M2I0hxkjk49cULqcWk+WYATAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQE +AwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAUoKsITQfI/Ki2Pm4rzc2IInRNwPWaZ+4 +YRC6ojGYWUfo0Q0lHhVBDOAqVdVXUsv45Mdpox1NcQJeXyFFYEhcCY5JEMEE3Kli +awLwQ8hOnThJdMkycFRtwUf8jrQ2ntScvd0g1lPJGKm1Vrl2i5VnZu69mP6u775u ++2D2/VnGKhs/I0qUJDAnyIm860Qkmss9vk/Ves6OF8tiwdneHg56/0OGNFK8YT88 +X7vZdrRTvJez/opMEi4r89fO4aL/3Xtw+zuhTaRjAv04l5U/BXCga99igUOLtFkN +SoxUnMW7gZ/NfaXvCyUeOiDbHPwfmGcCCtRzRBPbUYQaVQNW4AB+dAb/OMRyHdOo +P2gxXdMJxy6MW2Pg6Nwe0uxhHvLe5e/2mXZgLR6UcnHGCyoyx5JO1UbXHfmpGQrI ++pXObSOYqgs4rZpWDW+N8TEAiMEXnM0ZNjX+VVOg4DwzX5Ze4jLp3zO7Bkqp2IRz +znfSxqxx4VyjHQy7Ct9f4qNx2No3WqB4K/TUfet27fJhcKVlmtOJNBir+3I+17Q9 +eVzYH6Eze9mCUAyTF6ps3MKCuwJXNq+YJyo5UOGwifUll35HaBC07HPKs5fRJNz2 +YqAo07WjuGS3iGJCz51TzZm+ZGiPTx4SSPfSKcOYKMryMguTjClPPGAyzQWWYezy +r/6zcCwupvI= +-----END CERTIFICATE----- + +# Issuer: CN=BJCA Global Root CA2 O=BEIJING CERTIFICATE AUTHORITY +# Subject: CN=BJCA Global Root CA2 O=BEIJING CERTIFICATE AUTHORITY +# Label: "BJCA Global Root CA2" +# Serial: 58605626836079930195615843123109055211 +# MD5 Fingerprint: 5e:0a:f6:47:5f:a6:14:e8:11:01:95:3f:4d:01:eb:3c +# SHA1 Fingerprint: f4:27:86:eb:6e:b8:6d:88:31:67:02:fb:ba:66:a4:53:00:aa:7a:a6 +# SHA256 Fingerprint: 57:4d:f6:93:1e:27:80:39:66:7b:72:0a:fd:c1:60:0f:c2:7e:b6:6d:d3:09:29:79:fb:73:85:64:87:21:28:82 +-----BEGIN CERTIFICATE----- +MIICJTCCAaugAwIBAgIQLBcIfWQqwP6FGFkGz7RK6zAKBggqhkjOPQQDAzBUMQsw +CQYDVQQGEwJDTjEmMCQGA1UECgwdQkVJSklORyBDRVJUSUZJQ0FURSBBVVRIT1JJ +VFkxHTAbBgNVBAMMFEJKQ0EgR2xvYmFsIFJvb3QgQ0EyMB4XDTE5MTIxOTAzMTgy +MVoXDTQ0MTIxMjAzMTgyMVowVDELMAkGA1UEBhMCQ04xJjAkBgNVBAoMHUJFSUpJ +TkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZMR0wGwYDVQQDDBRCSkNBIEdsb2JhbCBS +b290IENBMjB2MBAGByqGSM49AgEGBSuBBAAiA2IABJ3LgJGNU2e1uVCxA/jlSR9B +IgmwUVJY1is0j8USRhTFiy8shP8sbqjV8QnjAyEUxEM9fMEsxEtqSs3ph+B99iK+ ++kpRuDCK/eHeGBIK9ke35xe/J4rUQUyWPGCWwf0VHKNCMEAwHQYDVR0OBBYEFNJK +sVF/BvDRgh9Obl+rg/xI1LCRMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD +AgEGMAoGCCqGSM49BAMDA2gAMGUCMBq8W9f+qdJUDkpd0m2xQNz0Q9XSSpkZElaA +94M04TVOSG0ED1cxMDAtsaqdAzjbBgIxAMvMh1PLet8gUXOQwKhbYdDFUDn9hf7B +43j4ptZLvZuHjw/l1lOWqzzIQNph91Oj9w== +-----END CERTIFICATE----- diff --git a/env/Lib/site-packages/pip/_vendor/certifi/core.py b/env/Lib/site-packages/pip/_vendor/certifi/core.py index b8140cf1..c3e54660 100644 --- a/env/Lib/site-packages/pip/_vendor/certifi/core.py +++ b/env/Lib/site-packages/pip/_vendor/certifi/core.py @@ -1,34 +1,20 @@ -# -*- coding: utf-8 -*- - """ certifi.py ~~~~~~~~~~ This module returns the installation location of cacert.pem or its contents. """ -import os - +import sys -class _PipPatchedCertificate(Exception): - pass +if sys.version_info >= (3, 11): -try: - # Return a certificate file on disk for a standalone pip zipapp running in - # an isolated build environment to use. Passing --cert to the standalone - # pip does not work since requests calls where() unconditionally on import. - _PIP_STANDALONE_CERT = os.environ.get("_PIP_STANDALONE_CERT") - if _PIP_STANDALONE_CERT: - def where(): - return _PIP_STANDALONE_CERT - raise _PipPatchedCertificate() - - from importlib.resources import path as get_path, read_text + from importlib.resources import as_file, files _CACERT_CTX = None _CACERT_PATH = None - def where(): + def where() -> str: # This is slightly terrible, but we want to delay extracting the file # in cases where we're inside of a zipimport situation until someone # actually calls where(), but we don't want to re-extract the file @@ -47,30 +33,76 @@ try: # We also have to hold onto the actual context manager, because # it will do the cleanup whenever it gets garbage collected, so # we will also store that at the global level as well. + _CACERT_CTX = as_file(files("pip._vendor.certifi").joinpath("cacert.pem")) + _CACERT_PATH = str(_CACERT_CTX.__enter__()) + + return _CACERT_PATH + + def contents() -> str: + return files("pip._vendor.certifi").joinpath("cacert.pem").read_text(encoding="ascii") + +elif sys.version_info >= (3, 7): + + from importlib.resources import path as get_path, read_text + + _CACERT_CTX = None + _CACERT_PATH = None + + def where() -> str: + # This is slightly terrible, but we want to delay extracting the + # file in cases where we're inside of a zipimport situation until + # someone actually calls where(), but we don't want to re-extract + # the file on every call of where(), so we'll do it once then store + # it in a global variable. + global _CACERT_CTX + global _CACERT_PATH + if _CACERT_PATH is None: + # This is slightly janky, the importlib.resources API wants you + # to manage the cleanup of this file, so it doesn't actually + # return a path, it returns a context manager that will give + # you the path when you enter it and will do any cleanup when + # you leave it. In the common case of not needing a temporary + # file, it will just return the file system location and the + # __exit__() is a no-op. + # + # We also have to hold onto the actual context manager, because + # it will do the cleanup whenever it gets garbage collected, so + # we will also store that at the global level as well. _CACERT_CTX = get_path("pip._vendor.certifi", "cacert.pem") _CACERT_PATH = str(_CACERT_CTX.__enter__()) return _CACERT_PATH -except _PipPatchedCertificate: - pass + def contents() -> str: + return read_text("pip._vendor.certifi", "cacert.pem", encoding="ascii") + +else: + import os + import types + from typing import Union + + Package = Union[types.ModuleType, str] + Resource = Union[str, "os.PathLike"] -except ImportError: # This fallback will work for Python versions prior to 3.7 that lack the # importlib.resources module but relies on the existing `where` function # so won't address issues with environments like PyOxidizer that don't set # __file__ on modules. - def read_text(_module, _path, encoding="ascii"): - with open(where(), "r", encoding=encoding) as data: + def read_text( + package: Package, + resource: Resource, + encoding: str = 'utf-8', + errors: str = 'strict' + ) -> str: + with open(where(), encoding=encoding) as data: return data.read() # If we don't have importlib.resources, then we will just do the old logic # of assuming we're on the filesystem and munge the path directly. - def where(): + def where() -> str: f = os.path.dirname(__file__) return os.path.join(f, "cacert.pem") - -def contents(): - return read_text("certifi", "cacert.pem", encoding="ascii") + def contents() -> str: + return read_text("pip._vendor.certifi", "cacert.pem", encoding="ascii") diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__init__.py b/env/Lib/site-packages/pip/_vendor/chardet/__init__.py index 80ad2546..fe581623 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/__init__.py @@ -15,69 +15,101 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from typing import List, Union -from .universaldetector import UniversalDetector +from .charsetgroupprober import CharSetGroupProber +from .charsetprober import CharSetProber from .enums import InputState -from .version import __version__, VERSION - +from .resultdict import ResultDict +from .universaldetector import UniversalDetector +from .version import VERSION, __version__ -__all__ = ['UniversalDetector', 'detect', 'detect_all', '__version__', 'VERSION'] +__all__ = ["UniversalDetector", "detect", "detect_all", "__version__", "VERSION"] -def detect(byte_str): +def detect( + byte_str: Union[bytes, bytearray], should_rename_legacy: bool = False +) -> ResultDict: """ Detect the encoding of the given byte string. :param byte_str: The byte sequence to examine. :type byte_str: ``bytes`` or ``bytearray`` + :param should_rename_legacy: Should we rename legacy encodings + to their more modern equivalents? + :type should_rename_legacy: ``bool`` """ if not isinstance(byte_str, bytearray): if not isinstance(byte_str, bytes): - raise TypeError('Expected object of type bytes or bytearray, got: ' - '{}'.format(type(byte_str))) - else: - byte_str = bytearray(byte_str) - detector = UniversalDetector() + raise TypeError( + f"Expected object of type bytes or bytearray, got: {type(byte_str)}" + ) + byte_str = bytearray(byte_str) + detector = UniversalDetector(should_rename_legacy=should_rename_legacy) detector.feed(byte_str) return detector.close() -def detect_all(byte_str): +def detect_all( + byte_str: Union[bytes, bytearray], + ignore_threshold: bool = False, + should_rename_legacy: bool = False, +) -> List[ResultDict]: """ Detect all the possible encodings of the given byte string. - :param byte_str: The byte sequence to examine. - :type byte_str: ``bytes`` or ``bytearray`` + :param byte_str: The byte sequence to examine. + :type byte_str: ``bytes`` or ``bytearray`` + :param ignore_threshold: Include encodings that are below + ``UniversalDetector.MINIMUM_THRESHOLD`` + in results. + :type ignore_threshold: ``bool`` + :param should_rename_legacy: Should we rename legacy encodings + to their more modern equivalents? + :type should_rename_legacy: ``bool`` """ if not isinstance(byte_str, bytearray): if not isinstance(byte_str, bytes): - raise TypeError('Expected object of type bytes or bytearray, got: ' - '{}'.format(type(byte_str))) - else: - byte_str = bytearray(byte_str) + raise TypeError( + f"Expected object of type bytes or bytearray, got: {type(byte_str)}" + ) + byte_str = bytearray(byte_str) - detector = UniversalDetector() + detector = UniversalDetector(should_rename_legacy=should_rename_legacy) detector.feed(byte_str) detector.close() - if detector._input_state == InputState.HIGH_BYTE: - results = [] - for prober in detector._charset_probers: - if prober.get_confidence() > detector.MINIMUM_THRESHOLD: - charset_name = prober.charset_name - lower_charset_name = prober.charset_name.lower() + if detector.input_state == InputState.HIGH_BYTE: + results: List[ResultDict] = [] + probers: List[CharSetProber] = [] + for prober in detector.charset_probers: + if isinstance(prober, CharSetGroupProber): + probers.extend(p for p in prober.probers) + else: + probers.append(prober) + for prober in probers: + if ignore_threshold or prober.get_confidence() > detector.MINIMUM_THRESHOLD: + charset_name = prober.charset_name or "" + lower_charset_name = charset_name.lower() # Use Windows encoding name instead of ISO-8859 if we saw any # extra Windows-specific bytes - if lower_charset_name.startswith('iso-8859'): - if detector._has_win_bytes: - charset_name = detector.ISO_WIN_MAP.get(lower_charset_name, - charset_name) - results.append({ - 'encoding': charset_name, - 'confidence': prober.get_confidence(), - 'language': prober.language, - }) + if lower_charset_name.startswith("iso-8859") and detector.has_win_bytes: + charset_name = detector.ISO_WIN_MAP.get( + lower_charset_name, charset_name + ) + # Rename legacy encodings with superset encodings if asked + if should_rename_legacy: + charset_name = detector.LEGACY_MAP.get( + charset_name.lower(), charset_name + ) + results.append( + { + "encoding": charset_name, + "confidence": prober.get_confidence(), + "language": prober.language, + } + ) if len(results) > 0: - return sorted(results, key=lambda result: -result['confidence']) + return sorted(results, key=lambda result: -result["confidence"]) return [detector.result] diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 242690e3905fc3d2bea64f9fed1f46a5a0a00a9d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1927 zcmYe~<>g{vU|^UdaWM5b4+Fzv5C<7EF)%PVFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0 zxy(__U^a6OOD<~^Yc5+98zVzHLki0x#whj_))clDhA55{_7sj5hA7Sy&R_;ju9u7q z3=Eo#w**7;GRsnniW75OQcF^kOY(~}8E<iU<`tBd1eYY1q-rwV;*O68smRRFi;us> z9_AVp?CI~P$yx+*)h)IZu(n%V5IR0FC#Q&ofq|ijm4SgF8Dt5}BOv7<L1&OhJQx@l zN*HPwN*J4&iVeUlre>yMjS}V*#sw@TtThbHj0+i?8JigMI7%2nyjq45wq}M}#u~;2 z>@^Gv85tRB7#DCXWC&)^WU5-srJ$go0P%rBNk*zdYF=`FN@iZVLVg;UpPpHknx~Ld zS(2(yTvC*om#)VJ)?!tVSd^FxmWVGdDY60?qY#pj3Kmf)PAx1=%}Y*ID9Kkytw_wx z%uCgSXe+5KfT%&}Qb<SunO~fcppah#<s=prB~~URfc5+`cC9E#O)g1IQOHlqN=+^S zyA5VeF-Q|gKUj;7LVA9Ql|pr`Cg&}#%;L<v;*!L?<kVZ7a22;$LCoS?oFSD3sjfvu z`9-(b((;RP6H9KffE)*j9hS7z)RbGS$vOGOpqS(U=>fU;76&A{@{3k76bUmhF#Kw8 zwu%WYPAw{qNzF;gEQ;~ZOLZyAEK60;RS5O-1V?&^W3Ym!pNqerYp|zdOt7o3YjB8b zkb+rEK!8t7qKR%!etKqcNoICTYF=54Pi9g~ab`)XZb4#lc4B&JaZEvGfqr~hYF<iy zk$!SUVo^$JiGF;1W?p7Ve7s&kWf2<#1A{auZ3ux<3_BMi7b6=Z+kXyb4n{UcE=I6C zN`eAuU}s=p04JzBR7+5xgq6iv!j;9H%~W(HouQVghB1rBg&{Vgmbr#`0q;VF8pbTX zY?h+98s;qiS{4wwKwu$5Eo%+y0>Kofg^We>Y8bPGz@+d3ks8(-mW52UEHz9EL~B@} zCNO7-r7+K71|{RdxDxRire?+zmTZ=yD<u*&OpqL#!rsdi46;iyoiUg}lcQ=QI2l0` zd16iuIAIs$7Z+zH<sedgF*sReq$&)8BwxhAz`#(&ky)ItYhht(smXkc1C}vwaV6*H zrDdjovezw+oW#8J(!})Cm!POeiDXa-0xCIzK`8@NO4cx>FiJ9TgY&&#kr=3`0VQBf z##?Mfsl}x^CE)Z7Aw(D$7;bUc<Rs=Mr6k$~GB7ZF23b%g14;d$!b;C3CqFqcr`S#p zrc9IZ7ISuLrKVI7C&+M+okiRr77vKv1rdB80_3V9eh^ClWDQSzCaBPiF9wyGMa&=} zP7hCak9eoZ5Z7A*@t`DMoLUlJP?VpPT2y?CFFmy+9w`h2eLej=eM5cYLp*|9gFXCx zTyF8e^yDSxrru)B$uCbWy2Vvol2}wyT%K8yaf>fLBe6KXJTosIl(CC%aeD^)$A^3R z#rrx2++t2oExE;(SWu9fmr^7Sau0J(YThlj;{2kL)RZDgQ2EbRBna{VD97DmhXh~o zEjEY~i<Cfmguu4KT@P{zBy2%}UIYr@B2XUG1x1eqC~%Q8E)yu@axn2QvM_Qn@`183 zGbmGYFf#pTVPauqVq{}v`OC%1!zjQ6HpNeq>y}_CtU`iBQhpJnC}T~{E6pv21S~tW zK0?$qx7g!Bu^Ar^E+)W+AvqK7)>|Alx%nxjIjMFap<+<n@-Xr+3NUjpa|i(dn1u?@ diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-39.pyc deleted file mode 100644 index 22e5a3a5b405fb49e0ecd07504788eb717f34775..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 27206 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-39.pyc deleted file mode 100644 index 908c06840f9601d6728b3f573ba3eeeafc3e19ca..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1161 zcmYe~<>g{vU|^UdaWM5R8w0~*5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0 zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U|%pAp$!XC_^$?=krfq_Aj z@s^lxX--L|Q)Nl2b4FrOaB4|FQGQZtktX9UA?N&*%)IpAlEji!-^ApM%)C@h##<6j zndzo3nZ+eVnMtK3nfZB+d5Jld#hJyLjJJ55Jl##>gMH(D{asvrl97D?Vl#sXkS|Oa z7#LC+q8L*cqL|tl(il@1Q<z#fqL@=zQkYX%S{RxcqgYc}Ag*p^jACnNU}1;?xtjeJ z7sz^u6O%zcfEvjFVuQ>F;bI*I28I%b62=;aW~K#93mF(0N|;Mnni*>t;#o`Bni*;s z;@N8$7I1)MQW%06G#ULgId8ERmlmWJ6|pfeFx=vZkI&4@EQyaV0vTAu3KHW?28Ty{ zac&VPK5mJoAcaDFA}AQDQj2b}7Nr)amaJsF#ZsJ_leUua7H52Xa!z7#aeVwrhF?w2 zRxzQ)sYS&xsW~Z`MKS()sV+sCWvL3f3ZZ_UVXi^Jo*|CG3Z8y0{(i2(o{llWuD-6p zA+A9RW-$Q)J~4?Vx;gpjnZ+fU*)gekWidXPNioHlC8@dviOJcC>8Zsr1(^l<@nxxb zDfvbE$r*`7DXAs;Ntx-U1>ktqE2u2uU|?WS2E_x2!NADJ$i>LPSS5@ISv{EVF@hKr z%+4UKpb$u53}(<|^1H<X(pe<Hz`#(%10ujIFd+yEHy)5Hic?GC^AdAYH9?x0K(WSD zB@WUDiAz0XHN@G<?hHzi#i_V0=EzCROD|1KPt`@T6xo|Fc})&bgoB(HAAgH0K0Y@; zr8FlsKK>R@e0*VPVh%(G9B#Kb3X1XzQj1C|i-bXb6$SZ_7aGIKsX00E@el`r{m%zd z0ty6hs!{?u1C-G@7<t&37`d347{TJ8#K)hT1Pua6JQab$=#~&9$rXdLU@jyJf)nH| v0gz(k^an|jY`ICv#l^Yc^a?f_$t_?9f!uP7!v^9(I~kCJK#72d5e%6Dn}Qkd diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-39.pyc deleted file mode 100644 index 9989d318ab19c9f0fcddb06abe28dfb173338e4c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6247 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 NBH$??42EI?k^rk?1tS0e diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-39.pyc deleted file mode 100644 index 03d093d9005783303a25d07060ac0d6458c6a480..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2288 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 E0AGCYzyJUM diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-39.pyc deleted file mode 100644 index 1c50be04f05e5e4f40fe090c5e70ac24ac090267..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3510 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 PYcZ(Q;b7!o;$a2=iDZZj diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-39.pyc deleted file mode 100644 index 73c3104c8aa11cf93fbf43d878fb193edb95a7cd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2937 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 UH$SB`C)G{{<X?~_985gS00B-Em;e9( diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-39.pyc deleted file mode 100644 index aa6765a02e38059e3e96530c3401f8a2bb91bf79..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 426 zcmYe~<>g{vU|^UdaWHiQ3j@Pr5C<7EF)%PVFfcF_`!Fytq%fo~<}gGtq%veNrZ8nQ z6zQcfM=_<aL@}qbq_U<lMX{x_MzN=IWN}7u=1HZnL@}i>M=_^zrLutKSio}JQJg7^ z!3>(LFG2SBX)?WJW?*0_Vq{=o2yxToxy4*uS$vD9EVZaOGe0jrGcPUw7IQ$P5r{Cp z#avucbc?+-FEcqmCG{3haY<2TUV3~<WkG83EzXkEiV`sU7E4NIa>*^u%#zfi%#zgH z;#;gql_jagw^+fvl?+AvAS*${uR3R|n9$<XqT-m;oRrL>82`Lfm!izFR0UmyP(RNw z*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!klnAE(o7@y3f znBvTmRNaEa<m|-s)Z&<e%mV%Rvedkk{38A2jKrdp)Dr#V{M>@X61{@TTO2mI`6;D2 Zsdi$ZPzDhk%v_8tj4X^CAj||~0RS9jc0&LF diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-39.pyc deleted file mode 100644 index 692bdcf85197f2c73c3b4f755b64164563a32aae..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1168 zcmYe~<>g{vU|^UdaWK`Moq^#oh=Yt-7#J8F7#J9eT^JY`QW#Pga~N_NqZk=MY^EHh zT;?cdFq=7tC6_gd70hPIVasKYVrOJ<XGmd9VQXPXVM}FgW{%=WVGm}|<ao)*z`&r% zcuUeX)Y&`8C9}AsC^M<FBr`wHF)uNvvN*F?lkt|2bAC!@UV3mzVo9oRVsb`iUaBVJ zEivEHoRUnZ%92#)jKreg)RKUr{G`+(O~zY%&H<Jtmhr*9@xJ~pu0F}gegLtVK?KMj zCJYP=sSHt!DGX6e?F?y*DU2yhEgVtIsVphXDJ(4v&5Tj3sVoq8H#0`DwKK3VM1kDR zev2Dy2gJ%`kSCyKGJx113qZJ7hk=2igrS77hM}2h0n<VTMurmR5|(Dh8ish*61HZB z8isiG8ioZNAej_~U<OS_KTXbCti`1TsYOL>3=9mnIO5|o^D;}~<BLEB7O{fFIFrHQ z5nr5J#027trXYn|d?F~|s#1$?u@<Ekr<SZ_yv0(Snv=GY@fK%%d~!}=adCY7N`_y} z&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW!LGip z!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g`tfC{ zc`5lt`pFrIMJcHz`pE^BCYA-@h|(*lEaG5bU{D6d1c<@F$j8XV%)wYCf)uuTF#lr& zGAN*(L3%;SGKDdiL6gbv7Ash5kpKe&LlF;%0JFe^ASkGKKn^KREs4)d%uUq>=>~-$ z15=d*SR*7p^^g@2XD^#~eo<;-9&U>{auV~>OB2&m^^q(^@hD7zCI=|eLGFu>zr__F zpPQdjnv)tIe~TwRzOXbg2O<Lwx?3CtMfnA(MJ1I*!XVFzg1pEJjpgLjoSgW0h>O4h zzz0$S3I%Y=QUbXHl;1fRc{rFDxtN(4!Q!9<C;$oo<U|EYXF`y4R}9LBxsZGaPL;R# zbCW<iic?D<QCkFxl3Q%KNy){<x!^PlHX6w-U<ZNRa*M+T;z2tZkb^+!fQJzbnE~{b B88rX^ diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-39.pyc deleted file mode 100644 index 8ed9d05f14db8ab8feed48ad39c53b63daca2f7c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2675 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 M7vL1&7vKbu062<>6951J diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-39.pyc deleted file mode 100644 index 482622ef89f18580c9b0e89515439e2b6d1ef4ea..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2660 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-39.pyc deleted file mode 100644 index 7ab2666fb5a0482417f6bcb912a5958ded1428ab..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7109 zcmYe~<>g{vU|^UdaWIunlY!weh=Yth7#J8F7#J9eZ!j}3q%fo~<}l<kMlmunq%cJ> zr7~tQr!r=-q<~0d%mNa{f>~1;v#?>9daxNOU|tGH9ZL!u$dnY;6jrDxM2;ne1(gpq z7px!ZDmXjMAc`%8J&HY*DTOVSEtNfmBZV`CYYtl!M+$coCrCBe{UDR!dO)H`7$ips zgWO99!_9!W9^^M94AKo(0TNGPh4>%DCV(;Y;!qD$$DHO6#g)Pn#huET!kfyK%ALXo z4Hcdg{wQ9M-wB2aD6~-Ai^EQk8j!ujV31lchQvS2M6BTjNgW_lK{{YGh>Z<{<Utr& z4xNuI2V=w3fPBlG<`Ko0A`r!&%9|pX%9qNYB9tNwPD=tQB2j`kLk(sYIt?-#8-}aH z?r%`2poR}f1PO!81iKgHA`ni~h!RR+j}lH5OkqnEN)=8KO%VgTTO>t1m_bwGB_jg^ zgC^rG9^b^|jLf{$;F83WR1F4328JS#%u7&_P{ho@z%XD0$Qc7>`GER-L|Fck1(vv8 zvNA9*ykvrL!Rc?5fM&$efS`9kyaZ=IaOwmnOg2zK$%elqs^ap9(sg&zH8M6dy2b7c zDo~44HQ8=)C+8#<7sr<*Cgr5w;(>6|5|c~vi*9ijgGyYe6kl>iVo`ifY95r&l9!m9 zdW$0`F)zI|F&$bigB*h28FZ1QPPxnu&+g#h9smLy!vkRNkhKz={zeIgqR}uIh%nIP zB&m3N$;rULP{r*T?5}HNU}U80><4Mxf+LUOJP0-gOps|5DW&L3Y=tE@F*4mkk~R)_ z!3{4!Un0cNj1mAT2Gyb@McuGg3{Eto#6XlFqXjnugC-a0x$7lp#1N?{^$NJf;gwjB zn3q~Sgqx-~3s88uMtVq5Nyli3N#d~6Xn8tXo`RYh1C$Ps%0};?TWsF>MX8B-eww1U zSX1*#bBl{WV_Ub_Jfh;AeS&YX28TEXh1_Cw4GQuPy2a)h5*+XAdW+Q~Dn2;mmLN!x zhhtE@kE>sNh@+E_>n(1OjBmWJzl*ESEnd%He^7JQ*$-?M4}u#Ua!Ufib4E2o2q6=U zZj@I5icwwxAa}rw0!d;w3ZxF*DDNN?qr8KVjRHwxHwvT<YSc=GA}vrvf{0(W&Q>v@ z#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW!LGip!6B|e z3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g`tfC{c`5lt z`k*10l++Ua)Z*mgT)l$ITO2mI`6;D2sdh4;>97t41_mA`78N;01x7hWF-9>)xnC@t zEKE#{aQK^z9U>1>p};7^sKBW3gM}NH8juQ*X$p)A-&uIDtCC}sV^sLf!htFa09QDg APXGV_ diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-39.pyc deleted file mode 100644 index 66a43465cfa72e37b4ea0c7c5aa25508281a7ea8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2474 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-39.pyc deleted file mode 100644 index 73093afbbc99962912c07836236efb4ba88109d4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12090 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 J0}B%iGXRmCTrmIu diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-39.pyc deleted file mode 100644 index bba6aabf201ccfced52dab02e77fc50e5fff7484..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1169 zcmYe~<>g{vU|^UdaWM4?8w0~*5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0 zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U|%pAp$!XC_^$?=krfq_Aj z@s^lxX--L|Q)Nl2b4FrOaB4|FQGQZtktX9UA?N&*%)IpAlEji!-^ApM%)C@h##@rE zq0ZhxE}6w8MVU#ZC7Jnoj(LeWmBpFGnvA#jz>@L7zVW{PF0MYw$bJB^nLz}|A0`Y8 z45<uJj42FJOzjM5j46yMOf4Ky%&9CX%qc7_49$#Dtf?#zcQ-Rev9&X>Fhqge&3=m; zYzM@Z$skWa&13+vK^A~;u?_<RLkU9(V+}(y(*mZ242%pV%q1+%j5Q4LtR-yC3^fe# z>@^GvI6yKf48aVVjDDJ&w^)ly3sQ@U*cccXZgIrNXXa&=#K#wb3@l;=iE$=_gCxE< zw+Iv^w?tEr!XZ8p6cAOZMYmXsQj1edRx;jVDNfBvTgiBfGd?~!C$YFVK7J*`uV!bf zn9$<XqT-m;oRrL>82`Lfm!izFR0UmyP(RNw*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe z*B}M6n1BGEm_!rZoc#36;*!klnAE(o7@y3fnBvTmRNaEa<m|-s)Z&<e%mV%Rvedkk z{38A2jKrdp)Dr#F(&X%-0&v{w6;u{+FfcGEgJJ^2U|{59<YMGttP(*ATRoWnF#;JB z(9R&epfE^b3}(<|@~dKV4RzM_4k{90U|=ZX0TEypm=FYo9S_JQ#i=Fnd5O8Hnjq~= zpqOK-l0dc;SrJhd-(vI5FG@|!!)-A~PGVkqX<~Y+E|R4vK7}dJ<N(Dw$bIqgx47ct zbMsS5b5i5uZ}G&(7nUaGKxDvScZ;K-D8C@JsHCz;2;^B2kQaHO(VU!`lM^2gaS=EG z_&`cPp#V-=N+5TDGCT((4;vFB7c&zhSR9lB`E!$?K>&%XB2XaR5`v_=Vo+Ahg=9r= ys=OrtQjDAkA?cDWHz~QeI2W8~!A2vw1?(V@TW)dKKs;zC19A{3A@DGQAu|A*-y5<3 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-39.pyc deleted file mode 100644 index 1c4f7f75f2ddff3142de5583b5879734e5d31dfe..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 27210 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�kQaV~lsp3|aR(Xo9K@;uNvs1&)PvNW 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 ISeRLu0DL^!B>(^b diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-39.pyc deleted file mode 100644 index dc5d84ccb7b24e0ef47cd9a2760cae61c886d391..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1169 zcmYe~<>g{vU|^UdaWM5V8w0~*5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0 zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U|%pAp$!XC_^$?=krfq_Aj z@s^lxX--L|Q)Nl2b4FrOaB4|FQGQZtktX9UA?N&*%)IpAlEji!-^ApM%)C@h##@rE zq0S-UE}6w8MVU#ZC7Jnoj(LeWmBpFGnvA#jz>@L7zVW{PF0MYw$bJB^nLz}|A0`Y8 z45<uJj42FJOzjM5j46yMOf4Ky%&9CX%qc7_49$#Dtf?#zcQ-Rev9&X>Fhqge&3=m; zYzM@Z$skWa&13+vK^A~;u?_<RLkU9(V+}(y(*mZ242%pV%q1+%j5Q4LtR-yC3^fe# z>@^GvI6yKf48aVVjDDJ&w^)ly3sQ@U*cccXZgIrNXXa&=#K#wb3@l;=iE$=_gCxE< zw+Iv^w?tEr!XZ8p6cAOZMYmXsQj1edRx;jVDNfBvTgiBfGd?~!C$YFVK7J*`uV!bf zn9$<XqT-m;oRrL>82`Lfm!izFR0UmyP(RNw*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe z*B}M6n1BGEm_!rZoc#36;*!klnAE(o7@y3fnBvTmRNaEa<m|-s)Z&<e%mV%Rvedkk z{38A2jKrdp)Dr#F(&Uoz0&v{w6;u{+FfcGEfnoy0U|{59<YMGttP(*ATRoWnF#;JB z(9R&epfE^b3}(<|@~dKV4RzKH2`>_0U|=ZX0TEypm=FYo9S_JQ#i=Fnd5O8H8X)aV zpqOK-l0dc;SrJhd-(m|%%q&mL!)-A~PGVkqX<~XRC`}YYEk*GuOo1i`DAqyli;us> z6(66QpHiBW8Xtd)CqBNgG%*Jv0}i`e90f)B1*t_Pl|@1z&x(M&$P10;<kXy;_;`qm zzyZJqQUVGEaMDr)c^;JEIT(4^m>9X3nHa(1pcKfTn*<F4NL&?x+<Qw1lJ1H@Suq!q z6~U?UmH<dGaw3GJOSask<l^F7aH0hpjpP=vgFtS%#bE>Spq&iJL7;@d!w7~<0IBI5 AAOHXW diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-39.pyc deleted file mode 100644 index 92164a591727d598f99c59a54c72a5a654e51f86..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19134 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-39.pyc deleted file mode 100644 index 7d135e695847c53d86c4ce946c97a384a90bf099..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1177 zcmYe~<>g{vU|^UdaWM538w0~*5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0 zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U|%pAp$!XC_^$?=krfq_Aj z@s^lxX--L|Q)Nl2b4FrOaB4|FQGQZtktX9UA?N&*%)IpAlEji!-^ApM%)C@h##>VE zPDaLtMlPAfB}JJ@r6rm9d5(FBIhDnk#hQ$__#v|K!M^dn{w}UQ$;iF{v6(>x$R{QY z3=F9ZQH&`JQB3U&X^bh1DNHRKQOv0<Da<J>Eey?!QLL#f5SKSIMzOUsurNe{T+V)r z2Vx1tp~)bBKn-O8u|YO~aIp>p149Wz31baIGt&a5g$#@gCCnu(&5Sh+@vJ3m%?vdR z@$5AW3phYBDGb33nv8y$oVQquOAAtqir5$!7;bUI$7kkcmc+*wfeb8S1&MJcgF_|0 zIJXECE4M^bkU}Cp5fl_vsYSO~i&BeIOI9-8Vku6|Nn6Qyi!(kxIVZ8WI6i(Q!><-+ ztC-N@)S}{;)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0e?Qk?Psf;GS6|oQ z5Z53DvzUMYpO{1w-JJaN%;J*F?3mQNvKXJtq?qE&l2qM-#N_P6^wi>*g3JQ___EZz zl>8$7<c!3kl++Ua^dwNs6@cScub{GsgMooT2^1F~1_L7>BNrnFW0fd!=<2~j03(<| zLG29E3<`x5#$X0bCcj&35WPhL3=9lKJRkzh0uzFu(BlEQr8u=DJ})shRRg4*2^4os zRgw^$kT}&tRz;l6?9QO{S)7X7YL1-5y!6t<^i)u~D27^#>RFfyO%71hgPa&2e~T+V zJ~uz5G$%Da{uWPsd|_!~4nzhVez!OZit-Cmi%KesghBol1^JQ}8rR9GIXUt15GR4d zfDfbu6cFI_r3msrDC2W5@~|;6axpV8g2h3}kUuvG8VHd1Dgrt9mJlTI6@#*5E+k8W yljbb}kYePN2uYl5xk<^z#kt^=3pN_bEno+M+;WS<2I4_G8IXfOiGha^44DAk%^Ifw diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-39.pyc deleted file mode 100644 index c00756b966f3442fc6cbcc55997d0e580a79207a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3046 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-39.pyc deleted file mode 100644 index dd5e0198ea7365906b2425f44edb8914e42787d7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 22162 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-39.pyc deleted file mode 100644 index 2e0ac2242fba8ba4be81cde568bf387ed732e358..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 37635 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 W4jV`nVkZYO3{)nugb6qc$N~UKTQGb8 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-39.pyc deleted file mode 100644 index a2213cf6eeddafb3366e0e6a8ce9948521314d5c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21837 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-39.pyc deleted file mode 100644 index 967eb30becee3e0eeb1806594a6dd655a2c17abc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20513 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-39.pyc deleted file mode 100644 index e01cd062929dc27b8282f4d35adfaabab5b2ce11..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20581 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-39.pyc deleted file mode 100644 index df5dc55783115bfae52d945f12c3c1c6fc0d8cf2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21782 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-39.pyc deleted file mode 100644 index 035e6b2ac946b482d57c21a4f5fdfd19e195c0d4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26385 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 N4UbVCECg_-3;>FN`p5tP diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-39.pyc deleted file mode 100644 index 4444ac5e985a78c715efb7a6dbfc0ab5b9cd0d1d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20757 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-39.pyc deleted file mode 100644 index da8c69bb71b5a4fb53608a6d63f0211c238305a7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20597 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 VyFnoUN_`9*pftqF0^-B)F90E+x0(O| diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-39.pyc deleted file mode 100644 index 22da5e306b250a224197ddaa93606c63542779c1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2982 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 N03${40h>AtF904{UeN#m diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-39.pyc deleted file mode 100644 index 597ee0c4737ea0e4395d936f21e9b6e7aacab1d2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2289 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 Nfvf_hW*$ZXW&n>CEbjmS diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-39.pyc deleted file mode 100644 index 5367772f25a5634e054459e30d5dd3c8e8855245..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1158 zcmYe~<>g{vU|^UdaWM4`I|IXG5C<8vFfcGUFfcF_H!v_Tq%fo~<}l<kMlmvi*i1Q0 zxy(__U^a6OOD<~^E11oa!<Ne)#SUh(=5XY4Msb4KY&l%H+)><MHhT_FE^ibsn9Y&H zm&+f;4`y@b2;>Sz2{JOcGo)~(aJMj|aHldhGe-%f@B}kx^1ftbU|`T>yd~tEkysR* zTH;=mUs@1Ql%JGZq{(=TD>TH-0>KOR@(hOaxLre?y#nA|9(N}rV?!f2A0+J^gy1>{ zSejVExm-?}>85ZVNNq?sgqw^USRghiz(91d90LPGDnk@w3PTiA3QIdf8e<Am3Udo* z6mvTR3qur3FoP!REq-4o=U^mH_$4!eG($0n&B4IHzzm827X}7~5{44S8ir=3ET$U9 z6vkdgMurmRW`+`$W`+{hW`+{BW`+{>W`+`uW`+{ZW`+{3W`=Z*8isi88ioZt3mHHG z9L%7}<fqAai#sPVFFigjGp8iANR#&#YjJ5oYEcn40|Ub?j`;Y@yv&mL_#%+KMIa9q zu`)0)6tRH_b`Sw_R1qhL1xh`)*bBfhP<)HED784XM3d<jOL1yWS`iNe1H($jTb%Ln z$vKI|#qseg8Gf}pTg8MHrxq2*q~@e#7RC7IrMeVlmZd7_DunuZhPeg>dxkg$D|q_3 z`1`pAdpgDhyZX8YhqwkQn8gGH_{1cd=;q|7XBL-aX2+!FmBsjECdCwImZa(yBqnDk zrl%Ii6l50Y$Cst%rQ{dsCubxUrKFbV=O!f=r-RZ8#HD%#l|_6E3=CSJfE5FUHlq*| z3nL2r!Nyf3ffhY_u%OXo^wVSog;ZW*Zfbn|Ew1?Z-29Z%91xo)KEALtF$W?8w&oTu zGz5}Ub8_P2i$p*n2PT9-EKv{v3VKbDbHI_#2#yLrP2pQYATJcBmLR#l2&Ci|S7}L_ z1;jhxh`Pm9oRwJ&6#zxrE$-CP<g5ay2q*?`@uVk#Qaw}%6rW&4*+ozhP~_g?PA;%C zv4o0%V)_<WQf9g-Q~(s~U`-|EP!UiP06Q1SUtrIH{B?`N1`;rKp!`q_@-Gh~8e|3l DN3J3L diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-39.pyc deleted file mode 100644 index 83f7161fe18171b5c7febcaae21f7700bb5ad73f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15745 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-39.pyc deleted file mode 100644 index f04b346441caa82541f2812c58325aaae633f0c0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3142 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-39.pyc deleted file mode 100644 index 85e1d972af9dfa0554f1ff4ed7d33db1f6f48e74..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1727 zcmYe~<>g{vU|^UdaWM6&00YBg5C<8vFfcGUFfcF_&tYI-NMT4}%wfo7jACR2v6*t1 za+#x;!EELnmR!~-)?BtIHZY$hhdq}giX)dZiWAId&Ed-Bj^YNh*>ZStd82r9`J(u8 z`J?!A1)>CU1)~IWg`$MO^6WXnxgt>_U^YjNXs%e47?{nOBc3Y}CBewx&XB^D!rj7< z!kx<4%p4_|!V}D($@`L#fq_Aj@s^NtMq*KLYKePMerZ8KQGQZtktX9U9*@+dqSSII zpXrvAXRv>~g@vhQylK2ssE@m2kf)<xysy8DtIsW&a8ExM|M1{=LnBi|bXiTNTVim% z=JD=9uCCrteG*9ejFDwD8E;7<$(hD`xH<*7hC{SzvfUE#bn>+@HH{An4Gu;)11xH0 zh9)Wjw;V&gx4)-Fd=Q#?Nnb~2=g1&WA0JO=G$|=0HyNVJfx<DwGdSMN$RIw%!_gD! zRK{Bf>n-C$LW8_LgFWDK;=!4D={c!Rl_jarIDiCqGIELnv6(>xC{@WYFfgPtL@}l? zL@~89q%o#2rZBZ|L@~EBurNfi1T$zd-{KE;at=m{%VbbAL-jL&k|#d{0|Usw;u#DK z3?&RDj5Q3+ObeJ6GB7ffFgG*QGM2EEu%<B9Fg7#SGJ)AlU^a6N;{vuCrW)pjOpFXA zEG6vCAe9_ok`qjFfk|#K$pa>N!6YA;<Oh=iU{VlF3N<s<FoH}>=dWRi7p`GgAOdnl z3IoU^er_R}qPJL!OAAtqii8*#7;bUI$7kkcmc+*wft+6?$iTo*!~v2JEKV(n&&^Ls z&517nr{CftK9D32h~NehydVOUbBj1ZEH)6q4kADSQp5^kfr6z-0Aw6H)R0@OMXAN9 zC7LX^Sc+3~(r)o)fU^YDj$5KR`RSR-i8=A8!Xjmv#ii(?D;aNb#>Xe;Bo-IP$FF4g z)$VK+6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux#|%2s}^!JdvW!LGip z!6B|e3T80@0X{K_Cb}Toi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F z@{9D7GZKqZQcLuUlah<mLAe~_LA`>?A`u1#27OS<vH&F!Mm|P1Mixev|12zEl8KFx z=|2lQ8zTl}1&J^*GBGl}WfQHEKudFau$a<h1;tukVs2`D{4K6{P$ZS+fY?0o@r9*{ zIS?7JD{k>Z11LE)Cnr9>NDdS!U;>ori{wFEP%_X1xt586fq{b&oGkn_rEUp<d{~@X zg5<d(kdj+Gkhp>P7o2Qv3FRc_r6-l<q$d_-Cgy=tO%Xg5+~NbtrWd8AW<zA)DdiSF zNCsjYL<*er1VExirNzZ?v%m=qoYcT651a<U$q$qyZ}EcEmt-VnLd*aqx?5l~N=l2e zGmA4I!r)}cUz`N>7S#FR1P=-Vq_6=85GZVJaoFVMr<CTT+R1_f2&9aMk%v)$Nq~`u LS%C$_=3xc^0F%NL diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-39.pyc deleted file mode 100644 index 053a6cbc6f5de5073f9647c4821a5c41552f6cb1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2510 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-39.pyc deleted file mode 100644 index ba21409ee701f0adbd4ac2a2e39e517ace8ba781..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5858 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-39.pyc deleted file mode 100644 index b5f8a274e6f374bf861c728afa229521bc3ef729..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2019 zcmYe~<>g{vU|^UdaWM597X!m%5C<8vFfcGUFfcF_doVCCq%fo~<}l<kMlmvi*i1Q0 zxy(__xhzpEU_NsWYc5+98<@?K!=B3##lgtn&XB^I!q&o&!j{U|%pAp;!XC_^$?=kr zfq_Aj@fNRhMq*KLYDqv*eo|_YCetk*5Gyk;J-8&XB=r`LZ(?#rW?m|or^$Fr$T>d+ zCJB`S84?=eW)UCk8}IAy;_8!(?0gWL8AO1*5W>K~kjfCnn8Fanl)@Or+|H23n8K98 z+`<vX0%o(Mu(ohSv8J-6u%)oKFf=npv8S@7aHMd8*&HccDcmg#QJg6}DZDKVQC#f| zEDTZH!3>&wx41w~069IiC>>(m1N&r<A0ZqD1`r$M5D+fbVqjn>VJKm&VQ6Mrz_gHo zk)edSgr%9Wh9RCcg`tKao~?#q0Xs-Mg&~+hlhIF;;}&aiX+dgH5jz6|!!3^Z_{_Y_ zlKA){Rt5%!A~uj1XEHcw;)`={@y6$s=EmnH#V2PZ78T!OElMp;Em_HUi={X<Cv7F; zEzbD(<ebFf;`sQL48NM3tztrpQ;UjYQgc!=i(>rqQeBEN%Tg6|6+-<y!(4-cJwqIW z6+Hc1{QX>mJso3$U431HLtKLt%whrpd}0z!baV34GmA?yvtv^8%3^#nlVXZ9OHy?U z5|gtN(^HFM3Nj1y<I7U>Qu2%RK`u&3EzvJ6NwX*b$GKiXWf3O>1A`hUhB!dM#mL9V z#mL53C5#ADJ(!1ahp7@qnAR|4F+)N(1r)L@;IL%!dkL~bleGwB7dSYJctC*&$_7Q; zAQmr(;0F<cAVLU4fRyNfTnGwl2CxgO1d!YZ4q^<)fg;@*qzjabQW%37G@1OWSW8RN zbS;X&W`nH)v%mz%s#`puFe*+hiO);SO*I7RW&*jGsY)ElK4djSS$m5Cw~ZV*iFxUz ziRr1PNVXw|K1@Ct>=KY`7#J8pega{z2d6MFFw`)*FvO<SGSx6-F)U!LVOq#o%Ur`; z!j#3F%~YgQ!ji=bO4*DIg*k;RU~%?rrXrUTmMji5an5X}A{MYITniae7_(VHJQjv5 z?i40-1}27h?n00(PYFvFZ#Gj=Uk$?ozJ&}m3|aiyEJb}V^J*Bfc!C);nf+dZ99;y8 z3Qd6`P%Pi#%1f;%i7y6~Fhw9A++uYN3i1ys0_DwHY<~VB@xHFN*dPjSv3Z6BgZLb7 z{-J&@@tz^KSc5|xgF<czr>B<0Czlo#rRJ4@b6QSn9ykHrVg(z0i_^t5#ML>()6e}D zA6RXEURq{KYF={cEuml!|DX`((2)2Lk094z4}TvQO_m})P(J2Jsw_#3FD@y%#h84H z2bQV9ZUv_iFab^|ENQ8!DVCrplLJKwBL^c7BNrnFBO9FLV-#TGVdP`vV5;IrN<1Ka zD2WCXLLkqBqf!r4&@<LDf+8S=DVw24tp>yfVFqCaONLs;6y_R635H;X8pdD-aHeAM zOJC>yuu5dzd;6E53<50zKiF$BK|+Mr-_JGP*~2j?J|M{7Ns|fURkqT+oXqT0NWz5s zs|b{neL&s<MHT}i3nLe!0LTlHNM1k<PfZ?Bk(ig5n;IW~iz_}pH$SB`2gK%yk1s4u z%z?-hX@YVxsH_3!_*)zWMfnA(MJ1I*A|MGd5TOntKn}RY3oRs*Q*(0S<B{A5E*U@( zPy{NAl|c>#@i-V+n0VNDSeY2Pm_e9B7%cCn$#shtnp+_SUJ)p?Z?UH4mF5<MlN=-s z3PGY8oOE&_wO$dZbic)xo0ME!oC_}H!A2sv1s-U(IBX!Ewvz!l2voN5FbXj8F!Hbf E0KwGADF6Tf diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-39.pyc deleted file mode 100644 index 6b67d25af1395324763805ede852d3a9ce136ec1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 466 zcmYe~<>g{vU|^UdaWM500|Ucj5C<7EGcYhXFfcF_i!m@Tq%cG=q%cM?rZO&IN?}^a z7{#2z9L%7}Qni^YBqOs}AvZszG$&OdwIZ{)q*x(8FQ-zWBwwL8Gq)foGp$mgD7B<0 zGqo%;FI}M|BUPa+wWv5VKTjdAG&d==NFhH>Avq(lC?&OoE3GI$SD`$!BqK9Vp*Xdq zv_P+*QXw%fMFA`URi#i|npBXOoSm4STCB&#WtCW3l969zrQnj7r{I*6m<Lv-pplZ8 zr<VldI;7_&X6EQ6=jUp2Rk51r8R!|@V$}1~WVyv2AD@z+93Ov+J3b!ju=w~}ti=U6 znI*T_!(4-cJ^lSwG8C~fFhGc3_0Co?p~b01#WATlDVaqv{&}e`MVV!(3c3oRex6_* zA&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylB zsk$&v#S~-~=*O3(=B4Bp>4SZfTA~kin_fZXEe@MpaCqA>g5rmTfq{XAorMtqUKo-} diff --git a/env/Lib/site-packages/pip/_vendor/chardet/big5freq.py b/env/Lib/site-packages/pip/_vendor/chardet/big5freq.py index 38f32517..87d9f972 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/big5freq.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/big5freq.py @@ -42,9 +42,9 @@ BIG5_TYPICAL_DISTRIBUTION_RATIO = 0.75 -#Char to FreqOrder table +# Char to FreqOrder table BIG5_TABLE_SIZE = 5376 - +# fmt: off BIG5_CHAR_TO_FREQ_ORDER = ( 1,1801,1506, 255,1431, 198, 9, 82, 6,5008, 177, 202,3681,1256,2821, 110, # 16 3814, 33,3274, 261, 76, 44,2114, 16,2946,2187,1176, 659,3971, 26,3451,2653, # 32 @@ -383,4 +383,4 @@ BIG5_CHAR_TO_FREQ_ORDER = ( 890,3669,3943,5791,1878,3798,3439,5792,2186,2358,3440,1652,5793,5794,5795, 941, # 5360 2299, 208,3546,4161,2020, 330,4438,3944,2906,2499,3799,4439,4811,5796,5797,5798, # 5376 ) - +# fmt: on diff --git a/env/Lib/site-packages/pip/_vendor/chardet/big5prober.py b/env/Lib/site-packages/pip/_vendor/chardet/big5prober.py index 98f99701..ef09c60e 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/big5prober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/big5prober.py @@ -25,23 +25,23 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### -from .mbcharsetprober import MultiByteCharSetProber -from .codingstatemachine import CodingStateMachine from .chardistribution import Big5DistributionAnalysis +from .codingstatemachine import CodingStateMachine +from .mbcharsetprober import MultiByteCharSetProber from .mbcssm import BIG5_SM_MODEL class Big5Prober(MultiByteCharSetProber): - def __init__(self): - super(Big5Prober, self).__init__() + def __init__(self) -> None: + super().__init__() self.coding_sm = CodingStateMachine(BIG5_SM_MODEL) self.distribution_analyzer = Big5DistributionAnalysis() self.reset() @property - def charset_name(self): + def charset_name(self) -> str: return "Big5" @property - def language(self): + def language(self) -> str: return "Chinese" diff --git a/env/Lib/site-packages/pip/_vendor/chardet/chardistribution.py b/env/Lib/site-packages/pip/_vendor/chardet/chardistribution.py index c0395f4a..176cb996 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/chardistribution.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/chardistribution.py @@ -25,40 +25,58 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### -from .euctwfreq import (EUCTW_CHAR_TO_FREQ_ORDER, EUCTW_TABLE_SIZE, - EUCTW_TYPICAL_DISTRIBUTION_RATIO) -from .euckrfreq import (EUCKR_CHAR_TO_FREQ_ORDER, EUCKR_TABLE_SIZE, - EUCKR_TYPICAL_DISTRIBUTION_RATIO) -from .gb2312freq import (GB2312_CHAR_TO_FREQ_ORDER, GB2312_TABLE_SIZE, - GB2312_TYPICAL_DISTRIBUTION_RATIO) -from .big5freq import (BIG5_CHAR_TO_FREQ_ORDER, BIG5_TABLE_SIZE, - BIG5_TYPICAL_DISTRIBUTION_RATIO) -from .jisfreq import (JIS_CHAR_TO_FREQ_ORDER, JIS_TABLE_SIZE, - JIS_TYPICAL_DISTRIBUTION_RATIO) - - -class CharDistributionAnalysis(object): +from typing import Tuple, Union + +from .big5freq import ( + BIG5_CHAR_TO_FREQ_ORDER, + BIG5_TABLE_SIZE, + BIG5_TYPICAL_DISTRIBUTION_RATIO, +) +from .euckrfreq import ( + EUCKR_CHAR_TO_FREQ_ORDER, + EUCKR_TABLE_SIZE, + EUCKR_TYPICAL_DISTRIBUTION_RATIO, +) +from .euctwfreq import ( + EUCTW_CHAR_TO_FREQ_ORDER, + EUCTW_TABLE_SIZE, + EUCTW_TYPICAL_DISTRIBUTION_RATIO, +) +from .gb2312freq import ( + GB2312_CHAR_TO_FREQ_ORDER, + GB2312_TABLE_SIZE, + GB2312_TYPICAL_DISTRIBUTION_RATIO, +) +from .jisfreq import ( + JIS_CHAR_TO_FREQ_ORDER, + JIS_TABLE_SIZE, + JIS_TYPICAL_DISTRIBUTION_RATIO, +) +from .johabfreq import JOHAB_TO_EUCKR_ORDER_TABLE + + +class CharDistributionAnalysis: ENOUGH_DATA_THRESHOLD = 1024 SURE_YES = 0.99 SURE_NO = 0.01 MINIMUM_DATA_THRESHOLD = 3 - def __init__(self): + def __init__(self) -> None: # Mapping table to get frequency order from char order (get from # GetOrder()) - self._char_to_freq_order = None - self._table_size = None # Size of above table + self._char_to_freq_order: Tuple[int, ...] = tuple() + self._table_size = 0 # Size of above table # This is a constant value which varies from language to language, # used in calculating confidence. See # http://www.mozilla.org/projects/intl/UniversalCharsetDetection.html # for further detail. - self.typical_distribution_ratio = None - self._done = None - self._total_chars = None - self._freq_chars = None + self.typical_distribution_ratio = 0.0 + self._done = False + self._total_chars = 0 + self._freq_chars = 0 self.reset() - def reset(self): + def reset(self) -> None: """reset analyser, clear any state""" # If this flag is set to True, detection is done and conclusion has # been made @@ -67,7 +85,7 @@ class CharDistributionAnalysis(object): # The number of characters whose frequency order is less than 512 self._freq_chars = 0 - def feed(self, char, char_len): + def feed(self, char: Union[bytes, bytearray], char_len: int) -> None: """feed a character with known length""" if char_len == 2: # we only care about 2-bytes character in our distribution analysis @@ -81,7 +99,7 @@ class CharDistributionAnalysis(object): if 512 > self._char_to_freq_order[order]: self._freq_chars += 1 - def get_confidence(self): + def get_confidence(self) -> float: """return confidence based on existing data""" # if we didn't receive any character in our consideration range, # return negative answer @@ -89,20 +107,21 @@ class CharDistributionAnalysis(object): return self.SURE_NO if self._total_chars != self._freq_chars: - r = (self._freq_chars / ((self._total_chars - self._freq_chars) - * self.typical_distribution_ratio)) + r = self._freq_chars / ( + (self._total_chars - self._freq_chars) * self.typical_distribution_ratio + ) if r < self.SURE_YES: return r # normalize confidence (we don't want to be 100% sure) return self.SURE_YES - def got_enough_data(self): + def got_enough_data(self) -> bool: # It is not necessary to receive all data to draw conclusion. # For charset detection, certain amount of data is enough return self._total_chars > self.ENOUGH_DATA_THRESHOLD - def get_order(self, byte_str): + def get_order(self, _: Union[bytes, bytearray]) -> int: # We do not handle characters based on the original encoding string, # but convert this encoding string to a number, here called order. # This allows multiple encodings of a language to share one frequency @@ -111,13 +130,13 @@ class CharDistributionAnalysis(object): class EUCTWDistributionAnalysis(CharDistributionAnalysis): - def __init__(self): - super(EUCTWDistributionAnalysis, self).__init__() + def __init__(self) -> None: + super().__init__() self._char_to_freq_order = EUCTW_CHAR_TO_FREQ_ORDER self._table_size = EUCTW_TABLE_SIZE self.typical_distribution_ratio = EUCTW_TYPICAL_DISTRIBUTION_RATIO - def get_order(self, byte_str): + def get_order(self, byte_str: Union[bytes, bytearray]) -> int: # for euc-TW encoding, we are interested # first byte range: 0xc4 -- 0xfe # second byte range: 0xa1 -- 0xfe @@ -125,18 +144,17 @@ class EUCTWDistributionAnalysis(CharDistributionAnalysis): first_char = byte_str[0] if first_char >= 0xC4: return 94 * (first_char - 0xC4) + byte_str[1] - 0xA1 - else: - return -1 + return -1 class EUCKRDistributionAnalysis(CharDistributionAnalysis): - def __init__(self): - super(EUCKRDistributionAnalysis, self).__init__() + def __init__(self) -> None: + super().__init__() self._char_to_freq_order = EUCKR_CHAR_TO_FREQ_ORDER self._table_size = EUCKR_TABLE_SIZE self.typical_distribution_ratio = EUCKR_TYPICAL_DISTRIBUTION_RATIO - def get_order(self, byte_str): + def get_order(self, byte_str: Union[bytes, bytearray]) -> int: # for euc-KR encoding, we are interested # first byte range: 0xb0 -- 0xfe # second byte range: 0xa1 -- 0xfe @@ -144,18 +162,32 @@ class EUCKRDistributionAnalysis(CharDistributionAnalysis): first_char = byte_str[0] if first_char >= 0xB0: return 94 * (first_char - 0xB0) + byte_str[1] - 0xA1 - else: - return -1 + return -1 + + +class JOHABDistributionAnalysis(CharDistributionAnalysis): + def __init__(self) -> None: + super().__init__() + self._char_to_freq_order = EUCKR_CHAR_TO_FREQ_ORDER + self._table_size = EUCKR_TABLE_SIZE + self.typical_distribution_ratio = EUCKR_TYPICAL_DISTRIBUTION_RATIO + + def get_order(self, byte_str: Union[bytes, bytearray]) -> int: + first_char = byte_str[0] + if 0x88 <= first_char < 0xD4: + code = first_char * 256 + byte_str[1] + return JOHAB_TO_EUCKR_ORDER_TABLE.get(code, -1) + return -1 class GB2312DistributionAnalysis(CharDistributionAnalysis): - def __init__(self): - super(GB2312DistributionAnalysis, self).__init__() + def __init__(self) -> None: + super().__init__() self._char_to_freq_order = GB2312_CHAR_TO_FREQ_ORDER self._table_size = GB2312_TABLE_SIZE self.typical_distribution_ratio = GB2312_TYPICAL_DISTRIBUTION_RATIO - def get_order(self, byte_str): + def get_order(self, byte_str: Union[bytes, bytearray]) -> int: # for GB2312 encoding, we are interested # first byte range: 0xb0 -- 0xfe # second byte range: 0xa1 -- 0xfe @@ -163,18 +195,17 @@ class GB2312DistributionAnalysis(CharDistributionAnalysis): first_char, second_char = byte_str[0], byte_str[1] if (first_char >= 0xB0) and (second_char >= 0xA1): return 94 * (first_char - 0xB0) + second_char - 0xA1 - else: - return -1 + return -1 class Big5DistributionAnalysis(CharDistributionAnalysis): - def __init__(self): - super(Big5DistributionAnalysis, self).__init__() + def __init__(self) -> None: + super().__init__() self._char_to_freq_order = BIG5_CHAR_TO_FREQ_ORDER self._table_size = BIG5_TABLE_SIZE self.typical_distribution_ratio = BIG5_TYPICAL_DISTRIBUTION_RATIO - def get_order(self, byte_str): + def get_order(self, byte_str: Union[bytes, bytearray]) -> int: # for big5 encoding, we are interested # first byte range: 0xa4 -- 0xfe # second byte range: 0x40 -- 0x7e , 0xa1 -- 0xfe @@ -183,28 +214,26 @@ class Big5DistributionAnalysis(CharDistributionAnalysis): if first_char >= 0xA4: if second_char >= 0xA1: return 157 * (first_char - 0xA4) + second_char - 0xA1 + 63 - else: - return 157 * (first_char - 0xA4) + second_char - 0x40 - else: - return -1 + return 157 * (first_char - 0xA4) + second_char - 0x40 + return -1 class SJISDistributionAnalysis(CharDistributionAnalysis): - def __init__(self): - super(SJISDistributionAnalysis, self).__init__() + def __init__(self) -> None: + super().__init__() self._char_to_freq_order = JIS_CHAR_TO_FREQ_ORDER self._table_size = JIS_TABLE_SIZE self.typical_distribution_ratio = JIS_TYPICAL_DISTRIBUTION_RATIO - def get_order(self, byte_str): + def get_order(self, byte_str: Union[bytes, bytearray]) -> int: # for sjis encoding, we are interested # first byte range: 0x81 -- 0x9f , 0xe0 -- 0xfe # second byte range: 0x40 -- 0x7e, 0x81 -- oxfe # no validation needed here. State machine has done that first_char, second_char = byte_str[0], byte_str[1] - if (first_char >= 0x81) and (first_char <= 0x9F): + if 0x81 <= first_char <= 0x9F: order = 188 * (first_char - 0x81) - elif (first_char >= 0xE0) and (first_char <= 0xEF): + elif 0xE0 <= first_char <= 0xEF: order = 188 * (first_char - 0xE0 + 31) else: return -1 @@ -215,19 +244,18 @@ class SJISDistributionAnalysis(CharDistributionAnalysis): class EUCJPDistributionAnalysis(CharDistributionAnalysis): - def __init__(self): - super(EUCJPDistributionAnalysis, self).__init__() + def __init__(self) -> None: + super().__init__() self._char_to_freq_order = JIS_CHAR_TO_FREQ_ORDER self._table_size = JIS_TABLE_SIZE self.typical_distribution_ratio = JIS_TYPICAL_DISTRIBUTION_RATIO - def get_order(self, byte_str): + def get_order(self, byte_str: Union[bytes, bytearray]) -> int: # for euc-JP encoding, we are interested # first byte range: 0xa0 -- 0xfe # second byte range: 0xa1 -- 0xfe # no validation needed here. State machine has done that char = byte_str[0] if char >= 0xA0: - return 94 * (char - 0xA1) + byte_str[1] - 0xa1 - else: - return -1 + return 94 * (char - 0xA1) + byte_str[1] - 0xA1 + return -1 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py b/env/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py index 5812cef0..6def56b4 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py @@ -25,29 +25,30 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### -from .enums import ProbingState +from typing import List, Optional, Union + from .charsetprober import CharSetProber +from .enums import LanguageFilter, ProbingState class CharSetGroupProber(CharSetProber): - def __init__(self, lang_filter=None): - super(CharSetGroupProber, self).__init__(lang_filter=lang_filter) + def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: + super().__init__(lang_filter=lang_filter) self._active_num = 0 - self.probers = [] - self._best_guess_prober = None + self.probers: List[CharSetProber] = [] + self._best_guess_prober: Optional[CharSetProber] = None - def reset(self): - super(CharSetGroupProber, self).reset() + def reset(self) -> None: + super().reset() self._active_num = 0 for prober in self.probers: - if prober: - prober.reset() - prober.active = True - self._active_num += 1 + prober.reset() + prober.active = True + self._active_num += 1 self._best_guess_prober = None @property - def charset_name(self): + def charset_name(self) -> Optional[str]: if not self._best_guess_prober: self.get_confidence() if not self._best_guess_prober: @@ -55,17 +56,15 @@ class CharSetGroupProber(CharSetProber): return self._best_guess_prober.charset_name @property - def language(self): + def language(self) -> Optional[str]: if not self._best_guess_prober: self.get_confidence() if not self._best_guess_prober: return None return self._best_guess_prober.language - def feed(self, byte_str): + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: for prober in self.probers: - if not prober: - continue if not prober.active: continue state = prober.feed(byte_str) @@ -75,7 +74,7 @@ class CharSetGroupProber(CharSetProber): self._best_guess_prober = prober self._state = ProbingState.FOUND_IT return self.state - elif state == ProbingState.NOT_ME: + if state == ProbingState.NOT_ME: prober.active = False self._active_num -= 1 if self._active_num <= 0: @@ -83,22 +82,22 @@ class CharSetGroupProber(CharSetProber): return self.state return self.state - def get_confidence(self): + def get_confidence(self) -> float: state = self.state if state == ProbingState.FOUND_IT: return 0.99 - elif state == ProbingState.NOT_ME: + if state == ProbingState.NOT_ME: return 0.01 best_conf = 0.0 self._best_guess_prober = None for prober in self.probers: - if not prober: - continue if not prober.active: - self.logger.debug('%s not active', prober.charset_name) + self.logger.debug("%s not active", prober.charset_name) continue conf = prober.get_confidence() - self.logger.debug('%s %s confidence = %s', prober.charset_name, prober.language, conf) + self.logger.debug( + "%s %s confidence = %s", prober.charset_name, prober.language, conf + ) if best_conf < conf: best_conf = conf self._best_guess_prober = prober diff --git a/env/Lib/site-packages/pip/_vendor/chardet/charsetprober.py b/env/Lib/site-packages/pip/_vendor/chardet/charsetprober.py index eac4e598..a103ca11 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/charsetprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/charsetprober.py @@ -28,54 +28,62 @@ import logging import re +from typing import Optional, Union -from .enums import ProbingState +from .enums import LanguageFilter, ProbingState +INTERNATIONAL_WORDS_PATTERN = re.compile( + b"[a-zA-Z]*[\x80-\xFF]+[a-zA-Z]*[^a-zA-Z\x80-\xFF]?" +) -class CharSetProber(object): + +class CharSetProber: SHORTCUT_THRESHOLD = 0.95 - def __init__(self, lang_filter=None): - self._state = None + def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: + self._state = ProbingState.DETECTING + self.active = True self.lang_filter = lang_filter self.logger = logging.getLogger(__name__) - def reset(self): + def reset(self) -> None: self._state = ProbingState.DETECTING @property - def charset_name(self): + def charset_name(self) -> Optional[str]: return None - def feed(self, buf): - pass + @property + def language(self) -> Optional[str]: + raise NotImplementedError + + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: + raise NotImplementedError @property - def state(self): + def state(self) -> ProbingState: return self._state - def get_confidence(self): + def get_confidence(self) -> float: return 0.0 @staticmethod - def filter_high_byte_only(buf): - buf = re.sub(b'([\x00-\x7F])+', b' ', buf) + def filter_high_byte_only(buf: Union[bytes, bytearray]) -> bytes: + buf = re.sub(b"([\x00-\x7F])+", b" ", buf) return buf @staticmethod - def filter_international_words(buf): + def filter_international_words(buf: Union[bytes, bytearray]) -> bytearray: """ We define three types of bytes: alphabet: english alphabets [a-zA-Z] international: international characters [\x80-\xFF] marker: everything else [^a-zA-Z\x80-\xFF] - The input buffer can be thought to contain a series of words delimited by markers. This function works to filter all words that contain at least one international character. All contiguous sequences of markers are replaced by a single space ascii character. - This filter applies to all scripts which do not use English characters. """ filtered = bytearray() @@ -83,8 +91,7 @@ class CharSetProber(object): # This regex expression filters out only words that have at-least one # international character. The word may include one marker character at # the end. - words = re.findall(b'[a-zA-Z]*[\x80-\xFF]+[a-zA-Z]*[^a-zA-Z\x80-\xFF]?', - buf) + words = INTERNATIONAL_WORDS_PATTERN.findall(buf) for word in words: filtered.extend(word[:-1]) @@ -94,20 +101,17 @@ class CharSetProber(object): # similarly across all languages and may thus have similar # frequencies). last_char = word[-1:] - if not last_char.isalpha() and last_char < b'\x80': - last_char = b' ' + if not last_char.isalpha() and last_char < b"\x80": + last_char = b" " filtered.extend(last_char) return filtered @staticmethod - def filter_with_english_letters(buf): + def remove_xml_tags(buf: Union[bytes, bytearray]) -> bytes: """ Returns a copy of ``buf`` that retains only the sequences of English alphabet and high byte characters that are not between <> characters. - Also retains English alphabet and high byte characters immediately - before occurrences of >. - This filter can be applied to all scripts which contain both English characters and extended ASCII characters, but is currently only used by ``Latin1Prober``. @@ -115,26 +119,24 @@ class CharSetProber(object): filtered = bytearray() in_tag = False prev = 0 + buf = memoryview(buf).cast("c") - for curr in range(len(buf)): - # Slice here to get bytes instead of an int with Python 3 - buf_char = buf[curr:curr + 1] - # Check if we're coming out of or entering an HTML tag - if buf_char == b'>': - in_tag = False - elif buf_char == b'<': - in_tag = True + for curr, buf_char in enumerate(buf): + # Check if we're coming out of or entering an XML tag - # If current character is not extended-ASCII and not alphabetic... - if buf_char < b'\x80' and not buf_char.isalpha(): - # ...and we're not in a tag + # https://github.com/python/typeshed/issues/8182 + if buf_char == b">": # type: ignore[comparison-overlap] + prev = curr + 1 + in_tag = False + # https://github.com/python/typeshed/issues/8182 + elif buf_char == b"<": # type: ignore[comparison-overlap] if curr > prev and not in_tag: # Keep everything after last non-extended-ASCII, # non-alphabetic character filtered.extend(buf[prev:curr]) # Output a space to delimit stretch we kept - filtered.extend(b' ') - prev = curr + 1 + filtered.extend(b" ") + in_tag = True # If we're not in a tag... if not in_tag: diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py b/env/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py index 8b137891..e69de29b 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py @@ -1 +0,0 @@ - diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 4dc854ddc02c16c1da3beebcc0db9d85c3155dac..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 223 zcmYe~<>g{vU|^UdaWIvUfq~&Mh=Ytlf({G}48<%A3=Am@!3>&=ek&P@K*9*(SBtY% zOlWaxQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vVr=N?zpKGwEV@$BCuWN9K zYmkCjOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOs%}AIa&}^RYH>_KW`TZuS!!NN uevy81Mq*J)YKeYwPNsf*d}dx|NqoFsLFFwDo80`A(wtN~kn28!d;tKK?mPDY diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-39.pyc deleted file mode 100644 index 51cff09663700751e744603566aab3f8423a8f17..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2717 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 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py b/env/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py index 6d6f93aa..43f6e144 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py @@ -12,17 +12,21 @@ If no paths are provided, it takes its input from stdin. """ -from __future__ import absolute_import, print_function, unicode_literals import argparse import sys +from typing import Iterable, List, Optional -from pip._vendor.chardet import __version__ -from pip._vendor.chardet.compat import PY2 -from pip._vendor.chardet.universaldetector import UniversalDetector +from .. import __version__ +from ..universaldetector import UniversalDetector -def description_of(lines, name='stdin'): +def description_of( + lines: Iterable[bytes], + name: str = "stdin", + minimal: bool = False, + should_rename_legacy: bool = False, +) -> Optional[str]: """ Return a string describing the probable encoding of a file or list of strings. @@ -31,8 +35,11 @@ def description_of(lines, name='stdin'): :type lines: Iterable of bytes :param name: Name of file or collection of lines :type name: str + :param should_rename_legacy: Should we rename legacy encodings to + their more modern equivalents? + :type should_rename_legacy: ``bool`` """ - u = UniversalDetector() + u = UniversalDetector(should_rename_legacy=should_rename_legacy) for line in lines: line = bytearray(line) u.feed(line) @@ -41,16 +48,14 @@ def description_of(lines, name='stdin'): break u.close() result = u.result - if PY2: - name = name.decode(sys.getfilesystemencoding(), 'ignore') - if result['encoding']: - return '{}: {} with confidence {}'.format(name, result['encoding'], - result['confidence']) - else: - return '{}: no result'.format(name) + if minimal: + return result["encoding"] + if result["encoding"]: + return f'{name}: {result["encoding"]} with confidence {result["confidence"]}' + return f"{name}: no result" -def main(argv=None): +def main(argv: Optional[List[str]] = None) -> None: """ Handles command line arguments and gets things started. @@ -60,25 +65,48 @@ def main(argv=None): """ # Get command line arguments parser = argparse.ArgumentParser( - description="Takes one or more file paths and reports their detected \ - encodings") - parser.add_argument('input', - help='File whose encoding we would like to determine. \ - (default: stdin)', - type=argparse.FileType('rb'), nargs='*', - default=[sys.stdin if PY2 else sys.stdin.buffer]) - parser.add_argument('--version', action='version', - version='%(prog)s {}'.format(__version__)) + description=( + "Takes one or more file paths and reports their detected encodings" + ) + ) + parser.add_argument( + "input", + help="File whose encoding we would like to determine. (default: stdin)", + type=argparse.FileType("rb"), + nargs="*", + default=[sys.stdin.buffer], + ) + parser.add_argument( + "--minimal", + help="Print only the encoding to standard output", + action="store_true", + ) + parser.add_argument( + "-l", + "--legacy", + help="Rename legacy encodings to more modern ones.", + action="store_true", + ) + parser.add_argument( + "--version", action="version", version=f"%(prog)s {__version__}" + ) args = parser.parse_args(argv) for f in args.input: if f.isatty(): - print("You are running chardetect interactively. Press " + - "CTRL-D twice at the start of a blank line to signal the " + - "end of your input. If you want help, run chardetect " + - "--help\n", file=sys.stderr) - print(description_of(f, f.name)) - - -if __name__ == '__main__': + print( + "You are running chardetect interactively. Press " + "CTRL-D twice at the start of a blank line to signal the " + "end of your input. If you want help, run chardetect " + "--help\n", + file=sys.stderr, + ) + print( + description_of( + f, f.name, minimal=args.minimal, should_rename_legacy=args.legacy + ) + ) + + +if __name__ == "__main__": main() diff --git a/env/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py b/env/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py index 68fba44f..8ed4a877 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py @@ -27,10 +27,11 @@ import logging +from .codingstatemachinedict import CodingStateMachineDict from .enums import MachineState -class CodingStateMachine(object): +class CodingStateMachine: """ A state machine to verify a byte sequence for a particular encoding. For each byte the detector receives, it will feed that byte to every active @@ -52,37 +53,38 @@ class CodingStateMachine(object): negative answer for this encoding. Detector will exclude this encoding from consideration from here on. """ - def __init__(self, sm): + + def __init__(self, sm: CodingStateMachineDict) -> None: self._model = sm self._curr_byte_pos = 0 self._curr_char_len = 0 - self._curr_state = None + self._curr_state = MachineState.START + self.active = True self.logger = logging.getLogger(__name__) self.reset() - def reset(self): + def reset(self) -> None: self._curr_state = MachineState.START - def next_state(self, c): + def next_state(self, c: int) -> int: # for each byte we get its class # if it is first byte, we also get byte length - byte_class = self._model['class_table'][c] + byte_class = self._model["class_table"][c] if self._curr_state == MachineState.START: self._curr_byte_pos = 0 - self._curr_char_len = self._model['char_len_table'][byte_class] + self._curr_char_len = self._model["char_len_table"][byte_class] # from byte's class and state_table, we get its next state - curr_state = (self._curr_state * self._model['class_factor'] - + byte_class) - self._curr_state = self._model['state_table'][curr_state] + curr_state = self._curr_state * self._model["class_factor"] + byte_class + self._curr_state = self._model["state_table"][curr_state] self._curr_byte_pos += 1 return self._curr_state - def get_current_charlen(self): + def get_current_charlen(self) -> int: return self._curr_char_len - def get_coding_state_machine(self): - return self._model['name'] + def get_coding_state_machine(self) -> str: + return self._model["name"] @property - def language(self): - return self._model['language'] + def language(self) -> str: + return self._model["language"] diff --git a/env/Lib/site-packages/pip/_vendor/chardet/compat.py b/env/Lib/site-packages/pip/_vendor/chardet/compat.py deleted file mode 100644 index 8941572b..00000000 --- a/env/Lib/site-packages/pip/_vendor/chardet/compat.py +++ /dev/null @@ -1,36 +0,0 @@ -######################## BEGIN LICENSE BLOCK ######################## -# Contributor(s): -# Dan Blanchard -# Ian Cordasco -# -# This library is free software; you can redistribute it and/or -# modify it under the terms of the GNU Lesser General Public -# License as published by the Free Software Foundation; either -# version 2.1 of the License, or (at your option) any later version. -# -# This library is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -# Lesser General Public License for more details. -# -# You should have received a copy of the GNU Lesser General Public -# License along with this library; if not, write to the Free Software -# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA -# 02110-1301 USA -######################### END LICENSE BLOCK ######################### - -import sys - - -if sys.version_info < (3, 0): - PY2 = True - PY3 = False - string_types = (str, unicode) - text_type = unicode - iteritems = dict.iteritems -else: - PY2 = False - PY3 = True - string_types = (bytes, str) - text_type = str - iteritems = dict.items diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cp949prober.py b/env/Lib/site-packages/pip/_vendor/chardet/cp949prober.py index efd793ab..fa7307ed 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/cp949prober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/cp949prober.py @@ -32,8 +32,8 @@ from .mbcssm import CP949_SM_MODEL class CP949Prober(MultiByteCharSetProber): - def __init__(self): - super(CP949Prober, self).__init__() + def __init__(self) -> None: + super().__init__() self.coding_sm = CodingStateMachine(CP949_SM_MODEL) # NOTE: CP949 is a superset of EUC-KR, so the distribution should be # not different. @@ -41,9 +41,9 @@ class CP949Prober(MultiByteCharSetProber): self.reset() @property - def charset_name(self): + def charset_name(self) -> str: return "CP949" @property - def language(self): + def language(self) -> str: return "Korean" diff --git a/env/Lib/site-packages/pip/_vendor/chardet/enums.py b/env/Lib/site-packages/pip/_vendor/chardet/enums.py index 04512072..5e3e1982 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/enums.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/enums.py @@ -4,21 +4,26 @@ All of the Enums that are used throughout the chardet package. :author: Dan Blanchard (dan.blanchard@gmail.com) """ +from enum import Enum, Flag -class InputState(object): + +class InputState: """ This enum represents the different states a universal detector can be in. """ + PURE_ASCII = 0 ESC_ASCII = 1 HIGH_BYTE = 2 -class LanguageFilter(object): +class LanguageFilter(Flag): """ This enum represents the different language filters we can apply to a ``UniversalDetector``. """ + + NONE = 0x00 CHINESE_SIMPLIFIED = 0x01 CHINESE_TRADITIONAL = 0x02 JAPANESE = 0x04 @@ -29,46 +34,50 @@ class LanguageFilter(object): CJK = CHINESE | JAPANESE | KOREAN -class ProbingState(object): +class ProbingState(Enum): """ This enum represents the different states a prober can be in. """ + DETECTING = 0 FOUND_IT = 1 NOT_ME = 2 -class MachineState(object): +class MachineState: """ This enum represents the different states a state machine can be in. """ + START = 0 ERROR = 1 ITS_ME = 2 -class SequenceLikelihood(object): +class SequenceLikelihood: """ This enum represents the likelihood of a character following the previous one. """ + NEGATIVE = 0 UNLIKELY = 1 LIKELY = 2 POSITIVE = 3 @classmethod - def get_num_categories(cls): + def get_num_categories(cls) -> int: """:returns: The number of likelihood categories in the enum.""" return 4 -class CharacterCategory(object): +class CharacterCategory: """ This enum represents the different categories language models for ``SingleByteCharsetProber`` put characters into. Anything less than CONTROL is considered a letter. """ + UNDEFINED = 255 LINE_BREAK = 254 SYMBOL = 253 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/escprober.py b/env/Lib/site-packages/pip/_vendor/chardet/escprober.py index c70493f2..fd713830 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/escprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/escprober.py @@ -25,11 +25,17 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from typing import Optional, Union + from .charsetprober import CharSetProber from .codingstatemachine import CodingStateMachine -from .enums import LanguageFilter, ProbingState, MachineState -from .escsm import (HZ_SM_MODEL, ISO2022CN_SM_MODEL, ISO2022JP_SM_MODEL, - ISO2022KR_SM_MODEL) +from .enums import LanguageFilter, MachineState, ProbingState +from .escsm import ( + HZ_SM_MODEL, + ISO2022CN_SM_MODEL, + ISO2022JP_SM_MODEL, + ISO2022KR_SM_MODEL, +) class EscCharSetProber(CharSetProber): @@ -39,8 +45,8 @@ class EscCharSetProber(CharSetProber): identify these encodings. """ - def __init__(self, lang_filter=None): - super(EscCharSetProber, self).__init__(lang_filter=lang_filter) + def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: + super().__init__(lang_filter=lang_filter) self.coding_sm = [] if self.lang_filter & LanguageFilter.CHINESE_SIMPLIFIED: self.coding_sm.append(CodingStateMachine(HZ_SM_MODEL)) @@ -49,17 +55,15 @@ class EscCharSetProber(CharSetProber): self.coding_sm.append(CodingStateMachine(ISO2022JP_SM_MODEL)) if self.lang_filter & LanguageFilter.KOREAN: self.coding_sm.append(CodingStateMachine(ISO2022KR_SM_MODEL)) - self.active_sm_count = None - self._detected_charset = None - self._detected_language = None - self._state = None + self.active_sm_count = 0 + self._detected_charset: Optional[str] = None + self._detected_language: Optional[str] = None + self._state = ProbingState.DETECTING self.reset() - def reset(self): - super(EscCharSetProber, self).reset() + def reset(self) -> None: + super().reset() for coding_sm in self.coding_sm: - if not coding_sm: - continue coding_sm.active = True coding_sm.reset() self.active_sm_count = len(self.coding_sm) @@ -67,23 +71,20 @@ class EscCharSetProber(CharSetProber): self._detected_language = None @property - def charset_name(self): + def charset_name(self) -> Optional[str]: return self._detected_charset @property - def language(self): + def language(self) -> Optional[str]: return self._detected_language - def get_confidence(self): - if self._detected_charset: - return 0.99 - else: - return 0.00 + def get_confidence(self) -> float: + return 0.99 if self._detected_charset else 0.00 - def feed(self, byte_str): + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: for c in byte_str: for coding_sm in self.coding_sm: - if not coding_sm or not coding_sm.active: + if not coding_sm.active: continue coding_state = coding_sm.next_state(c) if coding_state == MachineState.ERROR: diff --git a/env/Lib/site-packages/pip/_vendor/chardet/escsm.py b/env/Lib/site-packages/pip/_vendor/chardet/escsm.py index 0069523a..11d4adf7 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/escsm.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/escsm.py @@ -12,7 +12,7 @@ # This library is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License as published by the Free Software Foundation; either -# version 2.1 of the License, or (at your option) any later version. +# version 2.1 of the License, or (at your option) any later version. # # This library is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -20,227 +20,242 @@ # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public -# License along with this library; if not, write to the Free Software -# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from .codingstatemachinedict import CodingStateMachineDict from .enums import MachineState +# fmt: off HZ_CLS = ( -1,0,0,0,0,0,0,0, # 00 - 07 -0,0,0,0,0,0,0,0, # 08 - 0f -0,0,0,0,0,0,0,0, # 10 - 17 -0,0,0,1,0,0,0,0, # 18 - 1f -0,0,0,0,0,0,0,0, # 20 - 27 -0,0,0,0,0,0,0,0, # 28 - 2f -0,0,0,0,0,0,0,0, # 30 - 37 -0,0,0,0,0,0,0,0, # 38 - 3f -0,0,0,0,0,0,0,0, # 40 - 47 -0,0,0,0,0,0,0,0, # 48 - 4f -0,0,0,0,0,0,0,0, # 50 - 57 -0,0,0,0,0,0,0,0, # 58 - 5f -0,0,0,0,0,0,0,0, # 60 - 67 -0,0,0,0,0,0,0,0, # 68 - 6f -0,0,0,0,0,0,0,0, # 70 - 77 -0,0,0,4,0,5,2,0, # 78 - 7f -1,1,1,1,1,1,1,1, # 80 - 87 -1,1,1,1,1,1,1,1, # 88 - 8f -1,1,1,1,1,1,1,1, # 90 - 97 -1,1,1,1,1,1,1,1, # 98 - 9f -1,1,1,1,1,1,1,1, # a0 - a7 -1,1,1,1,1,1,1,1, # a8 - af -1,1,1,1,1,1,1,1, # b0 - b7 -1,1,1,1,1,1,1,1, # b8 - bf -1,1,1,1,1,1,1,1, # c0 - c7 -1,1,1,1,1,1,1,1, # c8 - cf -1,1,1,1,1,1,1,1, # d0 - d7 -1,1,1,1,1,1,1,1, # d8 - df -1,1,1,1,1,1,1,1, # e0 - e7 -1,1,1,1,1,1,1,1, # e8 - ef -1,1,1,1,1,1,1,1, # f0 - f7 -1,1,1,1,1,1,1,1, # f8 - ff + 1, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 + 0, 0, 0, 0, 0, 0, 0, 0, # 08 - 0f + 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 + 0, 0, 0, 1, 0, 0, 0, 0, # 18 - 1f + 0, 0, 0, 0, 0, 0, 0, 0, # 20 - 27 + 0, 0, 0, 0, 0, 0, 0, 0, # 28 - 2f + 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 + 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f + 0, 0, 0, 0, 0, 0, 0, 0, # 40 - 47 + 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f + 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 + 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f + 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 + 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f + 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 + 0, 0, 0, 4, 0, 5, 2, 0, # 78 - 7f + 1, 1, 1, 1, 1, 1, 1, 1, # 80 - 87 + 1, 1, 1, 1, 1, 1, 1, 1, # 88 - 8f + 1, 1, 1, 1, 1, 1, 1, 1, # 90 - 97 + 1, 1, 1, 1, 1, 1, 1, 1, # 98 - 9f + 1, 1, 1, 1, 1, 1, 1, 1, # a0 - a7 + 1, 1, 1, 1, 1, 1, 1, 1, # a8 - af + 1, 1, 1, 1, 1, 1, 1, 1, # b0 - b7 + 1, 1, 1, 1, 1, 1, 1, 1, # b8 - bf + 1, 1, 1, 1, 1, 1, 1, 1, # c0 - c7 + 1, 1, 1, 1, 1, 1, 1, 1, # c8 - cf + 1, 1, 1, 1, 1, 1, 1, 1, # d0 - d7 + 1, 1, 1, 1, 1, 1, 1, 1, # d8 - df + 1, 1, 1, 1, 1, 1, 1, 1, # e0 - e7 + 1, 1, 1, 1, 1, 1, 1, 1, # e8 - ef + 1, 1, 1, 1, 1, 1, 1, 1, # f0 - f7 + 1, 1, 1, 1, 1, 1, 1, 1, # f8 - ff ) HZ_ST = ( -MachineState.START,MachineState.ERROR, 3,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,# 00-07 -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 08-0f -MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START, 4,MachineState.ERROR,# 10-17 - 5,MachineState.ERROR, 6,MachineState.ERROR, 5, 5, 4,MachineState.ERROR,# 18-1f - 4,MachineState.ERROR, 4, 4, 4,MachineState.ERROR, 4,MachineState.ERROR,# 20-27 - 4,MachineState.ITS_ME,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 28-2f +MachineState.START, MachineState.ERROR, 3, MachineState.START, MachineState.START, MachineState.START, MachineState.ERROR, MachineState.ERROR, # 00-07 +MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 08-0f +MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.START, MachineState.START, 4, MachineState.ERROR, # 10-17 + 5, MachineState.ERROR, 6, MachineState.ERROR, 5, 5, 4, MachineState.ERROR, # 18-1f + 4, MachineState.ERROR, 4, 4, 4, MachineState.ERROR, 4, MachineState.ERROR, # 20-27 + 4, MachineState.ITS_ME, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 28-2f ) +# fmt: on HZ_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0) -HZ_SM_MODEL = {'class_table': HZ_CLS, - 'class_factor': 6, - 'state_table': HZ_ST, - 'char_len_table': HZ_CHAR_LEN_TABLE, - 'name': "HZ-GB-2312", - 'language': 'Chinese'} +HZ_SM_MODEL: CodingStateMachineDict = { + "class_table": HZ_CLS, + "class_factor": 6, + "state_table": HZ_ST, + "char_len_table": HZ_CHAR_LEN_TABLE, + "name": "HZ-GB-2312", + "language": "Chinese", +} +# fmt: off ISO2022CN_CLS = ( -2,0,0,0,0,0,0,0, # 00 - 07 -0,0,0,0,0,0,0,0, # 08 - 0f -0,0,0,0,0,0,0,0, # 10 - 17 -0,0,0,1,0,0,0,0, # 18 - 1f -0,0,0,0,0,0,0,0, # 20 - 27 -0,3,0,0,0,0,0,0, # 28 - 2f -0,0,0,0,0,0,0,0, # 30 - 37 -0,0,0,0,0,0,0,0, # 38 - 3f -0,0,0,4,0,0,0,0, # 40 - 47 -0,0,0,0,0,0,0,0, # 48 - 4f -0,0,0,0,0,0,0,0, # 50 - 57 -0,0,0,0,0,0,0,0, # 58 - 5f -0,0,0,0,0,0,0,0, # 60 - 67 -0,0,0,0,0,0,0,0, # 68 - 6f -0,0,0,0,0,0,0,0, # 70 - 77 -0,0,0,0,0,0,0,0, # 78 - 7f -2,2,2,2,2,2,2,2, # 80 - 87 -2,2,2,2,2,2,2,2, # 88 - 8f -2,2,2,2,2,2,2,2, # 90 - 97 -2,2,2,2,2,2,2,2, # 98 - 9f -2,2,2,2,2,2,2,2, # a0 - a7 -2,2,2,2,2,2,2,2, # a8 - af -2,2,2,2,2,2,2,2, # b0 - b7 -2,2,2,2,2,2,2,2, # b8 - bf -2,2,2,2,2,2,2,2, # c0 - c7 -2,2,2,2,2,2,2,2, # c8 - cf -2,2,2,2,2,2,2,2, # d0 - d7 -2,2,2,2,2,2,2,2, # d8 - df -2,2,2,2,2,2,2,2, # e0 - e7 -2,2,2,2,2,2,2,2, # e8 - ef -2,2,2,2,2,2,2,2, # f0 - f7 -2,2,2,2,2,2,2,2, # f8 - ff + 2, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 + 0, 0, 0, 0, 0, 0, 0, 0, # 08 - 0f + 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 + 0, 0, 0, 1, 0, 0, 0, 0, # 18 - 1f + 0, 0, 0, 0, 0, 0, 0, 0, # 20 - 27 + 0, 3, 0, 0, 0, 0, 0, 0, # 28 - 2f + 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 + 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f + 0, 0, 0, 4, 0, 0, 0, 0, # 40 - 47 + 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f + 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 + 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f + 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 + 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f + 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 + 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f + 2, 2, 2, 2, 2, 2, 2, 2, # 80 - 87 + 2, 2, 2, 2, 2, 2, 2, 2, # 88 - 8f + 2, 2, 2, 2, 2, 2, 2, 2, # 90 - 97 + 2, 2, 2, 2, 2, 2, 2, 2, # 98 - 9f + 2, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 + 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af + 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 + 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf + 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 + 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf + 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 + 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df + 2, 2, 2, 2, 2, 2, 2, 2, # e0 - e7 + 2, 2, 2, 2, 2, 2, 2, 2, # e8 - ef + 2, 2, 2, 2, 2, 2, 2, 2, # f0 - f7 + 2, 2, 2, 2, 2, 2, 2, 2, # f8 - ff ) ISO2022CN_ST = ( -MachineState.START, 3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 00-07 -MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 08-0f -MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 10-17 -MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 4,MachineState.ERROR,# 18-1f -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 20-27 - 5, 6,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 28-2f -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 30-37 -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,# 38-3f + MachineState.START, 3, MachineState.ERROR, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 00-07 + MachineState.START, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 08-0f + MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 10-17 + MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 4, MachineState.ERROR, # 18-1f + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 20-27 + 5, 6, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 28-2f + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 30-37 + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.START, # 38-3f ) +# fmt: on ISO2022CN_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0, 0, 0, 0) -ISO2022CN_SM_MODEL = {'class_table': ISO2022CN_CLS, - 'class_factor': 9, - 'state_table': ISO2022CN_ST, - 'char_len_table': ISO2022CN_CHAR_LEN_TABLE, - 'name': "ISO-2022-CN", - 'language': 'Chinese'} +ISO2022CN_SM_MODEL: CodingStateMachineDict = { + "class_table": ISO2022CN_CLS, + "class_factor": 9, + "state_table": ISO2022CN_ST, + "char_len_table": ISO2022CN_CHAR_LEN_TABLE, + "name": "ISO-2022-CN", + "language": "Chinese", +} +# fmt: off ISO2022JP_CLS = ( -2,0,0,0,0,0,0,0, # 00 - 07 -0,0,0,0,0,0,2,2, # 08 - 0f -0,0,0,0,0,0,0,0, # 10 - 17 -0,0,0,1,0,0,0,0, # 18 - 1f -0,0,0,0,7,0,0,0, # 20 - 27 -3,0,0,0,0,0,0,0, # 28 - 2f -0,0,0,0,0,0,0,0, # 30 - 37 -0,0,0,0,0,0,0,0, # 38 - 3f -6,0,4,0,8,0,0,0, # 40 - 47 -0,9,5,0,0,0,0,0, # 48 - 4f -0,0,0,0,0,0,0,0, # 50 - 57 -0,0,0,0,0,0,0,0, # 58 - 5f -0,0,0,0,0,0,0,0, # 60 - 67 -0,0,0,0,0,0,0,0, # 68 - 6f -0,0,0,0,0,0,0,0, # 70 - 77 -0,0,0,0,0,0,0,0, # 78 - 7f -2,2,2,2,2,2,2,2, # 80 - 87 -2,2,2,2,2,2,2,2, # 88 - 8f -2,2,2,2,2,2,2,2, # 90 - 97 -2,2,2,2,2,2,2,2, # 98 - 9f -2,2,2,2,2,2,2,2, # a0 - a7 -2,2,2,2,2,2,2,2, # a8 - af -2,2,2,2,2,2,2,2, # b0 - b7 -2,2,2,2,2,2,2,2, # b8 - bf -2,2,2,2,2,2,2,2, # c0 - c7 -2,2,2,2,2,2,2,2, # c8 - cf -2,2,2,2,2,2,2,2, # d0 - d7 -2,2,2,2,2,2,2,2, # d8 - df -2,2,2,2,2,2,2,2, # e0 - e7 -2,2,2,2,2,2,2,2, # e8 - ef -2,2,2,2,2,2,2,2, # f0 - f7 -2,2,2,2,2,2,2,2, # f8 - ff + 2, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 + 0, 0, 0, 0, 0, 0, 2, 2, # 08 - 0f + 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 + 0, 0, 0, 1, 0, 0, 0, 0, # 18 - 1f + 0, 0, 0, 0, 7, 0, 0, 0, # 20 - 27 + 3, 0, 0, 0, 0, 0, 0, 0, # 28 - 2f + 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 + 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f + 6, 0, 4, 0, 8, 0, 0, 0, # 40 - 47 + 0, 9, 5, 0, 0, 0, 0, 0, # 48 - 4f + 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 + 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f + 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 + 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f + 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 + 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f + 2, 2, 2, 2, 2, 2, 2, 2, # 80 - 87 + 2, 2, 2, 2, 2, 2, 2, 2, # 88 - 8f + 2, 2, 2, 2, 2, 2, 2, 2, # 90 - 97 + 2, 2, 2, 2, 2, 2, 2, 2, # 98 - 9f + 2, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 + 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af + 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 + 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf + 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 + 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf + 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 + 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df + 2, 2, 2, 2, 2, 2, 2, 2, # e0 - e7 + 2, 2, 2, 2, 2, 2, 2, 2, # e8 - ef + 2, 2, 2, 2, 2, 2, 2, 2, # f0 - f7 + 2, 2, 2, 2, 2, 2, 2, 2, # f8 - ff ) ISO2022JP_ST = ( -MachineState.START, 3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 00-07 -MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 08-0f -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 10-17 -MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,# 18-1f -MachineState.ERROR, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 4,MachineState.ERROR,MachineState.ERROR,# 20-27 -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 6,MachineState.ITS_ME,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,# 28-2f -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,# 30-37 -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 38-3f -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,MachineState.START,# 40-47 + MachineState.START, 3, MachineState.ERROR, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 00-07 + MachineState.START, MachineState.START, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 08-0f + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 10-17 + MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, # 18-1f + MachineState.ERROR, 5, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 4, MachineState.ERROR, MachineState.ERROR, # 20-27 + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 6, MachineState.ITS_ME, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, # 28-2f + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, # 30-37 + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 38-3f + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.START, MachineState.START, # 40-47 ) +# fmt: on ISO2022JP_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0, 0, 0, 0, 0) -ISO2022JP_SM_MODEL = {'class_table': ISO2022JP_CLS, - 'class_factor': 10, - 'state_table': ISO2022JP_ST, - 'char_len_table': ISO2022JP_CHAR_LEN_TABLE, - 'name': "ISO-2022-JP", - 'language': 'Japanese'} +ISO2022JP_SM_MODEL: CodingStateMachineDict = { + "class_table": ISO2022JP_CLS, + "class_factor": 10, + "state_table": ISO2022JP_ST, + "char_len_table": ISO2022JP_CHAR_LEN_TABLE, + "name": "ISO-2022-JP", + "language": "Japanese", +} +# fmt: off ISO2022KR_CLS = ( -2,0,0,0,0,0,0,0, # 00 - 07 -0,0,0,0,0,0,0,0, # 08 - 0f -0,0,0,0,0,0,0,0, # 10 - 17 -0,0,0,1,0,0,0,0, # 18 - 1f -0,0,0,0,3,0,0,0, # 20 - 27 -0,4,0,0,0,0,0,0, # 28 - 2f -0,0,0,0,0,0,0,0, # 30 - 37 -0,0,0,0,0,0,0,0, # 38 - 3f -0,0,0,5,0,0,0,0, # 40 - 47 -0,0,0,0,0,0,0,0, # 48 - 4f -0,0,0,0,0,0,0,0, # 50 - 57 -0,0,0,0,0,0,0,0, # 58 - 5f -0,0,0,0,0,0,0,0, # 60 - 67 -0,0,0,0,0,0,0,0, # 68 - 6f -0,0,0,0,0,0,0,0, # 70 - 77 -0,0,0,0,0,0,0,0, # 78 - 7f -2,2,2,2,2,2,2,2, # 80 - 87 -2,2,2,2,2,2,2,2, # 88 - 8f -2,2,2,2,2,2,2,2, # 90 - 97 -2,2,2,2,2,2,2,2, # 98 - 9f -2,2,2,2,2,2,2,2, # a0 - a7 -2,2,2,2,2,2,2,2, # a8 - af -2,2,2,2,2,2,2,2, # b0 - b7 -2,2,2,2,2,2,2,2, # b8 - bf -2,2,2,2,2,2,2,2, # c0 - c7 -2,2,2,2,2,2,2,2, # c8 - cf -2,2,2,2,2,2,2,2, # d0 - d7 -2,2,2,2,2,2,2,2, # d8 - df -2,2,2,2,2,2,2,2, # e0 - e7 -2,2,2,2,2,2,2,2, # e8 - ef -2,2,2,2,2,2,2,2, # f0 - f7 -2,2,2,2,2,2,2,2, # f8 - ff + 2, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 + 0, 0, 0, 0, 0, 0, 0, 0, # 08 - 0f + 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 + 0, 0, 0, 1, 0, 0, 0, 0, # 18 - 1f + 0, 0, 0, 0, 3, 0, 0, 0, # 20 - 27 + 0, 4, 0, 0, 0, 0, 0, 0, # 28 - 2f + 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 + 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f + 0, 0, 0, 5, 0, 0, 0, 0, # 40 - 47 + 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f + 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 + 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f + 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 + 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f + 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 + 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f + 2, 2, 2, 2, 2, 2, 2, 2, # 80 - 87 + 2, 2, 2, 2, 2, 2, 2, 2, # 88 - 8f + 2, 2, 2, 2, 2, 2, 2, 2, # 90 - 97 + 2, 2, 2, 2, 2, 2, 2, 2, # 98 - 9f + 2, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 + 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af + 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 + 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf + 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 + 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf + 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 + 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df + 2, 2, 2, 2, 2, 2, 2, 2, # e0 - e7 + 2, 2, 2, 2, 2, 2, 2, 2, # e8 - ef + 2, 2, 2, 2, 2, 2, 2, 2, # f0 - f7 + 2, 2, 2, 2, 2, 2, 2, 2, # f8 - ff ) ISO2022KR_ST = ( -MachineState.START, 3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,# 00-07 -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 08-0f -MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 4,MachineState.ERROR,MachineState.ERROR,# 10-17 -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 18-1f -MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 20-27 + MachineState.START, 3, MachineState.ERROR, MachineState.START, MachineState.START, MachineState.START, MachineState.ERROR, MachineState.ERROR, # 00-07 + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 08-0f + MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 4, MachineState.ERROR, MachineState.ERROR, # 10-17 + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, 5, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 18-1f + MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 20-27 ) +# fmt: on ISO2022KR_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0) -ISO2022KR_SM_MODEL = {'class_table': ISO2022KR_CLS, - 'class_factor': 6, - 'state_table': ISO2022KR_ST, - 'char_len_table': ISO2022KR_CHAR_LEN_TABLE, - 'name': "ISO-2022-KR", - 'language': 'Korean'} - - +ISO2022KR_SM_MODEL: CodingStateMachineDict = { + "class_table": ISO2022KR_CLS, + "class_factor": 6, + "state_table": ISO2022KR_ST, + "char_len_table": ISO2022KR_CHAR_LEN_TABLE, + "name": "ISO-2022-KR", + "language": "Korean", +} diff --git a/env/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py b/env/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py index 20ce8f7d..39487f40 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py @@ -25,68 +25,78 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### -from .enums import ProbingState, MachineState -from .mbcharsetprober import MultiByteCharSetProber -from .codingstatemachine import CodingStateMachine +from typing import Union + from .chardistribution import EUCJPDistributionAnalysis +from .codingstatemachine import CodingStateMachine +from .enums import MachineState, ProbingState from .jpcntx import EUCJPContextAnalysis +from .mbcharsetprober import MultiByteCharSetProber from .mbcssm import EUCJP_SM_MODEL class EUCJPProber(MultiByteCharSetProber): - def __init__(self): - super(EUCJPProber, self).__init__() + def __init__(self) -> None: + super().__init__() self.coding_sm = CodingStateMachine(EUCJP_SM_MODEL) self.distribution_analyzer = EUCJPDistributionAnalysis() self.context_analyzer = EUCJPContextAnalysis() self.reset() - def reset(self): - super(EUCJPProber, self).reset() + def reset(self) -> None: + super().reset() self.context_analyzer.reset() @property - def charset_name(self): + def charset_name(self) -> str: return "EUC-JP" @property - def language(self): + def language(self) -> str: return "Japanese" - def feed(self, byte_str): - for i in range(len(byte_str)): - # PY3K: byte_str is a byte array, so byte_str[i] is an int, not a byte - coding_state = self.coding_sm.next_state(byte_str[i]) + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: + assert self.coding_sm is not None + assert self.distribution_analyzer is not None + + for i, byte in enumerate(byte_str): + # PY3K: byte_str is a byte array, so byte is an int, not a byte + coding_state = self.coding_sm.next_state(byte) if coding_state == MachineState.ERROR: - self.logger.debug('%s %s prober hit error at byte %s', - self.charset_name, self.language, i) + self.logger.debug( + "%s %s prober hit error at byte %s", + self.charset_name, + self.language, + i, + ) self._state = ProbingState.NOT_ME break - elif coding_state == MachineState.ITS_ME: + if coding_state == MachineState.ITS_ME: self._state = ProbingState.FOUND_IT break - elif coding_state == MachineState.START: + if coding_state == MachineState.START: char_len = self.coding_sm.get_current_charlen() if i == 0: - self._last_char[1] = byte_str[0] + self._last_char[1] = byte self.context_analyzer.feed(self._last_char, char_len) self.distribution_analyzer.feed(self._last_char, char_len) else: - self.context_analyzer.feed(byte_str[i - 1:i + 1], - char_len) - self.distribution_analyzer.feed(byte_str[i - 1:i + 1], - char_len) + self.context_analyzer.feed(byte_str[i - 1 : i + 1], char_len) + self.distribution_analyzer.feed(byte_str[i - 1 : i + 1], char_len) self._last_char[0] = byte_str[-1] if self.state == ProbingState.DETECTING: - if (self.context_analyzer.got_enough_data() and - (self.get_confidence() > self.SHORTCUT_THRESHOLD)): + if self.context_analyzer.got_enough_data() and ( + self.get_confidence() > self.SHORTCUT_THRESHOLD + ): self._state = ProbingState.FOUND_IT return self.state - def get_confidence(self): + def get_confidence(self) -> float: + assert self.distribution_analyzer is not None + context_conf = self.context_analyzer.get_confidence() distrib_conf = self.distribution_analyzer.get_confidence() return max(context_conf, distrib_conf) diff --git a/env/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py b/env/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py index b68078cb..7dc3b103 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py @@ -43,6 +43,7 @@ EUCKR_TYPICAL_DISTRIBUTION_RATIO = 6.0 EUCKR_TABLE_SIZE = 2352 # Char to FreqOrder table , +# fmt: off EUCKR_CHAR_TO_FREQ_ORDER = ( 13, 130, 120,1396, 481,1719,1720, 328, 609, 212,1721, 707, 400, 299,1722, 87, 1397,1723, 104, 536,1117,1203,1724,1267, 685,1268, 508,1725,1726,1727,1728,1398, @@ -192,4 +193,4 @@ EUCKR_CHAR_TO_FREQ_ORDER = ( 2629,2630,2631, 924, 648, 863, 603,2632,2633, 934,1540, 864, 865,2634, 642,1042, 670,1190,2635,2636,2637,2638, 168,2639, 652, 873, 542,1054,1541,2640,2641,2642, # 512, 256 ) - +# fmt: on diff --git a/env/Lib/site-packages/pip/_vendor/chardet/euckrprober.py b/env/Lib/site-packages/pip/_vendor/chardet/euckrprober.py index 345a060d..1fc5de04 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/euckrprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/euckrprober.py @@ -25,23 +25,23 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### -from .mbcharsetprober import MultiByteCharSetProber -from .codingstatemachine import CodingStateMachine from .chardistribution import EUCKRDistributionAnalysis +from .codingstatemachine import CodingStateMachine +from .mbcharsetprober import MultiByteCharSetProber from .mbcssm import EUCKR_SM_MODEL class EUCKRProber(MultiByteCharSetProber): - def __init__(self): - super(EUCKRProber, self).__init__() + def __init__(self) -> None: + super().__init__() self.coding_sm = CodingStateMachine(EUCKR_SM_MODEL) self.distribution_analyzer = EUCKRDistributionAnalysis() self.reset() @property - def charset_name(self): + def charset_name(self) -> str: return "EUC-KR" @property - def language(self): + def language(self) -> str: return "Korean" diff --git a/env/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py b/env/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py index ed7a995a..4900ccc1 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py @@ -43,345 +43,346 @@ EUCTW_TYPICAL_DISTRIBUTION_RATIO = 0.75 -# Char to FreqOrder table , +# Char to FreqOrder table EUCTW_TABLE_SIZE = 5376 +# fmt: off EUCTW_CHAR_TO_FREQ_ORDER = ( - 1,1800,1506, 255,1431, 198, 9, 82, 6,7310, 177, 202,3615,1256,2808, 110, # 2742 -3735, 33,3241, 261, 76, 44,2113, 16,2931,2184,1176, 659,3868, 26,3404,2643, # 2758 -1198,3869,3313,4060, 410,2211, 302, 590, 361,1963, 8, 204, 58,4296,7311,1931, # 2774 - 63,7312,7313, 317,1614, 75, 222, 159,4061,2412,1480,7314,3500,3068, 224,2809, # 2790 -3616, 3, 10,3870,1471, 29,2774,1135,2852,1939, 873, 130,3242,1123, 312,7315, # 2806 -4297,2051, 507, 252, 682,7316, 142,1914, 124, 206,2932, 34,3501,3173, 64, 604, # 2822 -7317,2494,1976,1977, 155,1990, 645, 641,1606,7318,3405, 337, 72, 406,7319, 80, # 2838 - 630, 238,3174,1509, 263, 939,1092,2644, 756,1440,1094,3406, 449, 69,2969, 591, # 2854 - 179,2095, 471, 115,2034,1843, 60, 50,2970, 134, 806,1868, 734,2035,3407, 180, # 2870 - 995,1607, 156, 537,2893, 688,7320, 319,1305, 779,2144, 514,2374, 298,4298, 359, # 2886 -2495, 90,2707,1338, 663, 11, 906,1099,2545, 20,2436, 182, 532,1716,7321, 732, # 2902 -1376,4062,1311,1420,3175, 25,2312,1056, 113, 399, 382,1949, 242,3408,2467, 529, # 2918 -3243, 475,1447,3617,7322, 117, 21, 656, 810,1297,2295,2329,3502,7323, 126,4063, # 2934 - 706, 456, 150, 613,4299, 71,1118,2036,4064, 145,3069, 85, 835, 486,2114,1246, # 2950 -1426, 428, 727,1285,1015, 800, 106, 623, 303,1281,7324,2127,2354, 347,3736, 221, # 2966 -3503,3110,7325,1955,1153,4065, 83, 296,1199,3070, 192, 624, 93,7326, 822,1897, # 2982 -2810,3111, 795,2064, 991,1554,1542,1592, 27, 43,2853, 859, 139,1456, 860,4300, # 2998 - 437, 712,3871, 164,2392,3112, 695, 211,3017,2096, 195,3872,1608,3504,3505,3618, # 3014 -3873, 234, 811,2971,2097,3874,2229,1441,3506,1615,2375, 668,2076,1638, 305, 228, # 3030 -1664,4301, 467, 415,7327, 262,2098,1593, 239, 108, 300, 200,1033, 512,1247,2077, # 3046 -7328,7329,2173,3176,3619,2673, 593, 845,1062,3244, 88,1723,2037,3875,1950, 212, # 3062 - 266, 152, 149, 468,1898,4066,4302, 77, 187,7330,3018, 37, 5,2972,7331,3876, # 3078 -7332,7333, 39,2517,4303,2894,3177,2078, 55, 148, 74,4304, 545, 483,1474,1029, # 3094 -1665, 217,1869,1531,3113,1104,2645,4067, 24, 172,3507, 900,3877,3508,3509,4305, # 3110 - 32,1408,2811,1312, 329, 487,2355,2247,2708, 784,2674, 4,3019,3314,1427,1788, # 3126 - 188, 109, 499,7334,3620,1717,1789, 888,1217,3020,4306,7335,3510,7336,3315,1520, # 3142 -3621,3878, 196,1034, 775,7337,7338, 929,1815, 249, 439, 38,7339,1063,7340, 794, # 3158 -3879,1435,2296, 46, 178,3245,2065,7341,2376,7342, 214,1709,4307, 804, 35, 707, # 3174 - 324,3622,1601,2546, 140, 459,4068,7343,7344,1365, 839, 272, 978,2257,2572,3409, # 3190 -2128,1363,3623,1423, 697, 100,3071, 48, 70,1231, 495,3114,2193,7345,1294,7346, # 3206 -2079, 462, 586,1042,3246, 853, 256, 988, 185,2377,3410,1698, 434,1084,7347,3411, # 3222 - 314,2615,2775,4308,2330,2331, 569,2280, 637,1816,2518, 757,1162,1878,1616,3412, # 3238 - 287,1577,2115, 768,4309,1671,2854,3511,2519,1321,3737, 909,2413,7348,4069, 933, # 3254 -3738,7349,2052,2356,1222,4310, 765,2414,1322, 786,4311,7350,1919,1462,1677,2895, # 3270 -1699,7351,4312,1424,2437,3115,3624,2590,3316,1774,1940,3413,3880,4070, 309,1369, # 3286 -1130,2812, 364,2230,1653,1299,3881,3512,3882,3883,2646, 525,1085,3021, 902,2000, # 3302 -1475, 964,4313, 421,1844,1415,1057,2281, 940,1364,3116, 376,4314,4315,1381, 7, # 3318 -2520, 983,2378, 336,1710,2675,1845, 321,3414, 559,1131,3022,2742,1808,1132,1313, # 3334 - 265,1481,1857,7352, 352,1203,2813,3247, 167,1089, 420,2814, 776, 792,1724,3513, # 3350 -4071,2438,3248,7353,4072,7354, 446, 229, 333,2743, 901,3739,1200,1557,4316,2647, # 3366 -1920, 395,2744,2676,3740,4073,1835, 125, 916,3178,2616,4317,7355,7356,3741,7357, # 3382 -7358,7359,4318,3117,3625,1133,2547,1757,3415,1510,2313,1409,3514,7360,2145, 438, # 3398 -2591,2896,2379,3317,1068, 958,3023, 461, 311,2855,2677,4074,1915,3179,4075,1978, # 3414 - 383, 750,2745,2617,4076, 274, 539, 385,1278,1442,7361,1154,1964, 384, 561, 210, # 3430 - 98,1295,2548,3515,7362,1711,2415,1482,3416,3884,2897,1257, 129,7363,3742, 642, # 3446 - 523,2776,2777,2648,7364, 141,2231,1333, 68, 176, 441, 876, 907,4077, 603,2592, # 3462 - 710, 171,3417, 404, 549, 18,3118,2393,1410,3626,1666,7365,3516,4319,2898,4320, # 3478 -7366,2973, 368,7367, 146, 366, 99, 871,3627,1543, 748, 807,1586,1185, 22,2258, # 3494 - 379,3743,3180,7368,3181, 505,1941,2618,1991,1382,2314,7369, 380,2357, 218, 702, # 3510 -1817,1248,3418,3024,3517,3318,3249,7370,2974,3628, 930,3250,3744,7371, 59,7372, # 3526 - 585, 601,4078, 497,3419,1112,1314,4321,1801,7373,1223,1472,2174,7374, 749,1836, # 3542 - 690,1899,3745,1772,3885,1476, 429,1043,1790,2232,2116, 917,4079, 447,1086,1629, # 3558 -7375, 556,7376,7377,2020,1654, 844,1090, 105, 550, 966,1758,2815,1008,1782, 686, # 3574 -1095,7378,2282, 793,1602,7379,3518,2593,4322,4080,2933,2297,4323,3746, 980,2496, # 3590 - 544, 353, 527,4324, 908,2678,2899,7380, 381,2619,1942,1348,7381,1341,1252, 560, # 3606 -3072,7382,3420,2856,7383,2053, 973, 886,2080, 143,4325,7384,7385, 157,3886, 496, # 3622 -4081, 57, 840, 540,2038,4326,4327,3421,2117,1445, 970,2259,1748,1965,2081,4082, # 3638 -3119,1234,1775,3251,2816,3629, 773,1206,2129,1066,2039,1326,3887,1738,1725,4083, # 3654 - 279,3120, 51,1544,2594, 423,1578,2130,2066, 173,4328,1879,7386,7387,1583, 264, # 3670 - 610,3630,4329,2439, 280, 154,7388,7389,7390,1739, 338,1282,3073, 693,2857,1411, # 3686 -1074,3747,2440,7391,4330,7392,7393,1240, 952,2394,7394,2900,1538,2679, 685,1483, # 3702 -4084,2468,1436, 953,4085,2054,4331, 671,2395, 79,4086,2441,3252, 608, 567,2680, # 3718 -3422,4087,4088,1691, 393,1261,1791,2396,7395,4332,7396,7397,7398,7399,1383,1672, # 3734 -3748,3182,1464, 522,1119, 661,1150, 216, 675,4333,3888,1432,3519, 609,4334,2681, # 3750 -2397,7400,7401,7402,4089,3025, 0,7403,2469, 315, 231,2442, 301,3319,4335,2380, # 3766 -7404, 233,4090,3631,1818,4336,4337,7405, 96,1776,1315,2082,7406, 257,7407,1809, # 3782 -3632,2709,1139,1819,4091,2021,1124,2163,2778,1777,2649,7408,3074, 363,1655,3183, # 3798 -7409,2975,7410,7411,7412,3889,1567,3890, 718, 103,3184, 849,1443, 341,3320,2934, # 3814 -1484,7413,1712, 127, 67, 339,4092,2398, 679,1412, 821,7414,7415, 834, 738, 351, # 3830 -2976,2146, 846, 235,1497,1880, 418,1992,3749,2710, 186,1100,2147,2746,3520,1545, # 3846 -1355,2935,2858,1377, 583,3891,4093,2573,2977,7416,1298,3633,1078,2549,3634,2358, # 3862 - 78,3750,3751, 267,1289,2099,2001,1594,4094, 348, 369,1274,2194,2175,1837,4338, # 3878 -1820,2817,3635,2747,2283,2002,4339,2936,2748, 144,3321, 882,4340,3892,2749,3423, # 3894 -4341,2901,7417,4095,1726, 320,7418,3893,3026, 788,2978,7419,2818,1773,1327,2859, # 3910 -3894,2819,7420,1306,4342,2003,1700,3752,3521,2359,2650, 787,2022, 506, 824,3636, # 3926 - 534, 323,4343,1044,3322,2023,1900, 946,3424,7421,1778,1500,1678,7422,1881,4344, # 3942 - 165, 243,4345,3637,2521, 123, 683,4096, 764,4346, 36,3895,1792, 589,2902, 816, # 3958 - 626,1667,3027,2233,1639,1555,1622,3753,3896,7423,3897,2860,1370,1228,1932, 891, # 3974 -2083,2903, 304,4097,7424, 292,2979,2711,3522, 691,2100,4098,1115,4347, 118, 662, # 3990 -7425, 611,1156, 854,2381,1316,2861, 2, 386, 515,2904,7426,7427,3253, 868,2234, # 4006 -1486, 855,2651, 785,2212,3028,7428,1040,3185,3523,7429,3121, 448,7430,1525,7431, # 4022 -2164,4348,7432,3754,7433,4099,2820,3524,3122, 503, 818,3898,3123,1568, 814, 676, # 4038 -1444, 306,1749,7434,3755,1416,1030, 197,1428, 805,2821,1501,4349,7435,7436,7437, # 4054 -1993,7438,4350,7439,7440,2195, 13,2779,3638,2980,3124,1229,1916,7441,3756,2131, # 4070 -7442,4100,4351,2399,3525,7443,2213,1511,1727,1120,7444,7445, 646,3757,2443, 307, # 4086 -7446,7447,1595,3186,7448,7449,7450,3639,1113,1356,3899,1465,2522,2523,7451, 519, # 4102 -7452, 128,2132, 92,2284,1979,7453,3900,1512, 342,3125,2196,7454,2780,2214,1980, # 4118 -3323,7455, 290,1656,1317, 789, 827,2360,7456,3758,4352, 562, 581,3901,7457, 401, # 4134 -4353,2248, 94,4354,1399,2781,7458,1463,2024,4355,3187,1943,7459, 828,1105,4101, # 4150 -1262,1394,7460,4102, 605,4356,7461,1783,2862,7462,2822, 819,2101, 578,2197,2937, # 4166 -7463,1502, 436,3254,4103,3255,2823,3902,2905,3425,3426,7464,2712,2315,7465,7466, # 4182 -2332,2067, 23,4357, 193, 826,3759,2102, 699,1630,4104,3075, 390,1793,1064,3526, # 4198 -7467,1579,3076,3077,1400,7468,4105,1838,1640,2863,7469,4358,4359, 137,4106, 598, # 4214 -3078,1966, 780, 104, 974,2938,7470, 278, 899, 253, 402, 572, 504, 493,1339,7471, # 4230 -3903,1275,4360,2574,2550,7472,3640,3029,3079,2249, 565,1334,2713, 863, 41,7473, # 4246 -7474,4361,7475,1657,2333, 19, 463,2750,4107, 606,7476,2981,3256,1087,2084,1323, # 4262 -2652,2982,7477,1631,1623,1750,4108,2682,7478,2864, 791,2714,2653,2334, 232,2416, # 4278 -7479,2983,1498,7480,2654,2620, 755,1366,3641,3257,3126,2025,1609, 119,1917,3427, # 4294 - 862,1026,4109,7481,3904,3760,4362,3905,4363,2260,1951,2470,7482,1125, 817,4110, # 4310 -4111,3906,1513,1766,2040,1487,4112,3030,3258,2824,3761,3127,7483,7484,1507,7485, # 4326 -2683, 733, 40,1632,1106,2865, 345,4113, 841,2524, 230,4364,2984,1846,3259,3428, # 4342 -7486,1263, 986,3429,7487, 735, 879, 254,1137, 857, 622,1300,1180,1388,1562,3907, # 4358 -3908,2939, 967,2751,2655,1349, 592,2133,1692,3324,2985,1994,4114,1679,3909,1901, # 4374 -2185,7488, 739,3642,2715,1296,1290,7489,4115,2198,2199,1921,1563,2595,2551,1870, # 4390 -2752,2986,7490, 435,7491, 343,1108, 596, 17,1751,4365,2235,3430,3643,7492,4366, # 4406 - 294,3527,2940,1693, 477, 979, 281,2041,3528, 643,2042,3644,2621,2782,2261,1031, # 4422 -2335,2134,2298,3529,4367, 367,1249,2552,7493,3530,7494,4368,1283,3325,2004, 240, # 4438 -1762,3326,4369,4370, 836,1069,3128, 474,7495,2148,2525, 268,3531,7496,3188,1521, # 4454 -1284,7497,1658,1546,4116,7498,3532,3533,7499,4117,3327,2684,1685,4118, 961,1673, # 4470 -2622, 190,2005,2200,3762,4371,4372,7500, 570,2497,3645,1490,7501,4373,2623,3260, # 4486 -1956,4374, 584,1514, 396,1045,1944,7502,4375,1967,2444,7503,7504,4376,3910, 619, # 4502 -7505,3129,3261, 215,2006,2783,2553,3189,4377,3190,4378, 763,4119,3763,4379,7506, # 4518 -7507,1957,1767,2941,3328,3646,1174, 452,1477,4380,3329,3130,7508,2825,1253,2382, # 4534 -2186,1091,2285,4120, 492,7509, 638,1169,1824,2135,1752,3911, 648, 926,1021,1324, # 4550 -4381, 520,4382, 997, 847,1007, 892,4383,3764,2262,1871,3647,7510,2400,1784,4384, # 4566 -1952,2942,3080,3191,1728,4121,2043,3648,4385,2007,1701,3131,1551, 30,2263,4122, # 4582 -7511,2026,4386,3534,7512, 501,7513,4123, 594,3431,2165,1821,3535,3432,3536,3192, # 4598 - 829,2826,4124,7514,1680,3132,1225,4125,7515,3262,4387,4126,3133,2336,7516,4388, # 4614 -4127,7517,3912,3913,7518,1847,2383,2596,3330,7519,4389, 374,3914, 652,4128,4129, # 4630 - 375,1140, 798,7520,7521,7522,2361,4390,2264, 546,1659, 138,3031,2445,4391,7523, # 4646 -2250, 612,1848, 910, 796,3765,1740,1371, 825,3766,3767,7524,2906,2554,7525, 692, # 4662 - 444,3032,2624, 801,4392,4130,7526,1491, 244,1053,3033,4131,4132, 340,7527,3915, # 4678 -1041,2987, 293,1168, 87,1357,7528,1539, 959,7529,2236, 721, 694,4133,3768, 219, # 4694 -1478, 644,1417,3331,2656,1413,1401,1335,1389,3916,7530,7531,2988,2362,3134,1825, # 4710 - 730,1515, 184,2827, 66,4393,7532,1660,2943, 246,3332, 378,1457, 226,3433, 975, # 4726 -3917,2944,1264,3537, 674, 696,7533, 163,7534,1141,2417,2166, 713,3538,3333,4394, # 4742 -3918,7535,7536,1186, 15,7537,1079,1070,7538,1522,3193,3539, 276,1050,2716, 758, # 4758 -1126, 653,2945,3263,7539,2337, 889,3540,3919,3081,2989, 903,1250,4395,3920,3434, # 4774 -3541,1342,1681,1718, 766,3264, 286, 89,2946,3649,7540,1713,7541,2597,3334,2990, # 4790 -7542,2947,2215,3194,2866,7543,4396,2498,2526, 181, 387,1075,3921, 731,2187,3335, # 4806 -7544,3265, 310, 313,3435,2299, 770,4134, 54,3034, 189,4397,3082,3769,3922,7545, # 4822 -1230,1617,1849, 355,3542,4135,4398,3336, 111,4136,3650,1350,3135,3436,3035,4137, # 4838 -2149,3266,3543,7546,2784,3923,3924,2991, 722,2008,7547,1071, 247,1207,2338,2471, # 4854 -1378,4399,2009, 864,1437,1214,4400, 373,3770,1142,2216, 667,4401, 442,2753,2555, # 4870 -3771,3925,1968,4138,3267,1839, 837, 170,1107, 934,1336,1882,7548,7549,2118,4139, # 4886 -2828, 743,1569,7550,4402,4140, 582,2384,1418,3437,7551,1802,7552, 357,1395,1729, # 4902 -3651,3268,2418,1564,2237,7553,3083,3772,1633,4403,1114,2085,4141,1532,7554, 482, # 4918 -2446,4404,7555,7556,1492, 833,1466,7557,2717,3544,1641,2829,7558,1526,1272,3652, # 4934 -4142,1686,1794, 416,2556,1902,1953,1803,7559,3773,2785,3774,1159,2316,7560,2867, # 4950 -4405,1610,1584,3036,2419,2754, 443,3269,1163,3136,7561,7562,3926,7563,4143,2499, # 4966 -3037,4406,3927,3137,2103,1647,3545,2010,1872,4144,7564,4145, 431,3438,7565, 250, # 4982 - 97, 81,4146,7566,1648,1850,1558, 160, 848,7567, 866, 740,1694,7568,2201,2830, # 4998 -3195,4147,4407,3653,1687, 950,2472, 426, 469,3196,3654,3655,3928,7569,7570,1188, # 5014 - 424,1995, 861,3546,4148,3775,2202,2685, 168,1235,3547,4149,7571,2086,1674,4408, # 5030 -3337,3270, 220,2557,1009,7572,3776, 670,2992, 332,1208, 717,7573,7574,3548,2447, # 5046 -3929,3338,7575, 513,7576,1209,2868,3339,3138,4409,1080,7577,7578,7579,7580,2527, # 5062 -3656,3549, 815,1587,3930,3931,7581,3550,3439,3777,1254,4410,1328,3038,1390,3932, # 5078 -1741,3933,3778,3934,7582, 236,3779,2448,3271,7583,7584,3657,3780,1273,3781,4411, # 5094 -7585, 308,7586,4412, 245,4413,1851,2473,1307,2575, 430, 715,2136,2449,7587, 270, # 5110 - 199,2869,3935,7588,3551,2718,1753, 761,1754, 725,1661,1840,4414,3440,3658,7589, # 5126 -7590, 587, 14,3272, 227,2598, 326, 480,2265, 943,2755,3552, 291, 650,1883,7591, # 5142 -1702,1226, 102,1547, 62,3441, 904,4415,3442,1164,4150,7592,7593,1224,1548,2756, # 5158 - 391, 498,1493,7594,1386,1419,7595,2055,1177,4416, 813, 880,1081,2363, 566,1145, # 5174 -4417,2286,1001,1035,2558,2599,2238, 394,1286,7596,7597,2068,7598, 86,1494,1730, # 5190 -3936, 491,1588, 745, 897,2948, 843,3340,3937,2757,2870,3273,1768, 998,2217,2069, # 5206 - 397,1826,1195,1969,3659,2993,3341, 284,7599,3782,2500,2137,2119,1903,7600,3938, # 5222 -2150,3939,4151,1036,3443,1904, 114,2559,4152, 209,1527,7601,7602,2949,2831,2625, # 5238 -2385,2719,3139, 812,2560,7603,3274,7604,1559, 737,1884,3660,1210, 885, 28,2686, # 5254 -3553,3783,7605,4153,1004,1779,4418,7606, 346,1981,2218,2687,4419,3784,1742, 797, # 5270 -1642,3940,1933,1072,1384,2151, 896,3941,3275,3661,3197,2871,3554,7607,2561,1958, # 5286 -4420,2450,1785,7608,7609,7610,3942,4154,1005,1308,3662,4155,2720,4421,4422,1528, # 5302 -2600, 161,1178,4156,1982, 987,4423,1101,4157, 631,3943,1157,3198,2420,1343,1241, # 5318 -1016,2239,2562, 372, 877,2339,2501,1160, 555,1934, 911,3944,7611, 466,1170, 169, # 5334 -1051,2907,2688,3663,2474,2994,1182,2011,2563,1251,2626,7612, 992,2340,3444,1540, # 5350 -2721,1201,2070,2401,1996,2475,7613,4424, 528,1922,2188,1503,1873,1570,2364,3342, # 5366 -3276,7614, 557,1073,7615,1827,3445,2087,2266,3140,3039,3084, 767,3085,2786,4425, # 5382 -1006,4158,4426,2341,1267,2176,3664,3199, 778,3945,3200,2722,1597,2657,7616,4427, # 5398 -7617,3446,7618,7619,7620,3277,2689,1433,3278, 131, 95,1504,3946, 723,4159,3141, # 5414 -1841,3555,2758,2189,3947,2027,2104,3665,7621,2995,3948,1218,7622,3343,3201,3949, # 5430 -4160,2576, 248,1634,3785, 912,7623,2832,3666,3040,3786, 654, 53,7624,2996,7625, # 5446 -1688,4428, 777,3447,1032,3950,1425,7626, 191, 820,2120,2833, 971,4429, 931,3202, # 5462 - 135, 664, 783,3787,1997, 772,2908,1935,3951,3788,4430,2909,3203, 282,2723, 640, # 5478 -1372,3448,1127, 922, 325,3344,7627,7628, 711,2044,7629,7630,3952,2219,2787,1936, # 5494 -3953,3345,2220,2251,3789,2300,7631,4431,3790,1258,3279,3954,3204,2138,2950,3955, # 5510 -3956,7632,2221, 258,3205,4432, 101,1227,7633,3280,1755,7634,1391,3281,7635,2910, # 5526 -2056, 893,7636,7637,7638,1402,4161,2342,7639,7640,3206,3556,7641,7642, 878,1325, # 5542 -1780,2788,4433, 259,1385,2577, 744,1183,2267,4434,7643,3957,2502,7644, 684,1024, # 5558 -4162,7645, 472,3557,3449,1165,3282,3958,3959, 322,2152, 881, 455,1695,1152,1340, # 5574 - 660, 554,2153,4435,1058,4436,4163, 830,1065,3346,3960,4437,1923,7646,1703,1918, # 5590 -7647, 932,2268, 122,7648,4438, 947, 677,7649,3791,2627, 297,1905,1924,2269,4439, # 5606 -2317,3283,7650,7651,4164,7652,4165, 84,4166, 112, 989,7653, 547,1059,3961, 701, # 5622 -3558,1019,7654,4167,7655,3450, 942, 639, 457,2301,2451, 993,2951, 407, 851, 494, # 5638 -4440,3347, 927,7656,1237,7657,2421,3348, 573,4168, 680, 921,2911,1279,1874, 285, # 5654 - 790,1448,1983, 719,2167,7658,7659,4441,3962,3963,1649,7660,1541, 563,7661,1077, # 5670 -7662,3349,3041,3451, 511,2997,3964,3965,3667,3966,1268,2564,3350,3207,4442,4443, # 5686 -7663, 535,1048,1276,1189,2912,2028,3142,1438,1373,2834,2952,1134,2012,7664,4169, # 5702 -1238,2578,3086,1259,7665, 700,7666,2953,3143,3668,4170,7667,4171,1146,1875,1906, # 5718 -4444,2601,3967, 781,2422, 132,1589, 203, 147, 273,2789,2402, 898,1786,2154,3968, # 5734 -3969,7668,3792,2790,7669,7670,4445,4446,7671,3208,7672,1635,3793, 965,7673,1804, # 5750 -2690,1516,3559,1121,1082,1329,3284,3970,1449,3794, 65,1128,2835,2913,2759,1590, # 5766 -3795,7674,7675, 12,2658, 45, 976,2579,3144,4447, 517,2528,1013,1037,3209,7676, # 5782 -3796,2836,7677,3797,7678,3452,7679,2602, 614,1998,2318,3798,3087,2724,2628,7680, # 5798 -2580,4172, 599,1269,7681,1810,3669,7682,2691,3088, 759,1060, 489,1805,3351,3285, # 5814 -1358,7683,7684,2386,1387,1215,2629,2252, 490,7685,7686,4173,1759,2387,2343,7687, # 5830 -4448,3799,1907,3971,2630,1806,3210,4449,3453,3286,2760,2344, 874,7688,7689,3454, # 5846 -3670,1858, 91,2914,3671,3042,3800,4450,7690,3145,3972,2659,7691,3455,1202,1403, # 5862 -3801,2954,2529,1517,2503,4451,3456,2504,7692,4452,7693,2692,1885,1495,1731,3973, # 5878 -2365,4453,7694,2029,7695,7696,3974,2693,1216, 237,2581,4174,2319,3975,3802,4454, # 5894 -4455,2694,3560,3457, 445,4456,7697,7698,7699,7700,2761, 61,3976,3672,1822,3977, # 5910 -7701, 687,2045, 935, 925, 405,2660, 703,1096,1859,2725,4457,3978,1876,1367,2695, # 5926 -3352, 918,2105,1781,2476, 334,3287,1611,1093,4458, 564,3146,3458,3673,3353, 945, # 5942 -2631,2057,4459,7702,1925, 872,4175,7703,3459,2696,3089, 349,4176,3674,3979,4460, # 5958 -3803,4177,3675,2155,3980,4461,4462,4178,4463,2403,2046, 782,3981, 400, 251,4179, # 5974 -1624,7704,7705, 277,3676, 299,1265, 476,1191,3804,2121,4180,4181,1109, 205,7706, # 5990 -2582,1000,2156,3561,1860,7707,7708,7709,4464,7710,4465,2565, 107,2477,2157,3982, # 6006 -3460,3147,7711,1533, 541,1301, 158, 753,4182,2872,3562,7712,1696, 370,1088,4183, # 6022 -4466,3563, 579, 327, 440, 162,2240, 269,1937,1374,3461, 968,3043, 56,1396,3090, # 6038 -2106,3288,3354,7713,1926,2158,4467,2998,7714,3564,7715,7716,3677,4468,2478,7717, # 6054 -2791,7718,1650,4469,7719,2603,7720,7721,3983,2661,3355,1149,3356,3984,3805,3985, # 6070 -7722,1076, 49,7723, 951,3211,3289,3290, 450,2837, 920,7724,1811,2792,2366,4184, # 6086 -1908,1138,2367,3806,3462,7725,3212,4470,1909,1147,1518,2423,4471,3807,7726,4472, # 6102 -2388,2604, 260,1795,3213,7727,7728,3808,3291, 708,7729,3565,1704,7730,3566,1351, # 6118 -1618,3357,2999,1886, 944,4185,3358,4186,3044,3359,4187,7731,3678, 422, 413,1714, # 6134 -3292, 500,2058,2345,4188,2479,7732,1344,1910, 954,7733,1668,7734,7735,3986,2404, # 6150 -4189,3567,3809,4190,7736,2302,1318,2505,3091, 133,3092,2873,4473, 629, 31,2838, # 6166 -2697,3810,4474, 850, 949,4475,3987,2955,1732,2088,4191,1496,1852,7737,3988, 620, # 6182 -3214, 981,1242,3679,3360,1619,3680,1643,3293,2139,2452,1970,1719,3463,2168,7738, # 6198 -3215,7739,7740,3361,1828,7741,1277,4476,1565,2047,7742,1636,3568,3093,7743, 869, # 6214 -2839, 655,3811,3812,3094,3989,3000,3813,1310,3569,4477,7744,7745,7746,1733, 558, # 6230 -4478,3681, 335,1549,3045,1756,4192,3682,1945,3464,1829,1291,1192, 470,2726,2107, # 6246 -2793, 913,1054,3990,7747,1027,7748,3046,3991,4479, 982,2662,3362,3148,3465,3216, # 6262 -3217,1946,2794,7749, 571,4480,7750,1830,7751,3570,2583,1523,2424,7752,2089, 984, # 6278 -4481,3683,1959,7753,3684, 852, 923,2795,3466,3685, 969,1519, 999,2048,2320,1705, # 6294 -7754,3095, 615,1662, 151, 597,3992,2405,2321,1049, 275,4482,3686,4193, 568,3687, # 6310 -3571,2480,4194,3688,7755,2425,2270, 409,3218,7756,1566,2874,3467,1002, 769,2840, # 6326 - 194,2090,3149,3689,2222,3294,4195, 628,1505,7757,7758,1763,2177,3001,3993, 521, # 6342 -1161,2584,1787,2203,2406,4483,3994,1625,4196,4197, 412, 42,3096, 464,7759,2632, # 6358 -4484,3363,1760,1571,2875,3468,2530,1219,2204,3814,2633,2140,2368,4485,4486,3295, # 6374 -1651,3364,3572,7760,7761,3573,2481,3469,7762,3690,7763,7764,2271,2091, 460,7765, # 6390 -4487,7766,3002, 962, 588,3574, 289,3219,2634,1116, 52,7767,3047,1796,7768,7769, # 6406 -7770,1467,7771,1598,1143,3691,4198,1984,1734,1067,4488,1280,3365, 465,4489,1572, # 6422 - 510,7772,1927,2241,1812,1644,3575,7773,4490,3692,7774,7775,2663,1573,1534,7776, # 6438 -7777,4199, 536,1807,1761,3470,3815,3150,2635,7778,7779,7780,4491,3471,2915,1911, # 6454 -2796,7781,3296,1122, 377,3220,7782, 360,7783,7784,4200,1529, 551,7785,2059,3693, # 6470 -1769,2426,7786,2916,4201,3297,3097,2322,2108,2030,4492,1404, 136,1468,1479, 672, # 6486 -1171,3221,2303, 271,3151,7787,2762,7788,2049, 678,2727, 865,1947,4493,7789,2013, # 6502 -3995,2956,7790,2728,2223,1397,3048,3694,4494,4495,1735,2917,3366,3576,7791,3816, # 6518 - 509,2841,2453,2876,3817,7792,7793,3152,3153,4496,4202,2531,4497,2304,1166,1010, # 6534 - 552, 681,1887,7794,7795,2957,2958,3996,1287,1596,1861,3154, 358, 453, 736, 175, # 6550 - 478,1117, 905,1167,1097,7796,1853,1530,7797,1706,7798,2178,3472,2287,3695,3473, # 6566 -3577,4203,2092,4204,7799,3367,1193,2482,4205,1458,2190,2205,1862,1888,1421,3298, # 6582 -2918,3049,2179,3474, 595,2122,7800,3997,7801,7802,4206,1707,2636, 223,3696,1359, # 6598 - 751,3098, 183,3475,7803,2797,3003, 419,2369, 633, 704,3818,2389, 241,7804,7805, # 6614 -7806, 838,3004,3697,2272,2763,2454,3819,1938,2050,3998,1309,3099,2242,1181,7807, # 6630 -1136,2206,3820,2370,1446,4207,2305,4498,7808,7809,4208,1055,2605, 484,3698,7810, # 6646 -3999, 625,4209,2273,3368,1499,4210,4000,7811,4001,4211,3222,2274,2275,3476,7812, # 6662 -7813,2764, 808,2606,3699,3369,4002,4212,3100,2532, 526,3370,3821,4213, 955,7814, # 6678 -1620,4214,2637,2427,7815,1429,3700,1669,1831, 994, 928,7816,3578,1260,7817,7818, # 6694 -7819,1948,2288, 741,2919,1626,4215,2729,2455, 867,1184, 362,3371,1392,7820,7821, # 6710 -4003,4216,1770,1736,3223,2920,4499,4500,1928,2698,1459,1158,7822,3050,3372,2877, # 6726 -1292,1929,2506,2842,3701,1985,1187,2071,2014,2607,4217,7823,2566,2507,2169,3702, # 6742 -2483,3299,7824,3703,4501,7825,7826, 666,1003,3005,1022,3579,4218,7827,4502,1813, # 6758 -2253, 574,3822,1603, 295,1535, 705,3823,4219, 283, 858, 417,7828,7829,3224,4503, # 6774 -4504,3051,1220,1889,1046,2276,2456,4004,1393,1599, 689,2567, 388,4220,7830,2484, # 6790 - 802,7831,2798,3824,2060,1405,2254,7832,4505,3825,2109,1052,1345,3225,1585,7833, # 6806 - 809,7834,7835,7836, 575,2730,3477, 956,1552,1469,1144,2323,7837,2324,1560,2457, # 6822 -3580,3226,4005, 616,2207,3155,2180,2289,7838,1832,7839,3478,4506,7840,1319,3704, # 6838 -3705,1211,3581,1023,3227,1293,2799,7841,7842,7843,3826, 607,2306,3827, 762,2878, # 6854 -1439,4221,1360,7844,1485,3052,7845,4507,1038,4222,1450,2061,2638,4223,1379,4508, # 6870 -2585,7846,7847,4224,1352,1414,2325,2921,1172,7848,7849,3828,3829,7850,1797,1451, # 6886 -7851,7852,7853,7854,2922,4006,4007,2485,2346, 411,4008,4009,3582,3300,3101,4509, # 6902 -1561,2664,1452,4010,1375,7855,7856, 47,2959, 316,7857,1406,1591,2923,3156,7858, # 6918 -1025,2141,3102,3157, 354,2731, 884,2224,4225,2407, 508,3706, 726,3583, 996,2428, # 6934 -3584, 729,7859, 392,2191,1453,4011,4510,3707,7860,7861,2458,3585,2608,1675,2800, # 6950 - 919,2347,2960,2348,1270,4511,4012, 73,7862,7863, 647,7864,3228,2843,2255,1550, # 6966 -1346,3006,7865,1332, 883,3479,7866,7867,7868,7869,3301,2765,7870,1212, 831,1347, # 6982 -4226,4512,2326,3830,1863,3053, 720,3831,4513,4514,3832,7871,4227,7872,7873,4515, # 6998 -7874,7875,1798,4516,3708,2609,4517,3586,1645,2371,7876,7877,2924, 669,2208,2665, # 7014 -2429,7878,2879,7879,7880,1028,3229,7881,4228,2408,7882,2256,1353,7883,7884,4518, # 7030 -3158, 518,7885,4013,7886,4229,1960,7887,2142,4230,7888,7889,3007,2349,2350,3833, # 7046 - 516,1833,1454,4014,2699,4231,4519,2225,2610,1971,1129,3587,7890,2766,7891,2961, # 7062 -1422, 577,1470,3008,1524,3373,7892,7893, 432,4232,3054,3480,7894,2586,1455,2508, # 7078 -2226,1972,1175,7895,1020,2732,4015,3481,4520,7896,2733,7897,1743,1361,3055,3482, # 7094 -2639,4016,4233,4521,2290, 895, 924,4234,2170, 331,2243,3056, 166,1627,3057,1098, # 7110 -7898,1232,2880,2227,3374,4522, 657, 403,1196,2372, 542,3709,3375,1600,4235,3483, # 7126 -7899,4523,2767,3230, 576, 530,1362,7900,4524,2533,2666,3710,4017,7901, 842,3834, # 7142 -7902,2801,2031,1014,4018, 213,2700,3376, 665, 621,4236,7903,3711,2925,2430,7904, # 7158 -2431,3302,3588,3377,7905,4237,2534,4238,4525,3589,1682,4239,3484,1380,7906, 724, # 7174 -2277, 600,1670,7907,1337,1233,4526,3103,2244,7908,1621,4527,7909, 651,4240,7910, # 7190 -1612,4241,2611,7911,2844,7912,2734,2307,3058,7913, 716,2459,3059, 174,1255,2701, # 7206 -4019,3590, 548,1320,1398, 728,4020,1574,7914,1890,1197,3060,4021,7915,3061,3062, # 7222 -3712,3591,3713, 747,7916, 635,4242,4528,7917,7918,7919,4243,7920,7921,4529,7922, # 7238 -3378,4530,2432, 451,7923,3714,2535,2072,4244,2735,4245,4022,7924,1764,4531,7925, # 7254 -4246, 350,7926,2278,2390,2486,7927,4247,4023,2245,1434,4024, 488,4532, 458,4248, # 7270 -4025,3715, 771,1330,2391,3835,2568,3159,2159,2409,1553,2667,3160,4249,7928,2487, # 7286 -2881,2612,1720,2702,4250,3379,4533,7929,2536,4251,7930,3231,4252,2768,7931,2015, # 7302 -2736,7932,1155,1017,3716,3836,7933,3303,2308, 201,1864,4253,1430,7934,4026,7935, # 7318 -7936,7937,7938,7939,4254,1604,7940, 414,1865, 371,2587,4534,4535,3485,2016,3104, # 7334 -4536,1708, 960,4255, 887, 389,2171,1536,1663,1721,7941,2228,4027,2351,2926,1580, # 7350 -7942,7943,7944,1744,7945,2537,4537,4538,7946,4539,7947,2073,7948,7949,3592,3380, # 7366 -2882,4256,7950,4257,2640,3381,2802, 673,2703,2460, 709,3486,4028,3593,4258,7951, # 7382 -1148, 502, 634,7952,7953,1204,4540,3594,1575,4541,2613,3717,7954,3718,3105, 948, # 7398 -3232, 121,1745,3837,1110,7955,4259,3063,2509,3009,4029,3719,1151,1771,3838,1488, # 7414 -4030,1986,7956,2433,3487,7957,7958,2093,7959,4260,3839,1213,1407,2803, 531,2737, # 7430 -2538,3233,1011,1537,7960,2769,4261,3106,1061,7961,3720,3721,1866,2883,7962,2017, # 7446 - 120,4262,4263,2062,3595,3234,2309,3840,2668,3382,1954,4542,7963,7964,3488,1047, # 7462 -2704,1266,7965,1368,4543,2845, 649,3383,3841,2539,2738,1102,2846,2669,7966,7967, # 7478 -1999,7968,1111,3596,2962,7969,2488,3842,3597,2804,1854,3384,3722,7970,7971,3385, # 7494 -2410,2884,3304,3235,3598,7972,2569,7973,3599,2805,4031,1460, 856,7974,3600,7975, # 7510 -2885,2963,7976,2886,3843,7977,4264, 632,2510, 875,3844,1697,3845,2291,7978,7979, # 7526 -4544,3010,1239, 580,4545,4265,7980, 914, 936,2074,1190,4032,1039,2123,7981,7982, # 7542 -7983,3386,1473,7984,1354,4266,3846,7985,2172,3064,4033, 915,3305,4267,4268,3306, # 7558 -1605,1834,7986,2739, 398,3601,4269,3847,4034, 328,1912,2847,4035,3848,1331,4270, # 7574 -3011, 937,4271,7987,3602,4036,4037,3387,2160,4546,3388, 524, 742, 538,3065,1012, # 7590 -7988,7989,3849,2461,7990, 658,1103, 225,3850,7991,7992,4547,7993,4548,7994,3236, # 7606 -1243,7995,4038, 963,2246,4549,7996,2705,3603,3161,7997,7998,2588,2327,7999,4550, # 7622 -8000,8001,8002,3489,3307, 957,3389,2540,2032,1930,2927,2462, 870,2018,3604,1746, # 7638 -2770,2771,2434,2463,8003,3851,8004,3723,3107,3724,3490,3390,3725,8005,1179,3066, # 7654 -8006,3162,2373,4272,3726,2541,3163,3108,2740,4039,8007,3391,1556,2542,2292, 977, # 7670 -2887,2033,4040,1205,3392,8008,1765,3393,3164,2124,1271,1689, 714,4551,3491,8009, # 7686 -2328,3852, 533,4273,3605,2181, 617,8010,2464,3308,3492,2310,8011,8012,3165,8013, # 7702 -8014,3853,1987, 618, 427,2641,3493,3394,8015,8016,1244,1690,8017,2806,4274,4552, # 7718 -8018,3494,8019,8020,2279,1576, 473,3606,4275,3395, 972,8021,3607,8022,3067,8023, # 7734 -8024,4553,4554,8025,3727,4041,4042,8026, 153,4555, 356,8027,1891,2888,4276,2143, # 7750 - 408, 803,2352,8028,3854,8029,4277,1646,2570,2511,4556,4557,3855,8030,3856,4278, # 7766 -8031,2411,3396, 752,8032,8033,1961,2964,8034, 746,3012,2465,8035,4279,3728, 698, # 7782 -4558,1892,4280,3608,2543,4559,3609,3857,8036,3166,3397,8037,1823,1302,4043,2706, # 7798 -3858,1973,4281,8038,4282,3167, 823,1303,1288,1236,2848,3495,4044,3398, 774,3859, # 7814 -8039,1581,4560,1304,2849,3860,4561,8040,2435,2161,1083,3237,4283,4045,4284, 344, # 7830 -1173, 288,2311, 454,1683,8041,8042,1461,4562,4046,2589,8043,8044,4563, 985, 894, # 7846 -8045,3399,3168,8046,1913,2928,3729,1988,8047,2110,1974,8048,4047,8049,2571,1194, # 7862 - 425,8050,4564,3169,1245,3730,4285,8051,8052,2850,8053, 636,4565,1855,3861, 760, # 7878 -1799,8054,4286,2209,1508,4566,4048,1893,1684,2293,8055,8056,8057,4287,4288,2210, # 7894 - 479,8058,8059, 832,8060,4049,2489,8061,2965,2490,3731, 990,3109, 627,1814,2642, # 7910 -4289,1582,4290,2125,2111,3496,4567,8062, 799,4291,3170,8063,4568,2112,1737,3013, # 7926 -1018, 543, 754,4292,3309,1676,4569,4570,4050,8064,1489,8065,3497,8066,2614,2889, # 7942 -4051,8067,8068,2966,8069,8070,8071,8072,3171,4571,4572,2182,1722,8073,3238,3239, # 7958 -1842,3610,1715, 481, 365,1975,1856,8074,8075,1962,2491,4573,8076,2126,3611,3240, # 7974 - 433,1894,2063,2075,8077, 602,2741,8078,8079,8080,8081,8082,3014,1628,3400,8083, # 7990 -3172,4574,4052,2890,4575,2512,8084,2544,2772,8085,8086,8087,3310,4576,2891,8088, # 8006 -4577,8089,2851,4578,4579,1221,2967,4053,2513,8090,8091,8092,1867,1989,8093,8094, # 8022 -8095,1895,8096,8097,4580,1896,4054, 318,8098,2094,4055,4293,8099,8100, 485,8101, # 8038 - 938,3862, 553,2670, 116,8102,3863,3612,8103,3498,2671,2773,3401,3311,2807,8104, # 8054 -3613,2929,4056,1747,2930,2968,8105,8106, 207,8107,8108,2672,4581,2514,8109,3015, # 8070 - 890,3614,3864,8110,1877,3732,3402,8111,2183,2353,3403,1652,8112,8113,8114, 941, # 8086 -2294, 208,3499,4057,2019, 330,4294,3865,2892,2492,3733,4295,8115,8116,8117,8118, # 8102 + 1, 1800, 1506, 255, 1431, 198, 9, 82, 6, 7310, 177, 202, 3615, 1256, 2808, 110, # 2742 + 3735, 33, 3241, 261, 76, 44, 2113, 16, 2931, 2184, 1176, 659, 3868, 26, 3404, 2643, # 2758 + 1198, 3869, 3313, 4060, 410, 2211, 302, 590, 361, 1963, 8, 204, 58, 4296, 7311, 1931, # 2774 + 63, 7312, 7313, 317, 1614, 75, 222, 159, 4061, 2412, 1480, 7314, 3500, 3068, 224, 2809, # 2790 + 3616, 3, 10, 3870, 1471, 29, 2774, 1135, 2852, 1939, 873, 130, 3242, 1123, 312, 7315, # 2806 + 4297, 2051, 507, 252, 682, 7316, 142, 1914, 124, 206, 2932, 34, 3501, 3173, 64, 604, # 2822 + 7317, 2494, 1976, 1977, 155, 1990, 645, 641, 1606, 7318, 3405, 337, 72, 406, 7319, 80, # 2838 + 630, 238, 3174, 1509, 263, 939, 1092, 2644, 756, 1440, 1094, 3406, 449, 69, 2969, 591, # 2854 + 179, 2095, 471, 115, 2034, 1843, 60, 50, 2970, 134, 806, 1868, 734, 2035, 3407, 180, # 2870 + 995, 1607, 156, 537, 2893, 688, 7320, 319, 1305, 779, 2144, 514, 2374, 298, 4298, 359, # 2886 + 2495, 90, 2707, 1338, 663, 11, 906, 1099, 2545, 20, 2436, 182, 532, 1716, 7321, 732, # 2902 + 1376, 4062, 1311, 1420, 3175, 25, 2312, 1056, 113, 399, 382, 1949, 242, 3408, 2467, 529, # 2918 + 3243, 475, 1447, 3617, 7322, 117, 21, 656, 810, 1297, 2295, 2329, 3502, 7323, 126, 4063, # 2934 + 706, 456, 150, 613, 4299, 71, 1118, 2036, 4064, 145, 3069, 85, 835, 486, 2114, 1246, # 2950 + 1426, 428, 727, 1285, 1015, 800, 106, 623, 303, 1281, 7324, 2127, 2354, 347, 3736, 221, # 2966 + 3503, 3110, 7325, 1955, 1153, 4065, 83, 296, 1199, 3070, 192, 624, 93, 7326, 822, 1897, # 2982 + 2810, 3111, 795, 2064, 991, 1554, 1542, 1592, 27, 43, 2853, 859, 139, 1456, 860, 4300, # 2998 + 437, 712, 3871, 164, 2392, 3112, 695, 211, 3017, 2096, 195, 3872, 1608, 3504, 3505, 3618, # 3014 + 3873, 234, 811, 2971, 2097, 3874, 2229, 1441, 3506, 1615, 2375, 668, 2076, 1638, 305, 228, # 3030 + 1664, 4301, 467, 415, 7327, 262, 2098, 1593, 239, 108, 300, 200, 1033, 512, 1247, 2077, # 3046 + 7328, 7329, 2173, 3176, 3619, 2673, 593, 845, 1062, 3244, 88, 1723, 2037, 3875, 1950, 212, # 3062 + 266, 152, 149, 468, 1898, 4066, 4302, 77, 187, 7330, 3018, 37, 5, 2972, 7331, 3876, # 3078 + 7332, 7333, 39, 2517, 4303, 2894, 3177, 2078, 55, 148, 74, 4304, 545, 483, 1474, 1029, # 3094 + 1665, 217, 1869, 1531, 3113, 1104, 2645, 4067, 24, 172, 3507, 900, 3877, 3508, 3509, 4305, # 3110 + 32, 1408, 2811, 1312, 329, 487, 2355, 2247, 2708, 784, 2674, 4, 3019, 3314, 1427, 1788, # 3126 + 188, 109, 499, 7334, 3620, 1717, 1789, 888, 1217, 3020, 4306, 7335, 3510, 7336, 3315, 1520, # 3142 + 3621, 3878, 196, 1034, 775, 7337, 7338, 929, 1815, 249, 439, 38, 7339, 1063, 7340, 794, # 3158 + 3879, 1435, 2296, 46, 178, 3245, 2065, 7341, 2376, 7342, 214, 1709, 4307, 804, 35, 707, # 3174 + 324, 3622, 1601, 2546, 140, 459, 4068, 7343, 7344, 1365, 839, 272, 978, 2257, 2572, 3409, # 3190 + 2128, 1363, 3623, 1423, 697, 100, 3071, 48, 70, 1231, 495, 3114, 2193, 7345, 1294, 7346, # 3206 + 2079, 462, 586, 1042, 3246, 853, 256, 988, 185, 2377, 3410, 1698, 434, 1084, 7347, 3411, # 3222 + 314, 2615, 2775, 4308, 2330, 2331, 569, 2280, 637, 1816, 2518, 757, 1162, 1878, 1616, 3412, # 3238 + 287, 1577, 2115, 768, 4309, 1671, 2854, 3511, 2519, 1321, 3737, 909, 2413, 7348, 4069, 933, # 3254 + 3738, 7349, 2052, 2356, 1222, 4310, 765, 2414, 1322, 786, 4311, 7350, 1919, 1462, 1677, 2895, # 3270 + 1699, 7351, 4312, 1424, 2437, 3115, 3624, 2590, 3316, 1774, 1940, 3413, 3880, 4070, 309, 1369, # 3286 + 1130, 2812, 364, 2230, 1653, 1299, 3881, 3512, 3882, 3883, 2646, 525, 1085, 3021, 902, 2000, # 3302 + 1475, 964, 4313, 421, 1844, 1415, 1057, 2281, 940, 1364, 3116, 376, 4314, 4315, 1381, 7, # 3318 + 2520, 983, 2378, 336, 1710, 2675, 1845, 321, 3414, 559, 1131, 3022, 2742, 1808, 1132, 1313, # 3334 + 265, 1481, 1857, 7352, 352, 1203, 2813, 3247, 167, 1089, 420, 2814, 776, 792, 1724, 3513, # 3350 + 4071, 2438, 3248, 7353, 4072, 7354, 446, 229, 333, 2743, 901, 3739, 1200, 1557, 4316, 2647, # 3366 + 1920, 395, 2744, 2676, 3740, 4073, 1835, 125, 916, 3178, 2616, 4317, 7355, 7356, 3741, 7357, # 3382 + 7358, 7359, 4318, 3117, 3625, 1133, 2547, 1757, 3415, 1510, 2313, 1409, 3514, 7360, 2145, 438, # 3398 + 2591, 2896, 2379, 3317, 1068, 958, 3023, 461, 311, 2855, 2677, 4074, 1915, 3179, 4075, 1978, # 3414 + 383, 750, 2745, 2617, 4076, 274, 539, 385, 1278, 1442, 7361, 1154, 1964, 384, 561, 210, # 3430 + 98, 1295, 2548, 3515, 7362, 1711, 2415, 1482, 3416, 3884, 2897, 1257, 129, 7363, 3742, 642, # 3446 + 523, 2776, 2777, 2648, 7364, 141, 2231, 1333, 68, 176, 441, 876, 907, 4077, 603, 2592, # 3462 + 710, 171, 3417, 404, 549, 18, 3118, 2393, 1410, 3626, 1666, 7365, 3516, 4319, 2898, 4320, # 3478 + 7366, 2973, 368, 7367, 146, 366, 99, 871, 3627, 1543, 748, 807, 1586, 1185, 22, 2258, # 3494 + 379, 3743, 3180, 7368, 3181, 505, 1941, 2618, 1991, 1382, 2314, 7369, 380, 2357, 218, 702, # 3510 + 1817, 1248, 3418, 3024, 3517, 3318, 3249, 7370, 2974, 3628, 930, 3250, 3744, 7371, 59, 7372, # 3526 + 585, 601, 4078, 497, 3419, 1112, 1314, 4321, 1801, 7373, 1223, 1472, 2174, 7374, 749, 1836, # 3542 + 690, 1899, 3745, 1772, 3885, 1476, 429, 1043, 1790, 2232, 2116, 917, 4079, 447, 1086, 1629, # 3558 + 7375, 556, 7376, 7377, 2020, 1654, 844, 1090, 105, 550, 966, 1758, 2815, 1008, 1782, 686, # 3574 + 1095, 7378, 2282, 793, 1602, 7379, 3518, 2593, 4322, 4080, 2933, 2297, 4323, 3746, 980, 2496, # 3590 + 544, 353, 527, 4324, 908, 2678, 2899, 7380, 381, 2619, 1942, 1348, 7381, 1341, 1252, 560, # 3606 + 3072, 7382, 3420, 2856, 7383, 2053, 973, 886, 2080, 143, 4325, 7384, 7385, 157, 3886, 496, # 3622 + 4081, 57, 840, 540, 2038, 4326, 4327, 3421, 2117, 1445, 970, 2259, 1748, 1965, 2081, 4082, # 3638 + 3119, 1234, 1775, 3251, 2816, 3629, 773, 1206, 2129, 1066, 2039, 1326, 3887, 1738, 1725, 4083, # 3654 + 279, 3120, 51, 1544, 2594, 423, 1578, 2130, 2066, 173, 4328, 1879, 7386, 7387, 1583, 264, # 3670 + 610, 3630, 4329, 2439, 280, 154, 7388, 7389, 7390, 1739, 338, 1282, 3073, 693, 2857, 1411, # 3686 + 1074, 3747, 2440, 7391, 4330, 7392, 7393, 1240, 952, 2394, 7394, 2900, 1538, 2679, 685, 1483, # 3702 + 4084, 2468, 1436, 953, 4085, 2054, 4331, 671, 2395, 79, 4086, 2441, 3252, 608, 567, 2680, # 3718 + 3422, 4087, 4088, 1691, 393, 1261, 1791, 2396, 7395, 4332, 7396, 7397, 7398, 7399, 1383, 1672, # 3734 + 3748, 3182, 1464, 522, 1119, 661, 1150, 216, 675, 4333, 3888, 1432, 3519, 609, 4334, 2681, # 3750 + 2397, 7400, 7401, 7402, 4089, 3025, 0, 7403, 2469, 315, 231, 2442, 301, 3319, 4335, 2380, # 3766 + 7404, 233, 4090, 3631, 1818, 4336, 4337, 7405, 96, 1776, 1315, 2082, 7406, 257, 7407, 1809, # 3782 + 3632, 2709, 1139, 1819, 4091, 2021, 1124, 2163, 2778, 1777, 2649, 7408, 3074, 363, 1655, 3183, # 3798 + 7409, 2975, 7410, 7411, 7412, 3889, 1567, 3890, 718, 103, 3184, 849, 1443, 341, 3320, 2934, # 3814 + 1484, 7413, 1712, 127, 67, 339, 4092, 2398, 679, 1412, 821, 7414, 7415, 834, 738, 351, # 3830 + 2976, 2146, 846, 235, 1497, 1880, 418, 1992, 3749, 2710, 186, 1100, 2147, 2746, 3520, 1545, # 3846 + 1355, 2935, 2858, 1377, 583, 3891, 4093, 2573, 2977, 7416, 1298, 3633, 1078, 2549, 3634, 2358, # 3862 + 78, 3750, 3751, 267, 1289, 2099, 2001, 1594, 4094, 348, 369, 1274, 2194, 2175, 1837, 4338, # 3878 + 1820, 2817, 3635, 2747, 2283, 2002, 4339, 2936, 2748, 144, 3321, 882, 4340, 3892, 2749, 3423, # 3894 + 4341, 2901, 7417, 4095, 1726, 320, 7418, 3893, 3026, 788, 2978, 7419, 2818, 1773, 1327, 2859, # 3910 + 3894, 2819, 7420, 1306, 4342, 2003, 1700, 3752, 3521, 2359, 2650, 787, 2022, 506, 824, 3636, # 3926 + 534, 323, 4343, 1044, 3322, 2023, 1900, 946, 3424, 7421, 1778, 1500, 1678, 7422, 1881, 4344, # 3942 + 165, 243, 4345, 3637, 2521, 123, 683, 4096, 764, 4346, 36, 3895, 1792, 589, 2902, 816, # 3958 + 626, 1667, 3027, 2233, 1639, 1555, 1622, 3753, 3896, 7423, 3897, 2860, 1370, 1228, 1932, 891, # 3974 + 2083, 2903, 304, 4097, 7424, 292, 2979, 2711, 3522, 691, 2100, 4098, 1115, 4347, 118, 662, # 3990 + 7425, 611, 1156, 854, 2381, 1316, 2861, 2, 386, 515, 2904, 7426, 7427, 3253, 868, 2234, # 4006 + 1486, 855, 2651, 785, 2212, 3028, 7428, 1040, 3185, 3523, 7429, 3121, 448, 7430, 1525, 7431, # 4022 + 2164, 4348, 7432, 3754, 7433, 4099, 2820, 3524, 3122, 503, 818, 3898, 3123, 1568, 814, 676, # 4038 + 1444, 306, 1749, 7434, 3755, 1416, 1030, 197, 1428, 805, 2821, 1501, 4349, 7435, 7436, 7437, # 4054 + 1993, 7438, 4350, 7439, 7440, 2195, 13, 2779, 3638, 2980, 3124, 1229, 1916, 7441, 3756, 2131, # 4070 + 7442, 4100, 4351, 2399, 3525, 7443, 2213, 1511, 1727, 1120, 7444, 7445, 646, 3757, 2443, 307, # 4086 + 7446, 7447, 1595, 3186, 7448, 7449, 7450, 3639, 1113, 1356, 3899, 1465, 2522, 2523, 7451, 519, # 4102 + 7452, 128, 2132, 92, 2284, 1979, 7453, 3900, 1512, 342, 3125, 2196, 7454, 2780, 2214, 1980, # 4118 + 3323, 7455, 290, 1656, 1317, 789, 827, 2360, 7456, 3758, 4352, 562, 581, 3901, 7457, 401, # 4134 + 4353, 2248, 94, 4354, 1399, 2781, 7458, 1463, 2024, 4355, 3187, 1943, 7459, 828, 1105, 4101, # 4150 + 1262, 1394, 7460, 4102, 605, 4356, 7461, 1783, 2862, 7462, 2822, 819, 2101, 578, 2197, 2937, # 4166 + 7463, 1502, 436, 3254, 4103, 3255, 2823, 3902, 2905, 3425, 3426, 7464, 2712, 2315, 7465, 7466, # 4182 + 2332, 2067, 23, 4357, 193, 826, 3759, 2102, 699, 1630, 4104, 3075, 390, 1793, 1064, 3526, # 4198 + 7467, 1579, 3076, 3077, 1400, 7468, 4105, 1838, 1640, 2863, 7469, 4358, 4359, 137, 4106, 598, # 4214 + 3078, 1966, 780, 104, 974, 2938, 7470, 278, 899, 253, 402, 572, 504, 493, 1339, 7471, # 4230 + 3903, 1275, 4360, 2574, 2550, 7472, 3640, 3029, 3079, 2249, 565, 1334, 2713, 863, 41, 7473, # 4246 + 7474, 4361, 7475, 1657, 2333, 19, 463, 2750, 4107, 606, 7476, 2981, 3256, 1087, 2084, 1323, # 4262 + 2652, 2982, 7477, 1631, 1623, 1750, 4108, 2682, 7478, 2864, 791, 2714, 2653, 2334, 232, 2416, # 4278 + 7479, 2983, 1498, 7480, 2654, 2620, 755, 1366, 3641, 3257, 3126, 2025, 1609, 119, 1917, 3427, # 4294 + 862, 1026, 4109, 7481, 3904, 3760, 4362, 3905, 4363, 2260, 1951, 2470, 7482, 1125, 817, 4110, # 4310 + 4111, 3906, 1513, 1766, 2040, 1487, 4112, 3030, 3258, 2824, 3761, 3127, 7483, 7484, 1507, 7485, # 4326 + 2683, 733, 40, 1632, 1106, 2865, 345, 4113, 841, 2524, 230, 4364, 2984, 1846, 3259, 3428, # 4342 + 7486, 1263, 986, 3429, 7487, 735, 879, 254, 1137, 857, 622, 1300, 1180, 1388, 1562, 3907, # 4358 + 3908, 2939, 967, 2751, 2655, 1349, 592, 2133, 1692, 3324, 2985, 1994, 4114, 1679, 3909, 1901, # 4374 + 2185, 7488, 739, 3642, 2715, 1296, 1290, 7489, 4115, 2198, 2199, 1921, 1563, 2595, 2551, 1870, # 4390 + 2752, 2986, 7490, 435, 7491, 343, 1108, 596, 17, 1751, 4365, 2235, 3430, 3643, 7492, 4366, # 4406 + 294, 3527, 2940, 1693, 477, 979, 281, 2041, 3528, 643, 2042, 3644, 2621, 2782, 2261, 1031, # 4422 + 2335, 2134, 2298, 3529, 4367, 367, 1249, 2552, 7493, 3530, 7494, 4368, 1283, 3325, 2004, 240, # 4438 + 1762, 3326, 4369, 4370, 836, 1069, 3128, 474, 7495, 2148, 2525, 268, 3531, 7496, 3188, 1521, # 4454 + 1284, 7497, 1658, 1546, 4116, 7498, 3532, 3533, 7499, 4117, 3327, 2684, 1685, 4118, 961, 1673, # 4470 + 2622, 190, 2005, 2200, 3762, 4371, 4372, 7500, 570, 2497, 3645, 1490, 7501, 4373, 2623, 3260, # 4486 + 1956, 4374, 584, 1514, 396, 1045, 1944, 7502, 4375, 1967, 2444, 7503, 7504, 4376, 3910, 619, # 4502 + 7505, 3129, 3261, 215, 2006, 2783, 2553, 3189, 4377, 3190, 4378, 763, 4119, 3763, 4379, 7506, # 4518 + 7507, 1957, 1767, 2941, 3328, 3646, 1174, 452, 1477, 4380, 3329, 3130, 7508, 2825, 1253, 2382, # 4534 + 2186, 1091, 2285, 4120, 492, 7509, 638, 1169, 1824, 2135, 1752, 3911, 648, 926, 1021, 1324, # 4550 + 4381, 520, 4382, 997, 847, 1007, 892, 4383, 3764, 2262, 1871, 3647, 7510, 2400, 1784, 4384, # 4566 + 1952, 2942, 3080, 3191, 1728, 4121, 2043, 3648, 4385, 2007, 1701, 3131, 1551, 30, 2263, 4122, # 4582 + 7511, 2026, 4386, 3534, 7512, 501, 7513, 4123, 594, 3431, 2165, 1821, 3535, 3432, 3536, 3192, # 4598 + 829, 2826, 4124, 7514, 1680, 3132, 1225, 4125, 7515, 3262, 4387, 4126, 3133, 2336, 7516, 4388, # 4614 + 4127, 7517, 3912, 3913, 7518, 1847, 2383, 2596, 3330, 7519, 4389, 374, 3914, 652, 4128, 4129, # 4630 + 375, 1140, 798, 7520, 7521, 7522, 2361, 4390, 2264, 546, 1659, 138, 3031, 2445, 4391, 7523, # 4646 + 2250, 612, 1848, 910, 796, 3765, 1740, 1371, 825, 3766, 3767, 7524, 2906, 2554, 7525, 692, # 4662 + 444, 3032, 2624, 801, 4392, 4130, 7526, 1491, 244, 1053, 3033, 4131, 4132, 340, 7527, 3915, # 4678 + 1041, 2987, 293, 1168, 87, 1357, 7528, 1539, 959, 7529, 2236, 721, 694, 4133, 3768, 219, # 4694 + 1478, 644, 1417, 3331, 2656, 1413, 1401, 1335, 1389, 3916, 7530, 7531, 2988, 2362, 3134, 1825, # 4710 + 730, 1515, 184, 2827, 66, 4393, 7532, 1660, 2943, 246, 3332, 378, 1457, 226, 3433, 975, # 4726 + 3917, 2944, 1264, 3537, 674, 696, 7533, 163, 7534, 1141, 2417, 2166, 713, 3538, 3333, 4394, # 4742 + 3918, 7535, 7536, 1186, 15, 7537, 1079, 1070, 7538, 1522, 3193, 3539, 276, 1050, 2716, 758, # 4758 + 1126, 653, 2945, 3263, 7539, 2337, 889, 3540, 3919, 3081, 2989, 903, 1250, 4395, 3920, 3434, # 4774 + 3541, 1342, 1681, 1718, 766, 3264, 286, 89, 2946, 3649, 7540, 1713, 7541, 2597, 3334, 2990, # 4790 + 7542, 2947, 2215, 3194, 2866, 7543, 4396, 2498, 2526, 181, 387, 1075, 3921, 731, 2187, 3335, # 4806 + 7544, 3265, 310, 313, 3435, 2299, 770, 4134, 54, 3034, 189, 4397, 3082, 3769, 3922, 7545, # 4822 + 1230, 1617, 1849, 355, 3542, 4135, 4398, 3336, 111, 4136, 3650, 1350, 3135, 3436, 3035, 4137, # 4838 + 2149, 3266, 3543, 7546, 2784, 3923, 3924, 2991, 722, 2008, 7547, 1071, 247, 1207, 2338, 2471, # 4854 + 1378, 4399, 2009, 864, 1437, 1214, 4400, 373, 3770, 1142, 2216, 667, 4401, 442, 2753, 2555, # 4870 + 3771, 3925, 1968, 4138, 3267, 1839, 837, 170, 1107, 934, 1336, 1882, 7548, 7549, 2118, 4139, # 4886 + 2828, 743, 1569, 7550, 4402, 4140, 582, 2384, 1418, 3437, 7551, 1802, 7552, 357, 1395, 1729, # 4902 + 3651, 3268, 2418, 1564, 2237, 7553, 3083, 3772, 1633, 4403, 1114, 2085, 4141, 1532, 7554, 482, # 4918 + 2446, 4404, 7555, 7556, 1492, 833, 1466, 7557, 2717, 3544, 1641, 2829, 7558, 1526, 1272, 3652, # 4934 + 4142, 1686, 1794, 416, 2556, 1902, 1953, 1803, 7559, 3773, 2785, 3774, 1159, 2316, 7560, 2867, # 4950 + 4405, 1610, 1584, 3036, 2419, 2754, 443, 3269, 1163, 3136, 7561, 7562, 3926, 7563, 4143, 2499, # 4966 + 3037, 4406, 3927, 3137, 2103, 1647, 3545, 2010, 1872, 4144, 7564, 4145, 431, 3438, 7565, 250, # 4982 + 97, 81, 4146, 7566, 1648, 1850, 1558, 160, 848, 7567, 866, 740, 1694, 7568, 2201, 2830, # 4998 + 3195, 4147, 4407, 3653, 1687, 950, 2472, 426, 469, 3196, 3654, 3655, 3928, 7569, 7570, 1188, # 5014 + 424, 1995, 861, 3546, 4148, 3775, 2202, 2685, 168, 1235, 3547, 4149, 7571, 2086, 1674, 4408, # 5030 + 3337, 3270, 220, 2557, 1009, 7572, 3776, 670, 2992, 332, 1208, 717, 7573, 7574, 3548, 2447, # 5046 + 3929, 3338, 7575, 513, 7576, 1209, 2868, 3339, 3138, 4409, 1080, 7577, 7578, 7579, 7580, 2527, # 5062 + 3656, 3549, 815, 1587, 3930, 3931, 7581, 3550, 3439, 3777, 1254, 4410, 1328, 3038, 1390, 3932, # 5078 + 1741, 3933, 3778, 3934, 7582, 236, 3779, 2448, 3271, 7583, 7584, 3657, 3780, 1273, 3781, 4411, # 5094 + 7585, 308, 7586, 4412, 245, 4413, 1851, 2473, 1307, 2575, 430, 715, 2136, 2449, 7587, 270, # 5110 + 199, 2869, 3935, 7588, 3551, 2718, 1753, 761, 1754, 725, 1661, 1840, 4414, 3440, 3658, 7589, # 5126 + 7590, 587, 14, 3272, 227, 2598, 326, 480, 2265, 943, 2755, 3552, 291, 650, 1883, 7591, # 5142 + 1702, 1226, 102, 1547, 62, 3441, 904, 4415, 3442, 1164, 4150, 7592, 7593, 1224, 1548, 2756, # 5158 + 391, 498, 1493, 7594, 1386, 1419, 7595, 2055, 1177, 4416, 813, 880, 1081, 2363, 566, 1145, # 5174 + 4417, 2286, 1001, 1035, 2558, 2599, 2238, 394, 1286, 7596, 7597, 2068, 7598, 86, 1494, 1730, # 5190 + 3936, 491, 1588, 745, 897, 2948, 843, 3340, 3937, 2757, 2870, 3273, 1768, 998, 2217, 2069, # 5206 + 397, 1826, 1195, 1969, 3659, 2993, 3341, 284, 7599, 3782, 2500, 2137, 2119, 1903, 7600, 3938, # 5222 + 2150, 3939, 4151, 1036, 3443, 1904, 114, 2559, 4152, 209, 1527, 7601, 7602, 2949, 2831, 2625, # 5238 + 2385, 2719, 3139, 812, 2560, 7603, 3274, 7604, 1559, 737, 1884, 3660, 1210, 885, 28, 2686, # 5254 + 3553, 3783, 7605, 4153, 1004, 1779, 4418, 7606, 346, 1981, 2218, 2687, 4419, 3784, 1742, 797, # 5270 + 1642, 3940, 1933, 1072, 1384, 2151, 896, 3941, 3275, 3661, 3197, 2871, 3554, 7607, 2561, 1958, # 5286 + 4420, 2450, 1785, 7608, 7609, 7610, 3942, 4154, 1005, 1308, 3662, 4155, 2720, 4421, 4422, 1528, # 5302 + 2600, 161, 1178, 4156, 1982, 987, 4423, 1101, 4157, 631, 3943, 1157, 3198, 2420, 1343, 1241, # 5318 + 1016, 2239, 2562, 372, 877, 2339, 2501, 1160, 555, 1934, 911, 3944, 7611, 466, 1170, 169, # 5334 + 1051, 2907, 2688, 3663, 2474, 2994, 1182, 2011, 2563, 1251, 2626, 7612, 992, 2340, 3444, 1540, # 5350 + 2721, 1201, 2070, 2401, 1996, 2475, 7613, 4424, 528, 1922, 2188, 1503, 1873, 1570, 2364, 3342, # 5366 + 3276, 7614, 557, 1073, 7615, 1827, 3445, 2087, 2266, 3140, 3039, 3084, 767, 3085, 2786, 4425, # 5382 + 1006, 4158, 4426, 2341, 1267, 2176, 3664, 3199, 778, 3945, 3200, 2722, 1597, 2657, 7616, 4427, # 5398 + 7617, 3446, 7618, 7619, 7620, 3277, 2689, 1433, 3278, 131, 95, 1504, 3946, 723, 4159, 3141, # 5414 + 1841, 3555, 2758, 2189, 3947, 2027, 2104, 3665, 7621, 2995, 3948, 1218, 7622, 3343, 3201, 3949, # 5430 + 4160, 2576, 248, 1634, 3785, 912, 7623, 2832, 3666, 3040, 3786, 654, 53, 7624, 2996, 7625, # 5446 + 1688, 4428, 777, 3447, 1032, 3950, 1425, 7626, 191, 820, 2120, 2833, 971, 4429, 931, 3202, # 5462 + 135, 664, 783, 3787, 1997, 772, 2908, 1935, 3951, 3788, 4430, 2909, 3203, 282, 2723, 640, # 5478 + 1372, 3448, 1127, 922, 325, 3344, 7627, 7628, 711, 2044, 7629, 7630, 3952, 2219, 2787, 1936, # 5494 + 3953, 3345, 2220, 2251, 3789, 2300, 7631, 4431, 3790, 1258, 3279, 3954, 3204, 2138, 2950, 3955, # 5510 + 3956, 7632, 2221, 258, 3205, 4432, 101, 1227, 7633, 3280, 1755, 7634, 1391, 3281, 7635, 2910, # 5526 + 2056, 893, 7636, 7637, 7638, 1402, 4161, 2342, 7639, 7640, 3206, 3556, 7641, 7642, 878, 1325, # 5542 + 1780, 2788, 4433, 259, 1385, 2577, 744, 1183, 2267, 4434, 7643, 3957, 2502, 7644, 684, 1024, # 5558 + 4162, 7645, 472, 3557, 3449, 1165, 3282, 3958, 3959, 322, 2152, 881, 455, 1695, 1152, 1340, # 5574 + 660, 554, 2153, 4435, 1058, 4436, 4163, 830, 1065, 3346, 3960, 4437, 1923, 7646, 1703, 1918, # 5590 + 7647, 932, 2268, 122, 7648, 4438, 947, 677, 7649, 3791, 2627, 297, 1905, 1924, 2269, 4439, # 5606 + 2317, 3283, 7650, 7651, 4164, 7652, 4165, 84, 4166, 112, 989, 7653, 547, 1059, 3961, 701, # 5622 + 3558, 1019, 7654, 4167, 7655, 3450, 942, 639, 457, 2301, 2451, 993, 2951, 407, 851, 494, # 5638 + 4440, 3347, 927, 7656, 1237, 7657, 2421, 3348, 573, 4168, 680, 921, 2911, 1279, 1874, 285, # 5654 + 790, 1448, 1983, 719, 2167, 7658, 7659, 4441, 3962, 3963, 1649, 7660, 1541, 563, 7661, 1077, # 5670 + 7662, 3349, 3041, 3451, 511, 2997, 3964, 3965, 3667, 3966, 1268, 2564, 3350, 3207, 4442, 4443, # 5686 + 7663, 535, 1048, 1276, 1189, 2912, 2028, 3142, 1438, 1373, 2834, 2952, 1134, 2012, 7664, 4169, # 5702 + 1238, 2578, 3086, 1259, 7665, 700, 7666, 2953, 3143, 3668, 4170, 7667, 4171, 1146, 1875, 1906, # 5718 + 4444, 2601, 3967, 781, 2422, 132, 1589, 203, 147, 273, 2789, 2402, 898, 1786, 2154, 3968, # 5734 + 3969, 7668, 3792, 2790, 7669, 7670, 4445, 4446, 7671, 3208, 7672, 1635, 3793, 965, 7673, 1804, # 5750 + 2690, 1516, 3559, 1121, 1082, 1329, 3284, 3970, 1449, 3794, 65, 1128, 2835, 2913, 2759, 1590, # 5766 + 3795, 7674, 7675, 12, 2658, 45, 976, 2579, 3144, 4447, 517, 2528, 1013, 1037, 3209, 7676, # 5782 + 3796, 2836, 7677, 3797, 7678, 3452, 7679, 2602, 614, 1998, 2318, 3798, 3087, 2724, 2628, 7680, # 5798 + 2580, 4172, 599, 1269, 7681, 1810, 3669, 7682, 2691, 3088, 759, 1060, 489, 1805, 3351, 3285, # 5814 + 1358, 7683, 7684, 2386, 1387, 1215, 2629, 2252, 490, 7685, 7686, 4173, 1759, 2387, 2343, 7687, # 5830 + 4448, 3799, 1907, 3971, 2630, 1806, 3210, 4449, 3453, 3286, 2760, 2344, 874, 7688, 7689, 3454, # 5846 + 3670, 1858, 91, 2914, 3671, 3042, 3800, 4450, 7690, 3145, 3972, 2659, 7691, 3455, 1202, 1403, # 5862 + 3801, 2954, 2529, 1517, 2503, 4451, 3456, 2504, 7692, 4452, 7693, 2692, 1885, 1495, 1731, 3973, # 5878 + 2365, 4453, 7694, 2029, 7695, 7696, 3974, 2693, 1216, 237, 2581, 4174, 2319, 3975, 3802, 4454, # 5894 + 4455, 2694, 3560, 3457, 445, 4456, 7697, 7698, 7699, 7700, 2761, 61, 3976, 3672, 1822, 3977, # 5910 + 7701, 687, 2045, 935, 925, 405, 2660, 703, 1096, 1859, 2725, 4457, 3978, 1876, 1367, 2695, # 5926 + 3352, 918, 2105, 1781, 2476, 334, 3287, 1611, 1093, 4458, 564, 3146, 3458, 3673, 3353, 945, # 5942 + 2631, 2057, 4459, 7702, 1925, 872, 4175, 7703, 3459, 2696, 3089, 349, 4176, 3674, 3979, 4460, # 5958 + 3803, 4177, 3675, 2155, 3980, 4461, 4462, 4178, 4463, 2403, 2046, 782, 3981, 400, 251, 4179, # 5974 + 1624, 7704, 7705, 277, 3676, 299, 1265, 476, 1191, 3804, 2121, 4180, 4181, 1109, 205, 7706, # 5990 + 2582, 1000, 2156, 3561, 1860, 7707, 7708, 7709, 4464, 7710, 4465, 2565, 107, 2477, 2157, 3982, # 6006 + 3460, 3147, 7711, 1533, 541, 1301, 158, 753, 4182, 2872, 3562, 7712, 1696, 370, 1088, 4183, # 6022 + 4466, 3563, 579, 327, 440, 162, 2240, 269, 1937, 1374, 3461, 968, 3043, 56, 1396, 3090, # 6038 + 2106, 3288, 3354, 7713, 1926, 2158, 4467, 2998, 7714, 3564, 7715, 7716, 3677, 4468, 2478, 7717, # 6054 + 2791, 7718, 1650, 4469, 7719, 2603, 7720, 7721, 3983, 2661, 3355, 1149, 3356, 3984, 3805, 3985, # 6070 + 7722, 1076, 49, 7723, 951, 3211, 3289, 3290, 450, 2837, 920, 7724, 1811, 2792, 2366, 4184, # 6086 + 1908, 1138, 2367, 3806, 3462, 7725, 3212, 4470, 1909, 1147, 1518, 2423, 4471, 3807, 7726, 4472, # 6102 + 2388, 2604, 260, 1795, 3213, 7727, 7728, 3808, 3291, 708, 7729, 3565, 1704, 7730, 3566, 1351, # 6118 + 1618, 3357, 2999, 1886, 944, 4185, 3358, 4186, 3044, 3359, 4187, 7731, 3678, 422, 413, 1714, # 6134 + 3292, 500, 2058, 2345, 4188, 2479, 7732, 1344, 1910, 954, 7733, 1668, 7734, 7735, 3986, 2404, # 6150 + 4189, 3567, 3809, 4190, 7736, 2302, 1318, 2505, 3091, 133, 3092, 2873, 4473, 629, 31, 2838, # 6166 + 2697, 3810, 4474, 850, 949, 4475, 3987, 2955, 1732, 2088, 4191, 1496, 1852, 7737, 3988, 620, # 6182 + 3214, 981, 1242, 3679, 3360, 1619, 3680, 1643, 3293, 2139, 2452, 1970, 1719, 3463, 2168, 7738, # 6198 + 3215, 7739, 7740, 3361, 1828, 7741, 1277, 4476, 1565, 2047, 7742, 1636, 3568, 3093, 7743, 869, # 6214 + 2839, 655, 3811, 3812, 3094, 3989, 3000, 3813, 1310, 3569, 4477, 7744, 7745, 7746, 1733, 558, # 6230 + 4478, 3681, 335, 1549, 3045, 1756, 4192, 3682, 1945, 3464, 1829, 1291, 1192, 470, 2726, 2107, # 6246 + 2793, 913, 1054, 3990, 7747, 1027, 7748, 3046, 3991, 4479, 982, 2662, 3362, 3148, 3465, 3216, # 6262 + 3217, 1946, 2794, 7749, 571, 4480, 7750, 1830, 7751, 3570, 2583, 1523, 2424, 7752, 2089, 984, # 6278 + 4481, 3683, 1959, 7753, 3684, 852, 923, 2795, 3466, 3685, 969, 1519, 999, 2048, 2320, 1705, # 6294 + 7754, 3095, 615, 1662, 151, 597, 3992, 2405, 2321, 1049, 275, 4482, 3686, 4193, 568, 3687, # 6310 + 3571, 2480, 4194, 3688, 7755, 2425, 2270, 409, 3218, 7756, 1566, 2874, 3467, 1002, 769, 2840, # 6326 + 194, 2090, 3149, 3689, 2222, 3294, 4195, 628, 1505, 7757, 7758, 1763, 2177, 3001, 3993, 521, # 6342 + 1161, 2584, 1787, 2203, 2406, 4483, 3994, 1625, 4196, 4197, 412, 42, 3096, 464, 7759, 2632, # 6358 + 4484, 3363, 1760, 1571, 2875, 3468, 2530, 1219, 2204, 3814, 2633, 2140, 2368, 4485, 4486, 3295, # 6374 + 1651, 3364, 3572, 7760, 7761, 3573, 2481, 3469, 7762, 3690, 7763, 7764, 2271, 2091, 460, 7765, # 6390 + 4487, 7766, 3002, 962, 588, 3574, 289, 3219, 2634, 1116, 52, 7767, 3047, 1796, 7768, 7769, # 6406 + 7770, 1467, 7771, 1598, 1143, 3691, 4198, 1984, 1734, 1067, 4488, 1280, 3365, 465, 4489, 1572, # 6422 + 510, 7772, 1927, 2241, 1812, 1644, 3575, 7773, 4490, 3692, 7774, 7775, 2663, 1573, 1534, 7776, # 6438 + 7777, 4199, 536, 1807, 1761, 3470, 3815, 3150, 2635, 7778, 7779, 7780, 4491, 3471, 2915, 1911, # 6454 + 2796, 7781, 3296, 1122, 377, 3220, 7782, 360, 7783, 7784, 4200, 1529, 551, 7785, 2059, 3693, # 6470 + 1769, 2426, 7786, 2916, 4201, 3297, 3097, 2322, 2108, 2030, 4492, 1404, 136, 1468, 1479, 672, # 6486 + 1171, 3221, 2303, 271, 3151, 7787, 2762, 7788, 2049, 678, 2727, 865, 1947, 4493, 7789, 2013, # 6502 + 3995, 2956, 7790, 2728, 2223, 1397, 3048, 3694, 4494, 4495, 1735, 2917, 3366, 3576, 7791, 3816, # 6518 + 509, 2841, 2453, 2876, 3817, 7792, 7793, 3152, 3153, 4496, 4202, 2531, 4497, 2304, 1166, 1010, # 6534 + 552, 681, 1887, 7794, 7795, 2957, 2958, 3996, 1287, 1596, 1861, 3154, 358, 453, 736, 175, # 6550 + 478, 1117, 905, 1167, 1097, 7796, 1853, 1530, 7797, 1706, 7798, 2178, 3472, 2287, 3695, 3473, # 6566 + 3577, 4203, 2092, 4204, 7799, 3367, 1193, 2482, 4205, 1458, 2190, 2205, 1862, 1888, 1421, 3298, # 6582 + 2918, 3049, 2179, 3474, 595, 2122, 7800, 3997, 7801, 7802, 4206, 1707, 2636, 223, 3696, 1359, # 6598 + 751, 3098, 183, 3475, 7803, 2797, 3003, 419, 2369, 633, 704, 3818, 2389, 241, 7804, 7805, # 6614 + 7806, 838, 3004, 3697, 2272, 2763, 2454, 3819, 1938, 2050, 3998, 1309, 3099, 2242, 1181, 7807, # 6630 + 1136, 2206, 3820, 2370, 1446, 4207, 2305, 4498, 7808, 7809, 4208, 1055, 2605, 484, 3698, 7810, # 6646 + 3999, 625, 4209, 2273, 3368, 1499, 4210, 4000, 7811, 4001, 4211, 3222, 2274, 2275, 3476, 7812, # 6662 + 7813, 2764, 808, 2606, 3699, 3369, 4002, 4212, 3100, 2532, 526, 3370, 3821, 4213, 955, 7814, # 6678 + 1620, 4214, 2637, 2427, 7815, 1429, 3700, 1669, 1831, 994, 928, 7816, 3578, 1260, 7817, 7818, # 6694 + 7819, 1948, 2288, 741, 2919, 1626, 4215, 2729, 2455, 867, 1184, 362, 3371, 1392, 7820, 7821, # 6710 + 4003, 4216, 1770, 1736, 3223, 2920, 4499, 4500, 1928, 2698, 1459, 1158, 7822, 3050, 3372, 2877, # 6726 + 1292, 1929, 2506, 2842, 3701, 1985, 1187, 2071, 2014, 2607, 4217, 7823, 2566, 2507, 2169, 3702, # 6742 + 2483, 3299, 7824, 3703, 4501, 7825, 7826, 666, 1003, 3005, 1022, 3579, 4218, 7827, 4502, 1813, # 6758 + 2253, 574, 3822, 1603, 295, 1535, 705, 3823, 4219, 283, 858, 417, 7828, 7829, 3224, 4503, # 6774 + 4504, 3051, 1220, 1889, 1046, 2276, 2456, 4004, 1393, 1599, 689, 2567, 388, 4220, 7830, 2484, # 6790 + 802, 7831, 2798, 3824, 2060, 1405, 2254, 7832, 4505, 3825, 2109, 1052, 1345, 3225, 1585, 7833, # 6806 + 809, 7834, 7835, 7836, 575, 2730, 3477, 956, 1552, 1469, 1144, 2323, 7837, 2324, 1560, 2457, # 6822 + 3580, 3226, 4005, 616, 2207, 3155, 2180, 2289, 7838, 1832, 7839, 3478, 4506, 7840, 1319, 3704, # 6838 + 3705, 1211, 3581, 1023, 3227, 1293, 2799, 7841, 7842, 7843, 3826, 607, 2306, 3827, 762, 2878, # 6854 + 1439, 4221, 1360, 7844, 1485, 3052, 7845, 4507, 1038, 4222, 1450, 2061, 2638, 4223, 1379, 4508, # 6870 + 2585, 7846, 7847, 4224, 1352, 1414, 2325, 2921, 1172, 7848, 7849, 3828, 3829, 7850, 1797, 1451, # 6886 + 7851, 7852, 7853, 7854, 2922, 4006, 4007, 2485, 2346, 411, 4008, 4009, 3582, 3300, 3101, 4509, # 6902 + 1561, 2664, 1452, 4010, 1375, 7855, 7856, 47, 2959, 316, 7857, 1406, 1591, 2923, 3156, 7858, # 6918 + 1025, 2141, 3102, 3157, 354, 2731, 884, 2224, 4225, 2407, 508, 3706, 726, 3583, 996, 2428, # 6934 + 3584, 729, 7859, 392, 2191, 1453, 4011, 4510, 3707, 7860, 7861, 2458, 3585, 2608, 1675, 2800, # 6950 + 919, 2347, 2960, 2348, 1270, 4511, 4012, 73, 7862, 7863, 647, 7864, 3228, 2843, 2255, 1550, # 6966 + 1346, 3006, 7865, 1332, 883, 3479, 7866, 7867, 7868, 7869, 3301, 2765, 7870, 1212, 831, 1347, # 6982 + 4226, 4512, 2326, 3830, 1863, 3053, 720, 3831, 4513, 4514, 3832, 7871, 4227, 7872, 7873, 4515, # 6998 + 7874, 7875, 1798, 4516, 3708, 2609, 4517, 3586, 1645, 2371, 7876, 7877, 2924, 669, 2208, 2665, # 7014 + 2429, 7878, 2879, 7879, 7880, 1028, 3229, 7881, 4228, 2408, 7882, 2256, 1353, 7883, 7884, 4518, # 7030 + 3158, 518, 7885, 4013, 7886, 4229, 1960, 7887, 2142, 4230, 7888, 7889, 3007, 2349, 2350, 3833, # 7046 + 516, 1833, 1454, 4014, 2699, 4231, 4519, 2225, 2610, 1971, 1129, 3587, 7890, 2766, 7891, 2961, # 7062 + 1422, 577, 1470, 3008, 1524, 3373, 7892, 7893, 432, 4232, 3054, 3480, 7894, 2586, 1455, 2508, # 7078 + 2226, 1972, 1175, 7895, 1020, 2732, 4015, 3481, 4520, 7896, 2733, 7897, 1743, 1361, 3055, 3482, # 7094 + 2639, 4016, 4233, 4521, 2290, 895, 924, 4234, 2170, 331, 2243, 3056, 166, 1627, 3057, 1098, # 7110 + 7898, 1232, 2880, 2227, 3374, 4522, 657, 403, 1196, 2372, 542, 3709, 3375, 1600, 4235, 3483, # 7126 + 7899, 4523, 2767, 3230, 576, 530, 1362, 7900, 4524, 2533, 2666, 3710, 4017, 7901, 842, 3834, # 7142 + 7902, 2801, 2031, 1014, 4018, 213, 2700, 3376, 665, 621, 4236, 7903, 3711, 2925, 2430, 7904, # 7158 + 2431, 3302, 3588, 3377, 7905, 4237, 2534, 4238, 4525, 3589, 1682, 4239, 3484, 1380, 7906, 724, # 7174 + 2277, 600, 1670, 7907, 1337, 1233, 4526, 3103, 2244, 7908, 1621, 4527, 7909, 651, 4240, 7910, # 7190 + 1612, 4241, 2611, 7911, 2844, 7912, 2734, 2307, 3058, 7913, 716, 2459, 3059, 174, 1255, 2701, # 7206 + 4019, 3590, 548, 1320, 1398, 728, 4020, 1574, 7914, 1890, 1197, 3060, 4021, 7915, 3061, 3062, # 7222 + 3712, 3591, 3713, 747, 7916, 635, 4242, 4528, 7917, 7918, 7919, 4243, 7920, 7921, 4529, 7922, # 7238 + 3378, 4530, 2432, 451, 7923, 3714, 2535, 2072, 4244, 2735, 4245, 4022, 7924, 1764, 4531, 7925, # 7254 + 4246, 350, 7926, 2278, 2390, 2486, 7927, 4247, 4023, 2245, 1434, 4024, 488, 4532, 458, 4248, # 7270 + 4025, 3715, 771, 1330, 2391, 3835, 2568, 3159, 2159, 2409, 1553, 2667, 3160, 4249, 7928, 2487, # 7286 + 2881, 2612, 1720, 2702, 4250, 3379, 4533, 7929, 2536, 4251, 7930, 3231, 4252, 2768, 7931, 2015, # 7302 + 2736, 7932, 1155, 1017, 3716, 3836, 7933, 3303, 2308, 201, 1864, 4253, 1430, 7934, 4026, 7935, # 7318 + 7936, 7937, 7938, 7939, 4254, 1604, 7940, 414, 1865, 371, 2587, 4534, 4535, 3485, 2016, 3104, # 7334 + 4536, 1708, 960, 4255, 887, 389, 2171, 1536, 1663, 1721, 7941, 2228, 4027, 2351, 2926, 1580, # 7350 + 7942, 7943, 7944, 1744, 7945, 2537, 4537, 4538, 7946, 4539, 7947, 2073, 7948, 7949, 3592, 3380, # 7366 + 2882, 4256, 7950, 4257, 2640, 3381, 2802, 673, 2703, 2460, 709, 3486, 4028, 3593, 4258, 7951, # 7382 + 1148, 502, 634, 7952, 7953, 1204, 4540, 3594, 1575, 4541, 2613, 3717, 7954, 3718, 3105, 948, # 7398 + 3232, 121, 1745, 3837, 1110, 7955, 4259, 3063, 2509, 3009, 4029, 3719, 1151, 1771, 3838, 1488, # 7414 + 4030, 1986, 7956, 2433, 3487, 7957, 7958, 2093, 7959, 4260, 3839, 1213, 1407, 2803, 531, 2737, # 7430 + 2538, 3233, 1011, 1537, 7960, 2769, 4261, 3106, 1061, 7961, 3720, 3721, 1866, 2883, 7962, 2017, # 7446 + 120, 4262, 4263, 2062, 3595, 3234, 2309, 3840, 2668, 3382, 1954, 4542, 7963, 7964, 3488, 1047, # 7462 + 2704, 1266, 7965, 1368, 4543, 2845, 649, 3383, 3841, 2539, 2738, 1102, 2846, 2669, 7966, 7967, # 7478 + 1999, 7968, 1111, 3596, 2962, 7969, 2488, 3842, 3597, 2804, 1854, 3384, 3722, 7970, 7971, 3385, # 7494 + 2410, 2884, 3304, 3235, 3598, 7972, 2569, 7973, 3599, 2805, 4031, 1460, 856, 7974, 3600, 7975, # 7510 + 2885, 2963, 7976, 2886, 3843, 7977, 4264, 632, 2510, 875, 3844, 1697, 3845, 2291, 7978, 7979, # 7526 + 4544, 3010, 1239, 580, 4545, 4265, 7980, 914, 936, 2074, 1190, 4032, 1039, 2123, 7981, 7982, # 7542 + 7983, 3386, 1473, 7984, 1354, 4266, 3846, 7985, 2172, 3064, 4033, 915, 3305, 4267, 4268, 3306, # 7558 + 1605, 1834, 7986, 2739, 398, 3601, 4269, 3847, 4034, 328, 1912, 2847, 4035, 3848, 1331, 4270, # 7574 + 3011, 937, 4271, 7987, 3602, 4036, 4037, 3387, 2160, 4546, 3388, 524, 742, 538, 3065, 1012, # 7590 + 7988, 7989, 3849, 2461, 7990, 658, 1103, 225, 3850, 7991, 7992, 4547, 7993, 4548, 7994, 3236, # 7606 + 1243, 7995, 4038, 963, 2246, 4549, 7996, 2705, 3603, 3161, 7997, 7998, 2588, 2327, 7999, 4550, # 7622 + 8000, 8001, 8002, 3489, 3307, 957, 3389, 2540, 2032, 1930, 2927, 2462, 870, 2018, 3604, 1746, # 7638 + 2770, 2771, 2434, 2463, 8003, 3851, 8004, 3723, 3107, 3724, 3490, 3390, 3725, 8005, 1179, 3066, # 7654 + 8006, 3162, 2373, 4272, 3726, 2541, 3163, 3108, 2740, 4039, 8007, 3391, 1556, 2542, 2292, 977, # 7670 + 2887, 2033, 4040, 1205, 3392, 8008, 1765, 3393, 3164, 2124, 1271, 1689, 714, 4551, 3491, 8009, # 7686 + 2328, 3852, 533, 4273, 3605, 2181, 617, 8010, 2464, 3308, 3492, 2310, 8011, 8012, 3165, 8013, # 7702 + 8014, 3853, 1987, 618, 427, 2641, 3493, 3394, 8015, 8016, 1244, 1690, 8017, 2806, 4274, 4552, # 7718 + 8018, 3494, 8019, 8020, 2279, 1576, 473, 3606, 4275, 3395, 972, 8021, 3607, 8022, 3067, 8023, # 7734 + 8024, 4553, 4554, 8025, 3727, 4041, 4042, 8026, 153, 4555, 356, 8027, 1891, 2888, 4276, 2143, # 7750 + 408, 803, 2352, 8028, 3854, 8029, 4277, 1646, 2570, 2511, 4556, 4557, 3855, 8030, 3856, 4278, # 7766 + 8031, 2411, 3396, 752, 8032, 8033, 1961, 2964, 8034, 746, 3012, 2465, 8035, 4279, 3728, 698, # 7782 + 4558, 1892, 4280, 3608, 2543, 4559, 3609, 3857, 8036, 3166, 3397, 8037, 1823, 1302, 4043, 2706, # 7798 + 3858, 1973, 4281, 8038, 4282, 3167, 823, 1303, 1288, 1236, 2848, 3495, 4044, 3398, 774, 3859, # 7814 + 8039, 1581, 4560, 1304, 2849, 3860, 4561, 8040, 2435, 2161, 1083, 3237, 4283, 4045, 4284, 344, # 7830 + 1173, 288, 2311, 454, 1683, 8041, 8042, 1461, 4562, 4046, 2589, 8043, 8044, 4563, 985, 894, # 7846 + 8045, 3399, 3168, 8046, 1913, 2928, 3729, 1988, 8047, 2110, 1974, 8048, 4047, 8049, 2571, 1194, # 7862 + 425, 8050, 4564, 3169, 1245, 3730, 4285, 8051, 8052, 2850, 8053, 636, 4565, 1855, 3861, 760, # 7878 + 1799, 8054, 4286, 2209, 1508, 4566, 4048, 1893, 1684, 2293, 8055, 8056, 8057, 4287, 4288, 2210, # 7894 + 479, 8058, 8059, 832, 8060, 4049, 2489, 8061, 2965, 2490, 3731, 990, 3109, 627, 1814, 2642, # 7910 + 4289, 1582, 4290, 2125, 2111, 3496, 4567, 8062, 799, 4291, 3170, 8063, 4568, 2112, 1737, 3013, # 7926 + 1018, 543, 754, 4292, 3309, 1676, 4569, 4570, 4050, 8064, 1489, 8065, 3497, 8066, 2614, 2889, # 7942 + 4051, 8067, 8068, 2966, 8069, 8070, 8071, 8072, 3171, 4571, 4572, 2182, 1722, 8073, 3238, 3239, # 7958 + 1842, 3610, 1715, 481, 365, 1975, 1856, 8074, 8075, 1962, 2491, 4573, 8076, 2126, 3611, 3240, # 7974 + 433, 1894, 2063, 2075, 8077, 602, 2741, 8078, 8079, 8080, 8081, 8082, 3014, 1628, 3400, 8083, # 7990 + 3172, 4574, 4052, 2890, 4575, 2512, 8084, 2544, 2772, 8085, 8086, 8087, 3310, 4576, 2891, 8088, # 8006 + 4577, 8089, 2851, 4578, 4579, 1221, 2967, 4053, 2513, 8090, 8091, 8092, 1867, 1989, 8093, 8094, # 8022 + 8095, 1895, 8096, 8097, 4580, 1896, 4054, 318, 8098, 2094, 4055, 4293, 8099, 8100, 485, 8101, # 8038 + 938, 3862, 553, 2670, 116, 8102, 3863, 3612, 8103, 3498, 2671, 2773, 3401, 3311, 2807, 8104, # 8054 + 3613, 2929, 4056, 1747, 2930, 2968, 8105, 8106, 207, 8107, 8108, 2672, 4581, 2514, 8109, 3015, # 8070 + 890, 3614, 3864, 8110, 1877, 3732, 3402, 8111, 2183, 2353, 3403, 1652, 8112, 8113, 8114, 941, # 8086 + 2294, 208, 3499, 4057, 2019, 330, 4294, 3865, 2892, 2492, 3733, 4295, 8115, 8116, 8117, 8118, # 8102 ) - +# fmt: on diff --git a/env/Lib/site-packages/pip/_vendor/chardet/euctwprober.py b/env/Lib/site-packages/pip/_vendor/chardet/euctwprober.py index 35669cc4..a37ab189 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/euctwprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/euctwprober.py @@ -25,22 +25,23 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### -from .mbcharsetprober import MultiByteCharSetProber -from .codingstatemachine import CodingStateMachine from .chardistribution import EUCTWDistributionAnalysis +from .codingstatemachine import CodingStateMachine +from .mbcharsetprober import MultiByteCharSetProber from .mbcssm import EUCTW_SM_MODEL + class EUCTWProber(MultiByteCharSetProber): - def __init__(self): - super(EUCTWProber, self).__init__() + def __init__(self) -> None: + super().__init__() self.coding_sm = CodingStateMachine(EUCTW_SM_MODEL) self.distribution_analyzer = EUCTWDistributionAnalysis() self.reset() @property - def charset_name(self): + def charset_name(self) -> str: return "EUC-TW" @property - def language(self): + def language(self) -> str: return "Taiwan" diff --git a/env/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py b/env/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py index 697837bd..b32bfc74 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py @@ -43,6 +43,7 @@ GB2312_TYPICAL_DISTRIBUTION_RATIO = 0.9 GB2312_TABLE_SIZE = 3760 +# fmt: off GB2312_CHAR_TO_FREQ_ORDER = ( 1671, 749,1443,2364,3924,3807,2330,3921,1704,3463,2691,1511,1515, 572,3191,2205, 2361, 224,2558, 479,1711, 963,3162, 440,4060,1905,2966,2947,3580,2647,3961,3842, @@ -280,4 +281,4 @@ GB2312_CHAR_TO_FREQ_ORDER = ( 381,1638,4592,1020, 516,3214, 458, 947,4575,1432, 211,1514,2926,1865,2142, 189, 852,1221,1400,1486, 882,2299,4036, 351, 28,1122, 700,6479,6480,6481,6482,6483, #last 512 ) - +# fmt: on diff --git a/env/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py b/env/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py index 8446d2dd..d423e731 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py @@ -25,22 +25,23 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### -from .mbcharsetprober import MultiByteCharSetProber -from .codingstatemachine import CodingStateMachine from .chardistribution import GB2312DistributionAnalysis +from .codingstatemachine import CodingStateMachine +from .mbcharsetprober import MultiByteCharSetProber from .mbcssm import GB2312_SM_MODEL + class GB2312Prober(MultiByteCharSetProber): - def __init__(self): - super(GB2312Prober, self).__init__() + def __init__(self) -> None: + super().__init__() self.coding_sm = CodingStateMachine(GB2312_SM_MODEL) self.distribution_analyzer = GB2312DistributionAnalysis() self.reset() @property - def charset_name(self): + def charset_name(self) -> str: return "GB2312" @property - def language(self): + def language(self) -> str: return "Chinese" diff --git a/env/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py b/env/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py index b0e1bf49..785d0057 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py @@ -25,8 +25,11 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from typing import Optional, Union + from .charsetprober import CharSetProber from .enums import ProbingState +from .sbcharsetprober import SingleByteCharSetProber # This prober doesn't actually recognize a language or a charset. # It is a helper prober for the use of the Hebrew model probers @@ -125,18 +128,20 @@ from .enums import ProbingState # model probers scores. The answer is returned in the form of the name of the # charset identified, either "windows-1255" or "ISO-8859-8". + class HebrewProber(CharSetProber): + SPACE = 0x20 # windows-1255 / ISO-8859-8 code points of interest - FINAL_KAF = 0xea - NORMAL_KAF = 0xeb - FINAL_MEM = 0xed - NORMAL_MEM = 0xee - FINAL_NUN = 0xef - NORMAL_NUN = 0xf0 - FINAL_PE = 0xf3 - NORMAL_PE = 0xf4 - FINAL_TSADI = 0xf5 - NORMAL_TSADI = 0xf6 + FINAL_KAF = 0xEA + NORMAL_KAF = 0xEB + FINAL_MEM = 0xED + NORMAL_MEM = 0xEE + FINAL_NUN = 0xEF + NORMAL_NUN = 0xF0 + FINAL_PE = 0xF3 + NORMAL_PE = 0xF4 + FINAL_TSADI = 0xF5 + NORMAL_TSADI = 0xF6 # Minimum Visual vs Logical final letter score difference. # If the difference is below this, don't rely solely on the final letter score @@ -151,35 +156,44 @@ class HebrewProber(CharSetProber): VISUAL_HEBREW_NAME = "ISO-8859-8" LOGICAL_HEBREW_NAME = "windows-1255" - def __init__(self): - super(HebrewProber, self).__init__() - self._final_char_logical_score = None - self._final_char_visual_score = None - self._prev = None - self._before_prev = None - self._logical_prober = None - self._visual_prober = None + def __init__(self) -> None: + super().__init__() + self._final_char_logical_score = 0 + self._final_char_visual_score = 0 + self._prev = self.SPACE + self._before_prev = self.SPACE + self._logical_prober: Optional[SingleByteCharSetProber] = None + self._visual_prober: Optional[SingleByteCharSetProber] = None self.reset() - def reset(self): + def reset(self) -> None: self._final_char_logical_score = 0 self._final_char_visual_score = 0 # The two last characters seen in the previous buffer, # mPrev and mBeforePrev are initialized to space in order to simulate # a word delimiter at the beginning of the data - self._prev = ' ' - self._before_prev = ' ' + self._prev = self.SPACE + self._before_prev = self.SPACE # These probers are owned by the group prober. - def set_model_probers(self, logicalProber, visualProber): - self._logical_prober = logicalProber - self._visual_prober = visualProber + def set_model_probers( + self, + logical_prober: SingleByteCharSetProber, + visual_prober: SingleByteCharSetProber, + ) -> None: + self._logical_prober = logical_prober + self._visual_prober = visual_prober - def is_final(self, c): - return c in [self.FINAL_KAF, self.FINAL_MEM, self.FINAL_NUN, - self.FINAL_PE, self.FINAL_TSADI] + def is_final(self, c: int) -> bool: + return c in [ + self.FINAL_KAF, + self.FINAL_MEM, + self.FINAL_NUN, + self.FINAL_PE, + self.FINAL_TSADI, + ] - def is_non_final(self, c): + def is_non_final(self, c: int) -> bool: # The normal Tsadi is not a good Non-Final letter due to words like # 'lechotet' (to chat) containing an apostrophe after the tsadi. This # apostrophe is converted to a space in FilterWithoutEnglishLetters @@ -190,10 +204,9 @@ class HebrewProber(CharSetProber): # for example legally end with a Non-Final Pe or Kaf. However, the # benefit of these letters as Non-Final letters outweighs the damage # since these words are quite rare. - return c in [self.NORMAL_KAF, self.NORMAL_MEM, - self.NORMAL_NUN, self.NORMAL_PE] + return c in [self.NORMAL_KAF, self.NORMAL_MEM, self.NORMAL_NUN, self.NORMAL_PE] - def feed(self, byte_str): + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: # Final letter analysis for logical-visual decision. # Look for evidence that the received buffer is either logical Hebrew # or visual Hebrew. @@ -227,9 +240,9 @@ class HebrewProber(CharSetProber): byte_str = self.filter_high_byte_only(byte_str) for cur in byte_str: - if cur == ' ': + if cur == self.SPACE: # We stand on a space - a word just ended - if self._before_prev != ' ': + if self._before_prev != self.SPACE: # next-to-last char was not a space so self._prev is not a # 1 letter word if self.is_final(self._prev): @@ -241,8 +254,11 @@ class HebrewProber(CharSetProber): self._final_char_visual_score += 1 else: # Not standing on a space - if ((self._before_prev == ' ') and - (self.is_final(self._prev)) and (cur != ' ')): + if ( + (self._before_prev == self.SPACE) + and (self.is_final(self._prev)) + and (cur != self.SPACE) + ): # case (3) [-2:space][-1:final letter][cur:not space] self._final_char_visual_score += 1 self._before_prev = self._prev @@ -253,7 +269,10 @@ class HebrewProber(CharSetProber): return ProbingState.DETECTING @property - def charset_name(self): + def charset_name(self) -> str: + assert self._logical_prober is not None + assert self._visual_prober is not None + # Make the decision: is it Logical or Visual? # If the final letter score distance is dominant enough, rely on it. finalsub = self._final_char_logical_score - self._final_char_visual_score @@ -263,8 +282,9 @@ class HebrewProber(CharSetProber): return self.VISUAL_HEBREW_NAME # It's not dominant enough, try to rely on the model scores instead. - modelsub = (self._logical_prober.get_confidence() - - self._visual_prober.get_confidence()) + modelsub = ( + self._logical_prober.get_confidence() - self._visual_prober.get_confidence() + ) if modelsub > self.MIN_MODEL_DISTANCE: return self.LOGICAL_HEBREW_NAME if modelsub < -self.MIN_MODEL_DISTANCE: @@ -280,13 +300,17 @@ class HebrewProber(CharSetProber): return self.LOGICAL_HEBREW_NAME @property - def language(self): - return 'Hebrew' + def language(self) -> str: + return "Hebrew" @property - def state(self): + def state(self) -> ProbingState: + assert self._logical_prober is not None + assert self._visual_prober is not None + # Remain active as long as any of the model probers are active. - if (self._logical_prober.state == ProbingState.NOT_ME) and \ - (self._visual_prober.state == ProbingState.NOT_ME): + if (self._logical_prober.state == ProbingState.NOT_ME) and ( + self._visual_prober.state == ProbingState.NOT_ME + ): return ProbingState.NOT_ME return ProbingState.DETECTING diff --git a/env/Lib/site-packages/pip/_vendor/chardet/jisfreq.py b/env/Lib/site-packages/pip/_vendor/chardet/jisfreq.py index 83fc082b..3293576e 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/jisfreq.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/jisfreq.py @@ -46,6 +46,7 @@ JIS_TYPICAL_DISTRIBUTION_RATIO = 3.0 # Char to FreqOrder table , JIS_TABLE_SIZE = 4368 +# fmt: off JIS_CHAR_TO_FREQ_ORDER = ( 40, 1, 6, 182, 152, 180, 295,2127, 285, 381,3295,4304,3068,4606,3165,3510, # 16 3511,1822,2785,4607,1193,2226,5070,4608, 171,2996,1247, 18, 179,5071, 856,1661, # 32 @@ -321,5 +322,4 @@ JIS_CHAR_TO_FREQ_ORDER = ( 1444,1698,2385,2251,3729,1365,2281,2235,1717,6188, 864,3841,2515, 444, 527,2767, # 4352 2922,3625, 544, 461,6189, 566, 209,2437,3398,2098,1065,2068,3331,3626,3257,2137, # 4368 #last 512 ) - - +# fmt: on diff --git a/env/Lib/site-packages/pip/_vendor/chardet/jpcntx.py b/env/Lib/site-packages/pip/_vendor/chardet/jpcntx.py index 20044e4b..2f53bdda 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/jpcntx.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/jpcntx.py @@ -25,110 +25,114 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from typing import List, Tuple, Union # This is hiragana 2-char sequence table, the number in each cell represents its frequency category -jp2CharContext = ( -(0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1), -(2,4,0,4,0,3,0,4,0,3,4,4,4,2,4,3,3,4,3,2,3,3,4,2,3,3,3,2,4,1,4,3,3,1,5,4,3,4,3,4,3,5,3,0,3,5,4,2,0,3,1,0,3,3,0,3,3,0,1,1,0,4,3,0,3,3,0,4,0,2,0,3,5,5,5,5,4,0,4,1,0,3,4), -(0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2), -(0,4,0,5,0,5,0,4,0,4,5,4,4,3,5,3,5,1,5,3,4,3,4,4,3,4,3,3,4,3,5,4,4,3,5,5,3,5,5,5,3,5,5,3,4,5,5,3,1,3,2,0,3,4,0,4,2,0,4,2,1,5,3,2,3,5,0,4,0,2,0,5,4,4,5,4,5,0,4,0,0,4,4), -(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0), -(0,3,0,4,0,3,0,3,0,4,5,4,3,3,3,3,4,3,5,4,4,3,5,4,4,3,4,3,4,4,4,4,5,3,4,4,3,4,5,5,4,5,5,1,4,5,4,3,0,3,3,1,3,3,0,4,4,0,3,3,1,5,3,3,3,5,0,4,0,3,0,4,4,3,4,3,3,0,4,1,1,3,4), -(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0), -(0,4,0,3,0,3,0,4,0,3,4,4,3,2,2,1,2,1,3,1,3,3,3,3,3,4,3,1,3,3,5,3,3,0,4,3,0,5,4,3,3,5,4,4,3,4,4,5,0,1,2,0,1,2,0,2,2,0,1,0,0,5,2,2,1,4,0,3,0,1,0,4,4,3,5,4,3,0,2,1,0,4,3), -(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0), -(0,3,0,5,0,4,0,2,1,4,4,2,4,1,4,2,4,2,4,3,3,3,4,3,3,3,3,1,4,2,3,3,3,1,4,4,1,1,1,4,3,3,2,0,2,4,3,2,0,3,3,0,3,1,1,0,0,0,3,3,0,4,2,2,3,4,0,4,0,3,0,4,4,5,3,4,4,0,3,0,0,1,4), -(1,4,0,4,0,4,0,4,0,3,5,4,4,3,4,3,5,4,3,3,4,3,5,4,4,4,4,3,4,2,4,3,3,1,5,4,3,2,4,5,4,5,5,4,4,5,4,4,0,3,2,2,3,3,0,4,3,1,3,2,1,4,3,3,4,5,0,3,0,2,0,4,5,5,4,5,4,0,4,0,0,5,4), -(0,5,0,5,0,4,0,3,0,4,4,3,4,3,3,3,4,0,4,4,4,3,4,3,4,3,3,1,4,2,4,3,4,0,5,4,1,4,5,4,4,5,3,2,4,3,4,3,2,4,1,3,3,3,2,3,2,0,4,3,3,4,3,3,3,4,0,4,0,3,0,4,5,4,4,4,3,0,4,1,0,1,3), -(0,3,1,4,0,3,0,2,0,3,4,4,3,1,4,2,3,3,4,3,4,3,4,3,4,4,3,2,3,1,5,4,4,1,4,4,3,5,4,4,3,5,5,4,3,4,4,3,1,2,3,1,2,2,0,3,2,0,3,1,0,5,3,3,3,4,3,3,3,3,4,4,4,4,5,4,2,0,3,3,2,4,3), -(0,2,0,3,0,1,0,1,0,0,3,2,0,0,2,0,1,0,2,1,3,3,3,1,2,3,1,0,1,0,4,2,1,1,3,3,0,4,3,3,1,4,3,3,0,3,3,2,0,0,0,0,1,0,0,2,0,0,0,0,0,4,1,0,2,3,2,2,2,1,3,3,3,4,4,3,2,0,3,1,0,3,3), -(0,4,0,4,0,3,0,3,0,4,4,4,3,3,3,3,3,3,4,3,4,2,4,3,4,3,3,2,4,3,4,5,4,1,4,5,3,5,4,5,3,5,4,0,3,5,5,3,1,3,3,2,2,3,0,3,4,1,3,3,2,4,3,3,3,4,0,4,0,3,0,4,5,4,4,5,3,0,4,1,0,3,4), -(0,2,0,3,0,3,0,0,0,2,2,2,1,0,1,0,0,0,3,0,3,0,3,0,1,3,1,0,3,1,3,3,3,1,3,3,3,0,1,3,1,3,4,0,0,3,1,1,0,3,2,0,0,0,0,1,3,0,1,0,0,3,3,2,0,3,0,0,0,0,0,3,4,3,4,3,3,0,3,0,0,2,3), -(2,3,0,3,0,2,0,1,0,3,3,4,3,1,3,1,1,1,3,1,4,3,4,3,3,3,0,0,3,1,5,4,3,1,4,3,2,5,5,4,4,4,4,3,3,4,4,4,0,2,1,1,3,2,0,1,2,0,0,1,0,4,1,3,3,3,0,3,0,1,0,4,4,4,5,5,3,0,2,0,0,4,4), -(0,2,0,1,0,3,1,3,0,2,3,3,3,0,3,1,0,0,3,0,3,2,3,1,3,2,1,1,0,0,4,2,1,0,2,3,1,4,3,2,0,4,4,3,1,3,1,3,0,1,0,0,1,0,0,0,1,0,0,0,0,4,1,1,1,2,0,3,0,0,0,3,4,2,4,3,2,0,1,0,0,3,3), -(0,1,0,4,0,5,0,4,0,2,4,4,2,3,3,2,3,3,5,3,3,3,4,3,4,2,3,0,4,3,3,3,4,1,4,3,2,1,5,5,3,4,5,1,3,5,4,2,0,3,3,0,1,3,0,4,2,0,1,3,1,4,3,3,3,3,0,3,0,1,0,3,4,4,4,5,5,0,3,0,1,4,5), -(0,2,0,3,0,3,0,0,0,2,3,1,3,0,4,0,1,1,3,0,3,4,3,2,3,1,0,3,3,2,3,1,3,0,2,3,0,2,1,4,1,2,2,0,0,3,3,0,0,2,0,0,0,1,0,0,0,0,2,2,0,3,2,1,3,3,0,2,0,2,0,0,3,3,1,2,4,0,3,0,2,2,3), -(2,4,0,5,0,4,0,4,0,2,4,4,4,3,4,3,3,3,1,2,4,3,4,3,4,4,5,0,3,3,3,3,2,0,4,3,1,4,3,4,1,4,4,3,3,4,4,3,1,2,3,0,4,2,0,4,1,0,3,3,0,4,3,3,3,4,0,4,0,2,0,3,5,3,4,5,2,0,3,0,0,4,5), -(0,3,0,4,0,1,0,1,0,1,3,2,2,1,3,0,3,0,2,0,2,0,3,0,2,0,0,0,1,0,1,1,0,0,3,1,0,0,0,4,0,3,1,0,2,1,3,0,0,0,0,0,0,3,0,0,0,0,0,0,0,4,2,2,3,1,0,3,0,0,0,1,4,4,4,3,0,0,4,0,0,1,4), -(1,4,1,5,0,3,0,3,0,4,5,4,4,3,5,3,3,4,4,3,4,1,3,3,3,3,2,1,4,1,5,4,3,1,4,4,3,5,4,4,3,5,4,3,3,4,4,4,0,3,3,1,2,3,0,3,1,0,3,3,0,5,4,4,4,4,4,4,3,3,5,4,4,3,3,5,4,0,3,2,0,4,4), -(0,2,0,3,0,1,0,0,0,1,3,3,3,2,4,1,3,0,3,1,3,0,2,2,1,1,0,0,2,0,4,3,1,0,4,3,0,4,4,4,1,4,3,1,1,3,3,1,0,2,0,0,1,3,0,0,0,0,2,0,0,4,3,2,4,3,5,4,3,3,3,4,3,3,4,3,3,0,2,1,0,3,3), -(0,2,0,4,0,3,0,2,0,2,5,5,3,4,4,4,4,1,4,3,3,0,4,3,4,3,1,3,3,2,4,3,0,3,4,3,0,3,4,4,2,4,4,0,4,5,3,3,2,2,1,1,1,2,0,1,5,0,3,3,2,4,3,3,3,4,0,3,0,2,0,4,4,3,5,5,0,0,3,0,2,3,3), -(0,3,0,4,0,3,0,1,0,3,4,3,3,1,3,3,3,0,3,1,3,0,4,3,3,1,1,0,3,0,3,3,0,0,4,4,0,1,5,4,3,3,5,0,3,3,4,3,0,2,0,1,1,1,0,1,3,0,1,2,1,3,3,2,3,3,0,3,0,1,0,1,3,3,4,4,1,0,1,2,2,1,3), -(0,1,0,4,0,4,0,3,0,1,3,3,3,2,3,1,1,0,3,0,3,3,4,3,2,4,2,0,1,0,4,3,2,0,4,3,0,5,3,3,2,4,4,4,3,3,3,4,0,1,3,0,0,1,0,0,1,0,0,0,0,4,2,3,3,3,0,3,0,0,0,4,4,4,5,3,2,0,3,3,0,3,5), -(0,2,0,3,0,0,0,3,0,1,3,0,2,0,0,0,1,0,3,1,1,3,3,0,0,3,0,0,3,0,2,3,1,0,3,1,0,3,3,2,0,4,2,2,0,2,0,0,0,4,0,0,0,0,0,0,0,0,0,0,0,2,1,2,0,1,0,1,0,0,0,1,3,1,2,0,0,0,1,0,0,1,4), -(0,3,0,3,0,5,0,1,0,2,4,3,1,3,3,2,1,1,5,2,1,0,5,1,2,0,0,0,3,3,2,2,3,2,4,3,0,0,3,3,1,3,3,0,2,5,3,4,0,3,3,0,1,2,0,2,2,0,3,2,0,2,2,3,3,3,0,2,0,1,0,3,4,4,2,5,4,0,3,0,0,3,5), -(0,3,0,3,0,3,0,1,0,3,3,3,3,0,3,0,2,0,2,1,1,0,2,0,1,0,0,0,2,1,0,0,1,0,3,2,0,0,3,3,1,2,3,1,0,3,3,0,0,1,0,0,0,0,0,2,0,0,0,0,0,2,3,1,2,3,0,3,0,1,0,3,2,1,0,4,3,0,1,1,0,3,3), -(0,4,0,5,0,3,0,3,0,4,5,5,4,3,5,3,4,3,5,3,3,2,5,3,4,4,4,3,4,3,4,5,5,3,4,4,3,4,4,5,4,4,4,3,4,5,5,4,2,3,4,2,3,4,0,3,3,1,4,3,2,4,3,3,5,5,0,3,0,3,0,5,5,5,5,4,4,0,4,0,1,4,4), -(0,4,0,4,0,3,0,3,0,3,5,4,4,2,3,2,5,1,3,2,5,1,4,2,3,2,3,3,4,3,3,3,3,2,5,4,1,3,3,5,3,4,4,0,4,4,3,1,1,3,1,0,2,3,0,2,3,0,3,0,0,4,3,1,3,4,0,3,0,2,0,4,4,4,3,4,5,0,4,0,0,3,4), -(0,3,0,3,0,3,1,2,0,3,4,4,3,3,3,0,2,2,4,3,3,1,3,3,3,1,1,0,3,1,4,3,2,3,4,4,2,4,4,4,3,4,4,3,2,4,4,3,1,3,3,1,3,3,0,4,1,0,2,2,1,4,3,2,3,3,5,4,3,3,5,4,4,3,3,0,4,0,3,2,2,4,4), -(0,2,0,1,0,0,0,0,0,1,2,1,3,0,0,0,0,0,2,0,1,2,1,0,0,1,0,0,0,0,3,0,0,1,0,1,1,3,1,0,0,0,1,1,0,1,1,0,0,0,0,0,2,0,0,0,0,0,0,0,0,1,1,2,2,0,3,4,0,0,0,1,1,0,0,1,0,0,0,0,0,1,1), -(0,1,0,0,0,1,0,0,0,0,4,0,4,1,4,0,3,0,4,0,3,0,4,0,3,0,3,0,4,1,5,1,4,0,0,3,0,5,0,5,2,0,1,0,0,0,2,1,4,0,1,3,0,0,3,0,0,3,1,1,4,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0), -(1,4,0,5,0,3,0,2,0,3,5,4,4,3,4,3,5,3,4,3,3,0,4,3,3,3,3,3,3,2,4,4,3,1,3,4,4,5,4,4,3,4,4,1,3,5,4,3,3,3,1,2,2,3,3,1,3,1,3,3,3,5,3,3,4,5,0,3,0,3,0,3,4,3,4,4,3,0,3,0,2,4,3), -(0,1,0,4,0,0,0,0,0,1,4,0,4,1,4,2,4,0,3,0,1,0,1,0,0,0,0,0,2,0,3,1,1,1,0,3,0,0,0,1,2,1,0,0,1,1,1,1,0,1,0,0,0,1,0,0,3,0,0,0,0,3,2,0,2,2,0,1,0,0,0,2,3,2,3,3,0,0,0,0,2,1,0), -(0,5,1,5,0,3,0,3,0,5,4,4,5,1,5,3,3,0,4,3,4,3,5,3,4,3,3,2,4,3,4,3,3,0,3,3,1,4,4,3,4,4,4,3,4,5,5,3,2,3,1,1,3,3,1,3,1,1,3,3,2,4,5,3,3,5,0,4,0,3,0,4,4,3,5,3,3,0,3,4,0,4,3), -(0,5,0,5,0,3,0,2,0,4,4,3,5,2,4,3,3,3,4,4,4,3,5,3,5,3,3,1,4,0,4,3,3,0,3,3,0,4,4,4,4,5,4,3,3,5,5,3,2,3,1,2,3,2,0,1,0,0,3,2,2,4,4,3,1,5,0,4,0,3,0,4,3,1,3,2,1,0,3,3,0,3,3), -(0,4,0,5,0,5,0,4,0,4,5,5,5,3,4,3,3,2,5,4,4,3,5,3,5,3,4,0,4,3,4,4,3,2,4,4,3,4,5,4,4,5,5,0,3,5,5,4,1,3,3,2,3,3,1,3,1,0,4,3,1,4,4,3,4,5,0,4,0,2,0,4,3,4,4,3,3,0,4,0,0,5,5), -(0,4,0,4,0,5,0,1,1,3,3,4,4,3,4,1,3,0,5,1,3,0,3,1,3,1,1,0,3,0,3,3,4,0,4,3,0,4,4,4,3,4,4,0,3,5,4,1,0,3,0,0,2,3,0,3,1,0,3,1,0,3,2,1,3,5,0,3,0,1,0,3,2,3,3,4,4,0,2,2,0,4,4), -(2,4,0,5,0,4,0,3,0,4,5,5,4,3,5,3,5,3,5,3,5,2,5,3,4,3,3,4,3,4,5,3,2,1,5,4,3,2,3,4,5,3,4,1,2,5,4,3,0,3,3,0,3,2,0,2,3,0,4,1,0,3,4,3,3,5,0,3,0,1,0,4,5,5,5,4,3,0,4,2,0,3,5), -(0,5,0,4,0,4,0,2,0,5,4,3,4,3,4,3,3,3,4,3,4,2,5,3,5,3,4,1,4,3,4,4,4,0,3,5,0,4,4,4,4,5,3,1,3,4,5,3,3,3,3,3,3,3,0,2,2,0,3,3,2,4,3,3,3,5,3,4,1,3,3,5,3,2,0,0,0,0,4,3,1,3,3), -(0,1,0,3,0,3,0,1,0,1,3,3,3,2,3,3,3,0,3,0,0,0,3,1,3,0,0,0,2,2,2,3,0,0,3,2,0,1,2,4,1,3,3,0,0,3,3,3,0,1,0,0,2,1,0,0,3,0,3,1,0,3,0,0,1,3,0,2,0,1,0,3,3,1,3,3,0,0,1,1,0,3,3), -(0,2,0,3,0,2,1,4,0,2,2,3,1,1,3,1,1,0,2,0,3,1,2,3,1,3,0,0,1,0,4,3,2,3,3,3,1,4,2,3,3,3,3,1,0,3,1,4,0,1,1,0,1,2,0,1,1,0,1,1,0,3,1,3,2,2,0,1,0,0,0,2,3,3,3,1,0,0,0,0,0,2,3), -(0,5,0,4,0,5,0,2,0,4,5,5,3,3,4,3,3,1,5,4,4,2,4,4,4,3,4,2,4,3,5,5,4,3,3,4,3,3,5,5,4,5,5,1,3,4,5,3,1,4,3,1,3,3,0,3,3,1,4,3,1,4,5,3,3,5,0,4,0,3,0,5,3,3,1,4,3,0,4,0,1,5,3), -(0,5,0,5,0,4,0,2,0,4,4,3,4,3,3,3,3,3,5,4,4,4,4,4,4,5,3,3,5,2,4,4,4,3,4,4,3,3,4,4,5,5,3,3,4,3,4,3,3,4,3,3,3,3,1,2,2,1,4,3,3,5,4,4,3,4,0,4,0,3,0,4,4,4,4,4,1,0,4,2,0,2,4), -(0,4,0,4,0,3,0,1,0,3,5,2,3,0,3,0,2,1,4,2,3,3,4,1,4,3,3,2,4,1,3,3,3,0,3,3,0,0,3,3,3,5,3,3,3,3,3,2,0,2,0,0,2,0,0,2,0,0,1,0,0,3,1,2,2,3,0,3,0,2,0,4,4,3,3,4,1,0,3,0,0,2,4), -(0,0,0,4,0,0,0,0,0,0,1,0,1,0,2,0,0,0,0,0,1,0,2,0,1,0,0,0,0,0,3,1,3,0,3,2,0,0,0,1,0,3,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,4,0,2,0,0,0,0,0,0,2), -(0,2,1,3,0,2,0,2,0,3,3,3,3,1,3,1,3,3,3,3,3,3,4,2,2,1,2,1,4,0,4,3,1,3,3,3,2,4,3,5,4,3,3,3,3,3,3,3,0,1,3,0,2,0,0,1,0,0,1,0,0,4,2,0,2,3,0,3,3,0,3,3,4,2,3,1,4,0,1,2,0,2,3), -(0,3,0,3,0,1,0,3,0,2,3,3,3,0,3,1,2,0,3,3,2,3,3,2,3,2,3,1,3,0,4,3,2,0,3,3,1,4,3,3,2,3,4,3,1,3,3,1,1,0,1,1,0,1,0,1,0,1,0,0,0,4,1,1,0,3,0,3,1,0,2,3,3,3,3,3,1,0,0,2,0,3,3), -(0,0,0,0,0,0,0,0,0,0,3,0,2,0,3,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,3,0,3,0,3,1,0,1,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,2,0,2,3,0,0,0,0,0,0,0,0,3), -(0,2,0,3,1,3,0,3,0,2,3,3,3,1,3,1,3,1,3,1,3,3,3,1,3,0,2,3,1,1,4,3,3,2,3,3,1,2,2,4,1,3,3,0,1,4,2,3,0,1,3,0,3,0,0,1,3,0,2,0,0,3,3,2,1,3,0,3,0,2,0,3,4,4,4,3,1,0,3,0,0,3,3), -(0,2,0,1,0,2,0,0,0,1,3,2,2,1,3,0,1,1,3,0,3,2,3,1,2,0,2,0,1,1,3,3,3,0,3,3,1,1,2,3,2,3,3,1,2,3,2,0,0,1,0,0,0,0,0,0,3,0,1,0,0,2,1,2,1,3,0,3,0,0,0,3,4,4,4,3,2,0,2,0,0,2,4), -(0,0,0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,2,2,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,1,3,1,0,0,0,0,0,0,0,3), -(0,3,0,3,0,2,0,3,0,3,3,3,2,3,2,2,2,0,3,1,3,3,3,2,3,3,0,0,3,0,3,2,2,0,2,3,1,4,3,4,3,3,2,3,1,5,4,4,0,3,1,2,1,3,0,3,1,1,2,0,2,3,1,3,1,3,0,3,0,1,0,3,3,4,4,2,1,0,2,1,0,2,4), -(0,1,0,3,0,1,0,2,0,1,4,2,5,1,4,0,2,0,2,1,3,1,4,0,2,1,0,0,2,1,4,1,1,0,3,3,0,5,1,3,2,3,3,1,0,3,2,3,0,1,0,0,0,0,0,0,1,0,0,0,0,4,0,1,0,3,0,2,0,1,0,3,3,3,4,3,3,0,0,0,0,2,3), -(0,0,0,1,0,0,0,0,0,0,2,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,1,0,0,1,0,0,0,0,0,3), -(0,1,0,3,0,4,0,3,0,2,4,3,1,0,3,2,2,1,3,1,2,2,3,1,1,1,2,1,3,0,1,2,0,1,3,2,1,3,0,5,5,1,0,0,1,3,2,1,0,3,0,0,1,0,0,0,0,0,3,4,0,1,1,1,3,2,0,2,0,1,0,2,3,3,1,2,3,0,1,0,1,0,4), -(0,0,0,1,0,3,0,3,0,2,2,1,0,0,4,0,3,0,3,1,3,0,3,0,3,0,1,0,3,0,3,1,3,0,3,3,0,0,1,2,1,1,1,0,1,2,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,2,2,1,2,0,0,2,0,0,0,0,2,3,3,3,3,0,0,0,0,1,4), -(0,0,0,3,0,3,0,0,0,0,3,1,1,0,3,0,1,0,2,0,1,0,0,0,0,0,0,0,1,0,3,0,2,0,2,3,0,0,2,2,3,1,2,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,2,0,0,0,0,2,3), -(2,4,0,5,0,5,0,4,0,3,4,3,3,3,4,3,3,3,4,3,4,4,5,4,5,5,5,2,3,0,5,5,4,1,5,4,3,1,5,4,3,4,4,3,3,4,3,3,0,3,2,0,2,3,0,3,0,0,3,3,0,5,3,2,3,3,0,3,0,3,0,3,4,5,4,5,3,0,4,3,0,3,4), -(0,3,0,3,0,3,0,3,0,3,3,4,3,2,3,2,3,0,4,3,3,3,3,3,3,3,3,0,3,2,4,3,3,1,3,4,3,4,4,4,3,4,4,3,2,4,4,1,0,2,0,0,1,1,0,2,0,0,3,1,0,5,3,2,1,3,0,3,0,1,2,4,3,2,4,3,3,0,3,2,0,4,4), -(0,3,0,3,0,1,0,0,0,1,4,3,3,2,3,1,3,1,4,2,3,2,4,2,3,4,3,0,2,2,3,3,3,0,3,3,3,0,3,4,1,3,3,0,3,4,3,3,0,1,1,0,1,0,0,0,4,0,3,0,0,3,1,2,1,3,0,4,0,1,0,4,3,3,4,3,3,0,2,0,0,3,3), -(0,3,0,4,0,1,0,3,0,3,4,3,3,0,3,3,3,1,3,1,3,3,4,3,3,3,0,0,3,1,5,3,3,1,3,3,2,5,4,3,3,4,5,3,2,5,3,4,0,1,0,0,0,0,0,2,0,0,1,1,0,4,2,2,1,3,0,3,0,2,0,4,4,3,5,3,2,0,1,1,0,3,4), -(0,5,0,4,0,5,0,2,0,4,4,3,3,2,3,3,3,1,4,3,4,1,5,3,4,3,4,0,4,2,4,3,4,1,5,4,0,4,4,4,4,5,4,1,3,5,4,2,1,4,1,1,3,2,0,3,1,0,3,2,1,4,3,3,3,4,0,4,0,3,0,4,4,4,3,3,3,0,4,2,0,3,4), -(1,4,0,4,0,3,0,1,0,3,3,3,1,1,3,3,2,2,3,3,1,0,3,2,2,1,2,0,3,1,2,1,2,0,3,2,0,2,2,3,3,4,3,0,3,3,1,2,0,1,1,3,1,2,0,0,3,0,1,1,0,3,2,2,3,3,0,3,0,0,0,2,3,3,4,3,3,0,1,0,0,1,4), -(0,4,0,4,0,4,0,0,0,3,4,4,3,1,4,2,3,2,3,3,3,1,4,3,4,0,3,0,4,2,3,3,2,2,5,4,2,1,3,4,3,4,3,1,3,3,4,2,0,2,1,0,3,3,0,0,2,0,3,1,0,4,4,3,4,3,0,4,0,1,0,2,4,4,4,4,4,0,3,2,0,3,3), -(0,0,0,1,0,4,0,0,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,3,2,0,0,1,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,2), -(0,2,0,3,0,4,0,4,0,1,3,3,3,0,4,0,2,1,2,1,1,1,2,0,3,1,1,0,1,0,3,1,0,0,3,3,2,0,1,1,0,0,0,0,0,1,0,2,0,2,2,0,3,1,0,0,1,0,1,1,0,1,2,0,3,0,0,0,0,1,0,0,3,3,4,3,1,0,1,0,3,0,2), -(0,0,0,3,0,5,0,0,0,0,1,0,2,0,3,1,0,1,3,0,0,0,2,0,0,0,1,0,0,0,1,1,0,0,4,0,0,0,2,3,0,1,4,1,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,1,0,0,0,0,0,0,0,2,0,0,3,0,0,0,0,0,3), -(0,2,0,5,0,5,0,1,0,2,4,3,3,2,5,1,3,2,3,3,3,0,4,1,2,0,3,0,4,0,2,2,1,1,5,3,0,0,1,4,2,3,2,0,3,3,3,2,0,2,4,1,1,2,0,1,1,0,3,1,0,1,3,1,2,3,0,2,0,0,0,1,3,5,4,4,4,0,3,0,0,1,3), -(0,4,0,5,0,4,0,4,0,4,5,4,3,3,4,3,3,3,4,3,4,4,5,3,4,5,4,2,4,2,3,4,3,1,4,4,1,3,5,4,4,5,5,4,4,5,5,5,2,3,3,1,4,3,1,3,3,0,3,3,1,4,3,4,4,4,0,3,0,4,0,3,3,4,4,5,0,0,4,3,0,4,5), -(0,4,0,4,0,3,0,3,0,3,4,4,4,3,3,2,4,3,4,3,4,3,5,3,4,3,2,1,4,2,4,4,3,1,3,4,2,4,5,5,3,4,5,4,1,5,4,3,0,3,2,2,3,2,1,3,1,0,3,3,3,5,3,3,3,5,4,4,2,3,3,4,3,3,3,2,1,0,3,2,1,4,3), -(0,4,0,5,0,4,0,3,0,3,5,5,3,2,4,3,4,0,5,4,4,1,4,4,4,3,3,3,4,3,5,5,2,3,3,4,1,2,5,5,3,5,5,2,3,5,5,4,0,3,2,0,3,3,1,1,5,1,4,1,0,4,3,2,3,5,0,4,0,3,0,5,4,3,4,3,0,0,4,1,0,4,4), -(1,3,0,4,0,2,0,2,0,2,5,5,3,3,3,3,3,0,4,2,3,4,4,4,3,4,0,0,3,4,5,4,3,3,3,3,2,5,5,4,5,5,5,4,3,5,5,5,1,3,1,0,1,0,0,3,2,0,4,2,0,5,2,3,2,4,1,3,0,3,0,4,5,4,5,4,3,0,4,2,0,5,4), -(0,3,0,4,0,5,0,3,0,3,4,4,3,2,3,2,3,3,3,3,3,2,4,3,3,2,2,0,3,3,3,3,3,1,3,3,3,0,4,4,3,4,4,1,1,4,4,2,0,3,1,0,1,1,0,4,1,0,2,3,1,3,3,1,3,4,0,3,0,1,0,3,1,3,0,0,1,0,2,0,0,4,4), -(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0), -(0,3,0,3,0,2,0,3,0,1,5,4,3,3,3,1,4,2,1,2,3,4,4,2,4,4,5,0,3,1,4,3,4,0,4,3,3,3,2,3,2,5,3,4,3,2,2,3,0,0,3,0,2,1,0,1,2,0,0,0,0,2,1,1,3,1,0,2,0,4,0,3,4,4,4,5,2,0,2,0,0,1,3), -(0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,1,1,0,0,1,1,0,0,0,4,2,1,1,0,1,0,3,2,0,0,3,1,1,1,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,1,0,0,0,2,0,0,0,1,4,0,4,2,1,0,0,0,0,0,1), -(0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,0,1,0,1,0,0,0,0,3,1,0,0,0,2,0,2,1,0,0,1,2,1,0,1,1,0,0,3,0,0,0,0,0,0,0,0,0,0,0,1,3,1,0,0,0,0,0,1,0,0,2,1,0,0,0,0,0,0,0,0,2), -(0,4,0,4,0,4,0,3,0,4,4,3,4,2,4,3,2,0,4,4,4,3,5,3,5,3,3,2,4,2,4,3,4,3,1,4,0,2,3,4,4,4,3,3,3,4,4,4,3,4,1,3,4,3,2,1,2,1,3,3,3,4,4,3,3,5,0,4,0,3,0,4,3,3,3,2,1,0,3,0,0,3,3), -(0,4,0,3,0,3,0,3,0,3,5,5,3,3,3,3,4,3,4,3,3,3,4,4,4,3,3,3,3,4,3,5,3,3,1,3,2,4,5,5,5,5,4,3,4,5,5,3,2,2,3,3,3,3,2,3,3,1,2,3,2,4,3,3,3,4,0,4,0,2,0,4,3,2,2,1,2,0,3,0,0,4,1), +# fmt: off +jp2_char_context = ( + (0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1), + (2, 4, 0, 4, 0, 3, 0, 4, 0, 3, 4, 4, 4, 2, 4, 3, 3, 4, 3, 2, 3, 3, 4, 2, 3, 3, 3, 2, 4, 1, 4, 3, 3, 1, 5, 4, 3, 4, 3, 4, 3, 5, 3, 0, 3, 5, 4, 2, 0, 3, 1, 0, 3, 3, 0, 3, 3, 0, 1, 1, 0, 4, 3, 0, 3, 3, 0, 4, 0, 2, 0, 3, 5, 5, 5, 5, 4, 0, 4, 1, 0, 3, 4), + (0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2), + (0, 4, 0, 5, 0, 5, 0, 4, 0, 4, 5, 4, 4, 3, 5, 3, 5, 1, 5, 3, 4, 3, 4, 4, 3, 4, 3, 3, 4, 3, 5, 4, 4, 3, 5, 5, 3, 5, 5, 5, 3, 5, 5, 3, 4, 5, 5, 3, 1, 3, 2, 0, 3, 4, 0, 4, 2, 0, 4, 2, 1, 5, 3, 2, 3, 5, 0, 4, 0, 2, 0, 5, 4, 4, 5, 4, 5, 0, 4, 0, 0, 4, 4), + (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0), + (0, 3, 0, 4, 0, 3, 0, 3, 0, 4, 5, 4, 3, 3, 3, 3, 4, 3, 5, 4, 4, 3, 5, 4, 4, 3, 4, 3, 4, 4, 4, 4, 5, 3, 4, 4, 3, 4, 5, 5, 4, 5, 5, 1, 4, 5, 4, 3, 0, 3, 3, 1, 3, 3, 0, 4, 4, 0, 3, 3, 1, 5, 3, 3, 3, 5, 0, 4, 0, 3, 0, 4, 4, 3, 4, 3, 3, 0, 4, 1, 1, 3, 4), + (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0), + (0, 4, 0, 3, 0, 3, 0, 4, 0, 3, 4, 4, 3, 2, 2, 1, 2, 1, 3, 1, 3, 3, 3, 3, 3, 4, 3, 1, 3, 3, 5, 3, 3, 0, 4, 3, 0, 5, 4, 3, 3, 5, 4, 4, 3, 4, 4, 5, 0, 1, 2, 0, 1, 2, 0, 2, 2, 0, 1, 0, 0, 5, 2, 2, 1, 4, 0, 3, 0, 1, 0, 4, 4, 3, 5, 4, 3, 0, 2, 1, 0, 4, 3), + (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0), + (0, 3, 0, 5, 0, 4, 0, 2, 1, 4, 4, 2, 4, 1, 4, 2, 4, 2, 4, 3, 3, 3, 4, 3, 3, 3, 3, 1, 4, 2, 3, 3, 3, 1, 4, 4, 1, 1, 1, 4, 3, 3, 2, 0, 2, 4, 3, 2, 0, 3, 3, 0, 3, 1, 1, 0, 0, 0, 3, 3, 0, 4, 2, 2, 3, 4, 0, 4, 0, 3, 0, 4, 4, 5, 3, 4, 4, 0, 3, 0, 0, 1, 4), + (1, 4, 0, 4, 0, 4, 0, 4, 0, 3, 5, 4, 4, 3, 4, 3, 5, 4, 3, 3, 4, 3, 5, 4, 4, 4, 4, 3, 4, 2, 4, 3, 3, 1, 5, 4, 3, 2, 4, 5, 4, 5, 5, 4, 4, 5, 4, 4, 0, 3, 2, 2, 3, 3, 0, 4, 3, 1, 3, 2, 1, 4, 3, 3, 4, 5, 0, 3, 0, 2, 0, 4, 5, 5, 4, 5, 4, 0, 4, 0, 0, 5, 4), + (0, 5, 0, 5, 0, 4, 0, 3, 0, 4, 4, 3, 4, 3, 3, 3, 4, 0, 4, 4, 4, 3, 4, 3, 4, 3, 3, 1, 4, 2, 4, 3, 4, 0, 5, 4, 1, 4, 5, 4, 4, 5, 3, 2, 4, 3, 4, 3, 2, 4, 1, 3, 3, 3, 2, 3, 2, 0, 4, 3, 3, 4, 3, 3, 3, 4, 0, 4, 0, 3, 0, 4, 5, 4, 4, 4, 3, 0, 4, 1, 0, 1, 3), + (0, 3, 1, 4, 0, 3, 0, 2, 0, 3, 4, 4, 3, 1, 4, 2, 3, 3, 4, 3, 4, 3, 4, 3, 4, 4, 3, 2, 3, 1, 5, 4, 4, 1, 4, 4, 3, 5, 4, 4, 3, 5, 5, 4, 3, 4, 4, 3, 1, 2, 3, 1, 2, 2, 0, 3, 2, 0, 3, 1, 0, 5, 3, 3, 3, 4, 3, 3, 3, 3, 4, 4, 4, 4, 5, 4, 2, 0, 3, 3, 2, 4, 3), + (0, 2, 0, 3, 0, 1, 0, 1, 0, 0, 3, 2, 0, 0, 2, 0, 1, 0, 2, 1, 3, 3, 3, 1, 2, 3, 1, 0, 1, 0, 4, 2, 1, 1, 3, 3, 0, 4, 3, 3, 1, 4, 3, 3, 0, 3, 3, 2, 0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 0, 0, 0, 4, 1, 0, 2, 3, 2, 2, 2, 1, 3, 3, 3, 4, 4, 3, 2, 0, 3, 1, 0, 3, 3), + (0, 4, 0, 4, 0, 3, 0, 3, 0, 4, 4, 4, 3, 3, 3, 3, 3, 3, 4, 3, 4, 2, 4, 3, 4, 3, 3, 2, 4, 3, 4, 5, 4, 1, 4, 5, 3, 5, 4, 5, 3, 5, 4, 0, 3, 5, 5, 3, 1, 3, 3, 2, 2, 3, 0, 3, 4, 1, 3, 3, 2, 4, 3, 3, 3, 4, 0, 4, 0, 3, 0, 4, 5, 4, 4, 5, 3, 0, 4, 1, 0, 3, 4), + (0, 2, 0, 3, 0, 3, 0, 0, 0, 2, 2, 2, 1, 0, 1, 0, 0, 0, 3, 0, 3, 0, 3, 0, 1, 3, 1, 0, 3, 1, 3, 3, 3, 1, 3, 3, 3, 0, 1, 3, 1, 3, 4, 0, 0, 3, 1, 1, 0, 3, 2, 0, 0, 0, 0, 1, 3, 0, 1, 0, 0, 3, 3, 2, 0, 3, 0, 0, 0, 0, 0, 3, 4, 3, 4, 3, 3, 0, 3, 0, 0, 2, 3), + (2, 3, 0, 3, 0, 2, 0, 1, 0, 3, 3, 4, 3, 1, 3, 1, 1, 1, 3, 1, 4, 3, 4, 3, 3, 3, 0, 0, 3, 1, 5, 4, 3, 1, 4, 3, 2, 5, 5, 4, 4, 4, 4, 3, 3, 4, 4, 4, 0, 2, 1, 1, 3, 2, 0, 1, 2, 0, 0, 1, 0, 4, 1, 3, 3, 3, 0, 3, 0, 1, 0, 4, 4, 4, 5, 5, 3, 0, 2, 0, 0, 4, 4), + (0, 2, 0, 1, 0, 3, 1, 3, 0, 2, 3, 3, 3, 0, 3, 1, 0, 0, 3, 0, 3, 2, 3, 1, 3, 2, 1, 1, 0, 0, 4, 2, 1, 0, 2, 3, 1, 4, 3, 2, 0, 4, 4, 3, 1, 3, 1, 3, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 4, 1, 1, 1, 2, 0, 3, 0, 0, 0, 3, 4, 2, 4, 3, 2, 0, 1, 0, 0, 3, 3), + (0, 1, 0, 4, 0, 5, 0, 4, 0, 2, 4, 4, 2, 3, 3, 2, 3, 3, 5, 3, 3, 3, 4, 3, 4, 2, 3, 0, 4, 3, 3, 3, 4, 1, 4, 3, 2, 1, 5, 5, 3, 4, 5, 1, 3, 5, 4, 2, 0, 3, 3, 0, 1, 3, 0, 4, 2, 0, 1, 3, 1, 4, 3, 3, 3, 3, 0, 3, 0, 1, 0, 3, 4, 4, 4, 5, 5, 0, 3, 0, 1, 4, 5), + (0, 2, 0, 3, 0, 3, 0, 0, 0, 2, 3, 1, 3, 0, 4, 0, 1, 1, 3, 0, 3, 4, 3, 2, 3, 1, 0, 3, 3, 2, 3, 1, 3, 0, 2, 3, 0, 2, 1, 4, 1, 2, 2, 0, 0, 3, 3, 0, 0, 2, 0, 0, 0, 1, 0, 0, 0, 0, 2, 2, 0, 3, 2, 1, 3, 3, 0, 2, 0, 2, 0, 0, 3, 3, 1, 2, 4, 0, 3, 0, 2, 2, 3), + (2, 4, 0, 5, 0, 4, 0, 4, 0, 2, 4, 4, 4, 3, 4, 3, 3, 3, 1, 2, 4, 3, 4, 3, 4, 4, 5, 0, 3, 3, 3, 3, 2, 0, 4, 3, 1, 4, 3, 4, 1, 4, 4, 3, 3, 4, 4, 3, 1, 2, 3, 0, 4, 2, 0, 4, 1, 0, 3, 3, 0, 4, 3, 3, 3, 4, 0, 4, 0, 2, 0, 3, 5, 3, 4, 5, 2, 0, 3, 0, 0, 4, 5), + (0, 3, 0, 4, 0, 1, 0, 1, 0, 1, 3, 2, 2, 1, 3, 0, 3, 0, 2, 0, 2, 0, 3, 0, 2, 0, 0, 0, 1, 0, 1, 1, 0, 0, 3, 1, 0, 0, 0, 4, 0, 3, 1, 0, 2, 1, 3, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 4, 2, 2, 3, 1, 0, 3, 0, 0, 0, 1, 4, 4, 4, 3, 0, 0, 4, 0, 0, 1, 4), + (1, 4, 1, 5, 0, 3, 0, 3, 0, 4, 5, 4, 4, 3, 5, 3, 3, 4, 4, 3, 4, 1, 3, 3, 3, 3, 2, 1, 4, 1, 5, 4, 3, 1, 4, 4, 3, 5, 4, 4, 3, 5, 4, 3, 3, 4, 4, 4, 0, 3, 3, 1, 2, 3, 0, 3, 1, 0, 3, 3, 0, 5, 4, 4, 4, 4, 4, 4, 3, 3, 5, 4, 4, 3, 3, 5, 4, 0, 3, 2, 0, 4, 4), + (0, 2, 0, 3, 0, 1, 0, 0, 0, 1, 3, 3, 3, 2, 4, 1, 3, 0, 3, 1, 3, 0, 2, 2, 1, 1, 0, 0, 2, 0, 4, 3, 1, 0, 4, 3, 0, 4, 4, 4, 1, 4, 3, 1, 1, 3, 3, 1, 0, 2, 0, 0, 1, 3, 0, 0, 0, 0, 2, 0, 0, 4, 3, 2, 4, 3, 5, 4, 3, 3, 3, 4, 3, 3, 4, 3, 3, 0, 2, 1, 0, 3, 3), + (0, 2, 0, 4, 0, 3, 0, 2, 0, 2, 5, 5, 3, 4, 4, 4, 4, 1, 4, 3, 3, 0, 4, 3, 4, 3, 1, 3, 3, 2, 4, 3, 0, 3, 4, 3, 0, 3, 4, 4, 2, 4, 4, 0, 4, 5, 3, 3, 2, 2, 1, 1, 1, 2, 0, 1, 5, 0, 3, 3, 2, 4, 3, 3, 3, 4, 0, 3, 0, 2, 0, 4, 4, 3, 5, 5, 0, 0, 3, 0, 2, 3, 3), + (0, 3, 0, 4, 0, 3, 0, 1, 0, 3, 4, 3, 3, 1, 3, 3, 3, 0, 3, 1, 3, 0, 4, 3, 3, 1, 1, 0, 3, 0, 3, 3, 0, 0, 4, 4, 0, 1, 5, 4, 3, 3, 5, 0, 3, 3, 4, 3, 0, 2, 0, 1, 1, 1, 0, 1, 3, 0, 1, 2, 1, 3, 3, 2, 3, 3, 0, 3, 0, 1, 0, 1, 3, 3, 4, 4, 1, 0, 1, 2, 2, 1, 3), + (0, 1, 0, 4, 0, 4, 0, 3, 0, 1, 3, 3, 3, 2, 3, 1, 1, 0, 3, 0, 3, 3, 4, 3, 2, 4, 2, 0, 1, 0, 4, 3, 2, 0, 4, 3, 0, 5, 3, 3, 2, 4, 4, 4, 3, 3, 3, 4, 0, 1, 3, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 4, 2, 3, 3, 3, 0, 3, 0, 0, 0, 4, 4, 4, 5, 3, 2, 0, 3, 3, 0, 3, 5), + (0, 2, 0, 3, 0, 0, 0, 3, 0, 1, 3, 0, 2, 0, 0, 0, 1, 0, 3, 1, 1, 3, 3, 0, 0, 3, 0, 0, 3, 0, 2, 3, 1, 0, 3, 1, 0, 3, 3, 2, 0, 4, 2, 2, 0, 2, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 2, 0, 1, 0, 1, 0, 0, 0, 1, 3, 1, 2, 0, 0, 0, 1, 0, 0, 1, 4), + (0, 3, 0, 3, 0, 5, 0, 1, 0, 2, 4, 3, 1, 3, 3, 2, 1, 1, 5, 2, 1, 0, 5, 1, 2, 0, 0, 0, 3, 3, 2, 2, 3, 2, 4, 3, 0, 0, 3, 3, 1, 3, 3, 0, 2, 5, 3, 4, 0, 3, 3, 0, 1, 2, 0, 2, 2, 0, 3, 2, 0, 2, 2, 3, 3, 3, 0, 2, 0, 1, 0, 3, 4, 4, 2, 5, 4, 0, 3, 0, 0, 3, 5), + (0, 3, 0, 3, 0, 3, 0, 1, 0, 3, 3, 3, 3, 0, 3, 0, 2, 0, 2, 1, 1, 0, 2, 0, 1, 0, 0, 0, 2, 1, 0, 0, 1, 0, 3, 2, 0, 0, 3, 3, 1, 2, 3, 1, 0, 3, 3, 0, 0, 1, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 2, 3, 1, 2, 3, 0, 3, 0, 1, 0, 3, 2, 1, 0, 4, 3, 0, 1, 1, 0, 3, 3), + (0, 4, 0, 5, 0, 3, 0, 3, 0, 4, 5, 5, 4, 3, 5, 3, 4, 3, 5, 3, 3, 2, 5, 3, 4, 4, 4, 3, 4, 3, 4, 5, 5, 3, 4, 4, 3, 4, 4, 5, 4, 4, 4, 3, 4, 5, 5, 4, 2, 3, 4, 2, 3, 4, 0, 3, 3, 1, 4, 3, 2, 4, 3, 3, 5, 5, 0, 3, 0, 3, 0, 5, 5, 5, 5, 4, 4, 0, 4, 0, 1, 4, 4), + (0, 4, 0, 4, 0, 3, 0, 3, 0, 3, 5, 4, 4, 2, 3, 2, 5, 1, 3, 2, 5, 1, 4, 2, 3, 2, 3, 3, 4, 3, 3, 3, 3, 2, 5, 4, 1, 3, 3, 5, 3, 4, 4, 0, 4, 4, 3, 1, 1, 3, 1, 0, 2, 3, 0, 2, 3, 0, 3, 0, 0, 4, 3, 1, 3, 4, 0, 3, 0, 2, 0, 4, 4, 4, 3, 4, 5, 0, 4, 0, 0, 3, 4), + (0, 3, 0, 3, 0, 3, 1, 2, 0, 3, 4, 4, 3, 3, 3, 0, 2, 2, 4, 3, 3, 1, 3, 3, 3, 1, 1, 0, 3, 1, 4, 3, 2, 3, 4, 4, 2, 4, 4, 4, 3, 4, 4, 3, 2, 4, 4, 3, 1, 3, 3, 1, 3, 3, 0, 4, 1, 0, 2, 2, 1, 4, 3, 2, 3, 3, 5, 4, 3, 3, 5, 4, 4, 3, 3, 0, 4, 0, 3, 2, 2, 4, 4), + (0, 2, 0, 1, 0, 0, 0, 0, 0, 1, 2, 1, 3, 0, 0, 0, 0, 0, 2, 0, 1, 2, 1, 0, 0, 1, 0, 0, 0, 0, 3, 0, 0, 1, 0, 1, 1, 3, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 2, 2, 0, 3, 4, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1), + (0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 4, 0, 4, 1, 4, 0, 3, 0, 4, 0, 3, 0, 4, 0, 3, 0, 3, 0, 4, 1, 5, 1, 4, 0, 0, 3, 0, 5, 0, 5, 2, 0, 1, 0, 0, 0, 2, 1, 4, 0, 1, 3, 0, 0, 3, 0, 0, 3, 1, 1, 4, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0), + (1, 4, 0, 5, 0, 3, 0, 2, 0, 3, 5, 4, 4, 3, 4, 3, 5, 3, 4, 3, 3, 0, 4, 3, 3, 3, 3, 3, 3, 2, 4, 4, 3, 1, 3, 4, 4, 5, 4, 4, 3, 4, 4, 1, 3, 5, 4, 3, 3, 3, 1, 2, 2, 3, 3, 1, 3, 1, 3, 3, 3, 5, 3, 3, 4, 5, 0, 3, 0, 3, 0, 3, 4, 3, 4, 4, 3, 0, 3, 0, 2, 4, 3), + (0, 1, 0, 4, 0, 0, 0, 0, 0, 1, 4, 0, 4, 1, 4, 2, 4, 0, 3, 0, 1, 0, 1, 0, 0, 0, 0, 0, 2, 0, 3, 1, 1, 1, 0, 3, 0, 0, 0, 1, 2, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 3, 0, 0, 0, 0, 3, 2, 0, 2, 2, 0, 1, 0, 0, 0, 2, 3, 2, 3, 3, 0, 0, 0, 0, 2, 1, 0), + (0, 5, 1, 5, 0, 3, 0, 3, 0, 5, 4, 4, 5, 1, 5, 3, 3, 0, 4, 3, 4, 3, 5, 3, 4, 3, 3, 2, 4, 3, 4, 3, 3, 0, 3, 3, 1, 4, 4, 3, 4, 4, 4, 3, 4, 5, 5, 3, 2, 3, 1, 1, 3, 3, 1, 3, 1, 1, 3, 3, 2, 4, 5, 3, 3, 5, 0, 4, 0, 3, 0, 4, 4, 3, 5, 3, 3, 0, 3, 4, 0, 4, 3), + (0, 5, 0, 5, 0, 3, 0, 2, 0, 4, 4, 3, 5, 2, 4, 3, 3, 3, 4, 4, 4, 3, 5, 3, 5, 3, 3, 1, 4, 0, 4, 3, 3, 0, 3, 3, 0, 4, 4, 4, 4, 5, 4, 3, 3, 5, 5, 3, 2, 3, 1, 2, 3, 2, 0, 1, 0, 0, 3, 2, 2, 4, 4, 3, 1, 5, 0, 4, 0, 3, 0, 4, 3, 1, 3, 2, 1, 0, 3, 3, 0, 3, 3), + (0, 4, 0, 5, 0, 5, 0, 4, 0, 4, 5, 5, 5, 3, 4, 3, 3, 2, 5, 4, 4, 3, 5, 3, 5, 3, 4, 0, 4, 3, 4, 4, 3, 2, 4, 4, 3, 4, 5, 4, 4, 5, 5, 0, 3, 5, 5, 4, 1, 3, 3, 2, 3, 3, 1, 3, 1, 0, 4, 3, 1, 4, 4, 3, 4, 5, 0, 4, 0, 2, 0, 4, 3, 4, 4, 3, 3, 0, 4, 0, 0, 5, 5), + (0, 4, 0, 4, 0, 5, 0, 1, 1, 3, 3, 4, 4, 3, 4, 1, 3, 0, 5, 1, 3, 0, 3, 1, 3, 1, 1, 0, 3, 0, 3, 3, 4, 0, 4, 3, 0, 4, 4, 4, 3, 4, 4, 0, 3, 5, 4, 1, 0, 3, 0, 0, 2, 3, 0, 3, 1, 0, 3, 1, 0, 3, 2, 1, 3, 5, 0, 3, 0, 1, 0, 3, 2, 3, 3, 4, 4, 0, 2, 2, 0, 4, 4), + (2, 4, 0, 5, 0, 4, 0, 3, 0, 4, 5, 5, 4, 3, 5, 3, 5, 3, 5, 3, 5, 2, 5, 3, 4, 3, 3, 4, 3, 4, 5, 3, 2, 1, 5, 4, 3, 2, 3, 4, 5, 3, 4, 1, 2, 5, 4, 3, 0, 3, 3, 0, 3, 2, 0, 2, 3, 0, 4, 1, 0, 3, 4, 3, 3, 5, 0, 3, 0, 1, 0, 4, 5, 5, 5, 4, 3, 0, 4, 2, 0, 3, 5), + (0, 5, 0, 4, 0, 4, 0, 2, 0, 5, 4, 3, 4, 3, 4, 3, 3, 3, 4, 3, 4, 2, 5, 3, 5, 3, 4, 1, 4, 3, 4, 4, 4, 0, 3, 5, 0, 4, 4, 4, 4, 5, 3, 1, 3, 4, 5, 3, 3, 3, 3, 3, 3, 3, 0, 2, 2, 0, 3, 3, 2, 4, 3, 3, 3, 5, 3, 4, 1, 3, 3, 5, 3, 2, 0, 0, 0, 0, 4, 3, 1, 3, 3), + (0, 1, 0, 3, 0, 3, 0, 1, 0, 1, 3, 3, 3, 2, 3, 3, 3, 0, 3, 0, 0, 0, 3, 1, 3, 0, 0, 0, 2, 2, 2, 3, 0, 0, 3, 2, 0, 1, 2, 4, 1, 3, 3, 0, 0, 3, 3, 3, 0, 1, 0, 0, 2, 1, 0, 0, 3, 0, 3, 1, 0, 3, 0, 0, 1, 3, 0, 2, 0, 1, 0, 3, 3, 1, 3, 3, 0, 0, 1, 1, 0, 3, 3), + (0, 2, 0, 3, 0, 2, 1, 4, 0, 2, 2, 3, 1, 1, 3, 1, 1, 0, 2, 0, 3, 1, 2, 3, 1, 3, 0, 0, 1, 0, 4, 3, 2, 3, 3, 3, 1, 4, 2, 3, 3, 3, 3, 1, 0, 3, 1, 4, 0, 1, 1, 0, 1, 2, 0, 1, 1, 0, 1, 1, 0, 3, 1, 3, 2, 2, 0, 1, 0, 0, 0, 2, 3, 3, 3, 1, 0, 0, 0, 0, 0, 2, 3), + (0, 5, 0, 4, 0, 5, 0, 2, 0, 4, 5, 5, 3, 3, 4, 3, 3, 1, 5, 4, 4, 2, 4, 4, 4, 3, 4, 2, 4, 3, 5, 5, 4, 3, 3, 4, 3, 3, 5, 5, 4, 5, 5, 1, 3, 4, 5, 3, 1, 4, 3, 1, 3, 3, 0, 3, 3, 1, 4, 3, 1, 4, 5, 3, 3, 5, 0, 4, 0, 3, 0, 5, 3, 3, 1, 4, 3, 0, 4, 0, 1, 5, 3), + (0, 5, 0, 5, 0, 4, 0, 2, 0, 4, 4, 3, 4, 3, 3, 3, 3, 3, 5, 4, 4, 4, 4, 4, 4, 5, 3, 3, 5, 2, 4, 4, 4, 3, 4, 4, 3, 3, 4, 4, 5, 5, 3, 3, 4, 3, 4, 3, 3, 4, 3, 3, 3, 3, 1, 2, 2, 1, 4, 3, 3, 5, 4, 4, 3, 4, 0, 4, 0, 3, 0, 4, 4, 4, 4, 4, 1, 0, 4, 2, 0, 2, 4), + (0, 4, 0, 4, 0, 3, 0, 1, 0, 3, 5, 2, 3, 0, 3, 0, 2, 1, 4, 2, 3, 3, 4, 1, 4, 3, 3, 2, 4, 1, 3, 3, 3, 0, 3, 3, 0, 0, 3, 3, 3, 5, 3, 3, 3, 3, 3, 2, 0, 2, 0, 0, 2, 0, 0, 2, 0, 0, 1, 0, 0, 3, 1, 2, 2, 3, 0, 3, 0, 2, 0, 4, 4, 3, 3, 4, 1, 0, 3, 0, 0, 2, 4), + (0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 2, 0, 0, 0, 0, 0, 1, 0, 2, 0, 1, 0, 0, 0, 0, 0, 3, 1, 3, 0, 3, 2, 0, 0, 0, 1, 0, 3, 2, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 4, 0, 2, 0, 0, 0, 0, 0, 0, 2), + (0, 2, 1, 3, 0, 2, 0, 2, 0, 3, 3, 3, 3, 1, 3, 1, 3, 3, 3, 3, 3, 3, 4, 2, 2, 1, 2, 1, 4, 0, 4, 3, 1, 3, 3, 3, 2, 4, 3, 5, 4, 3, 3, 3, 3, 3, 3, 3, 0, 1, 3, 0, 2, 0, 0, 1, 0, 0, 1, 0, 0, 4, 2, 0, 2, 3, 0, 3, 3, 0, 3, 3, 4, 2, 3, 1, 4, 0, 1, 2, 0, 2, 3), + (0, 3, 0, 3, 0, 1, 0, 3, 0, 2, 3, 3, 3, 0, 3, 1, 2, 0, 3, 3, 2, 3, 3, 2, 3, 2, 3, 1, 3, 0, 4, 3, 2, 0, 3, 3, 1, 4, 3, 3, 2, 3, 4, 3, 1, 3, 3, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 4, 1, 1, 0, 3, 0, 3, 1, 0, 2, 3, 3, 3, 3, 3, 1, 0, 0, 2, 0, 3, 3), + (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 2, 0, 3, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 3, 0, 3, 0, 3, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 2, 0, 2, 3, 0, 0, 0, 0, 0, 0, 0, 0, 3), + (0, 2, 0, 3, 1, 3, 0, 3, 0, 2, 3, 3, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 1, 3, 0, 2, 3, 1, 1, 4, 3, 3, 2, 3, 3, 1, 2, 2, 4, 1, 3, 3, 0, 1, 4, 2, 3, 0, 1, 3, 0, 3, 0, 0, 1, 3, 0, 2, 0, 0, 3, 3, 2, 1, 3, 0, 3, 0, 2, 0, 3, 4, 4, 4, 3, 1, 0, 3, 0, 0, 3, 3), + (0, 2, 0, 1, 0, 2, 0, 0, 0, 1, 3, 2, 2, 1, 3, 0, 1, 1, 3, 0, 3, 2, 3, 1, 2, 0, 2, 0, 1, 1, 3, 3, 3, 0, 3, 3, 1, 1, 2, 3, 2, 3, 3, 1, 2, 3, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 3, 0, 1, 0, 0, 2, 1, 2, 1, 3, 0, 3, 0, 0, 0, 3, 4, 4, 4, 3, 2, 0, 2, 0, 0, 2, 4), + (0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 3, 1, 0, 0, 0, 0, 0, 0, 0, 3), + (0, 3, 0, 3, 0, 2, 0, 3, 0, 3, 3, 3, 2, 3, 2, 2, 2, 0, 3, 1, 3, 3, 3, 2, 3, 3, 0, 0, 3, 0, 3, 2, 2, 0, 2, 3, 1, 4, 3, 4, 3, 3, 2, 3, 1, 5, 4, 4, 0, 3, 1, 2, 1, 3, 0, 3, 1, 1, 2, 0, 2, 3, 1, 3, 1, 3, 0, 3, 0, 1, 0, 3, 3, 4, 4, 2, 1, 0, 2, 1, 0, 2, 4), + (0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 4, 2, 5, 1, 4, 0, 2, 0, 2, 1, 3, 1, 4, 0, 2, 1, 0, 0, 2, 1, 4, 1, 1, 0, 3, 3, 0, 5, 1, 3, 2, 3, 3, 1, 0, 3, 2, 3, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 4, 0, 1, 0, 3, 0, 2, 0, 1, 0, 3, 3, 3, 4, 3, 3, 0, 0, 0, 0, 2, 3), + (0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 2, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 0, 1, 0, 0, 0, 0, 0, 3), + (0, 1, 0, 3, 0, 4, 0, 3, 0, 2, 4, 3, 1, 0, 3, 2, 2, 1, 3, 1, 2, 2, 3, 1, 1, 1, 2, 1, 3, 0, 1, 2, 0, 1, 3, 2, 1, 3, 0, 5, 5, 1, 0, 0, 1, 3, 2, 1, 0, 3, 0, 0, 1, 0, 0, 0, 0, 0, 3, 4, 0, 1, 1, 1, 3, 2, 0, 2, 0, 1, 0, 2, 3, 3, 1, 2, 3, 0, 1, 0, 1, 0, 4), + (0, 0, 0, 1, 0, 3, 0, 3, 0, 2, 2, 1, 0, 0, 4, 0, 3, 0, 3, 1, 3, 0, 3, 0, 3, 0, 1, 0, 3, 0, 3, 1, 3, 0, 3, 3, 0, 0, 1, 2, 1, 1, 1, 0, 1, 2, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 1, 2, 0, 0, 2, 0, 0, 0, 0, 2, 3, 3, 3, 3, 0, 0, 0, 0, 1, 4), + (0, 0, 0, 3, 0, 3, 0, 0, 0, 0, 3, 1, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 0, 2, 0, 2, 3, 0, 0, 2, 2, 3, 1, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 2, 3), + (2, 4, 0, 5, 0, 5, 0, 4, 0, 3, 4, 3, 3, 3, 4, 3, 3, 3, 4, 3, 4, 4, 5, 4, 5, 5, 5, 2, 3, 0, 5, 5, 4, 1, 5, 4, 3, 1, 5, 4, 3, 4, 4, 3, 3, 4, 3, 3, 0, 3, 2, 0, 2, 3, 0, 3, 0, 0, 3, 3, 0, 5, 3, 2, 3, 3, 0, 3, 0, 3, 0, 3, 4, 5, 4, 5, 3, 0, 4, 3, 0, 3, 4), + (0, 3, 0, 3, 0, 3, 0, 3, 0, 3, 3, 4, 3, 2, 3, 2, 3, 0, 4, 3, 3, 3, 3, 3, 3, 3, 3, 0, 3, 2, 4, 3, 3, 1, 3, 4, 3, 4, 4, 4, 3, 4, 4, 3, 2, 4, 4, 1, 0, 2, 0, 0, 1, 1, 0, 2, 0, 0, 3, 1, 0, 5, 3, 2, 1, 3, 0, 3, 0, 1, 2, 4, 3, 2, 4, 3, 3, 0, 3, 2, 0, 4, 4), + (0, 3, 0, 3, 0, 1, 0, 0, 0, 1, 4, 3, 3, 2, 3, 1, 3, 1, 4, 2, 3, 2, 4, 2, 3, 4, 3, 0, 2, 2, 3, 3, 3, 0, 3, 3, 3, 0, 3, 4, 1, 3, 3, 0, 3, 4, 3, 3, 0, 1, 1, 0, 1, 0, 0, 0, 4, 0, 3, 0, 0, 3, 1, 2, 1, 3, 0, 4, 0, 1, 0, 4, 3, 3, 4, 3, 3, 0, 2, 0, 0, 3, 3), + (0, 3, 0, 4, 0, 1, 0, 3, 0, 3, 4, 3, 3, 0, 3, 3, 3, 1, 3, 1, 3, 3, 4, 3, 3, 3, 0, 0, 3, 1, 5, 3, 3, 1, 3, 3, 2, 5, 4, 3, 3, 4, 5, 3, 2, 5, 3, 4, 0, 1, 0, 0, 0, 0, 0, 2, 0, 0, 1, 1, 0, 4, 2, 2, 1, 3, 0, 3, 0, 2, 0, 4, 4, 3, 5, 3, 2, 0, 1, 1, 0, 3, 4), + (0, 5, 0, 4, 0, 5, 0, 2, 0, 4, 4, 3, 3, 2, 3, 3, 3, 1, 4, 3, 4, 1, 5, 3, 4, 3, 4, 0, 4, 2, 4, 3, 4, 1, 5, 4, 0, 4, 4, 4, 4, 5, 4, 1, 3, 5, 4, 2, 1, 4, 1, 1, 3, 2, 0, 3, 1, 0, 3, 2, 1, 4, 3, 3, 3, 4, 0, 4, 0, 3, 0, 4, 4, 4, 3, 3, 3, 0, 4, 2, 0, 3, 4), + (1, 4, 0, 4, 0, 3, 0, 1, 0, 3, 3, 3, 1, 1, 3, 3, 2, 2, 3, 3, 1, 0, 3, 2, 2, 1, 2, 0, 3, 1, 2, 1, 2, 0, 3, 2, 0, 2, 2, 3, 3, 4, 3, 0, 3, 3, 1, 2, 0, 1, 1, 3, 1, 2, 0, 0, 3, 0, 1, 1, 0, 3, 2, 2, 3, 3, 0, 3, 0, 0, 0, 2, 3, 3, 4, 3, 3, 0, 1, 0, 0, 1, 4), + (0, 4, 0, 4, 0, 4, 0, 0, 0, 3, 4, 4, 3, 1, 4, 2, 3, 2, 3, 3, 3, 1, 4, 3, 4, 0, 3, 0, 4, 2, 3, 3, 2, 2, 5, 4, 2, 1, 3, 4, 3, 4, 3, 1, 3, 3, 4, 2, 0, 2, 1, 0, 3, 3, 0, 0, 2, 0, 3, 1, 0, 4, 4, 3, 4, 3, 0, 4, 0, 1, 0, 2, 4, 4, 4, 4, 4, 0, 3, 2, 0, 3, 3), + (0, 0, 0, 1, 0, 4, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 2, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 2), + (0, 2, 0, 3, 0, 4, 0, 4, 0, 1, 3, 3, 3, 0, 4, 0, 2, 1, 2, 1, 1, 1, 2, 0, 3, 1, 1, 0, 1, 0, 3, 1, 0, 0, 3, 3, 2, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 2, 0, 2, 2, 0, 3, 1, 0, 0, 1, 0, 1, 1, 0, 1, 2, 0, 3, 0, 0, 0, 0, 1, 0, 0, 3, 3, 4, 3, 1, 0, 1, 0, 3, 0, 2), + (0, 0, 0, 3, 0, 5, 0, 0, 0, 0, 1, 0, 2, 0, 3, 1, 0, 1, 3, 0, 0, 0, 2, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 4, 0, 0, 0, 2, 3, 0, 1, 4, 1, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 3, 0, 0, 0, 0, 0, 3), + (0, 2, 0, 5, 0, 5, 0, 1, 0, 2, 4, 3, 3, 2, 5, 1, 3, 2, 3, 3, 3, 0, 4, 1, 2, 0, 3, 0, 4, 0, 2, 2, 1, 1, 5, 3, 0, 0, 1, 4, 2, 3, 2, 0, 3, 3, 3, 2, 0, 2, 4, 1, 1, 2, 0, 1, 1, 0, 3, 1, 0, 1, 3, 1, 2, 3, 0, 2, 0, 0, 0, 1, 3, 5, 4, 4, 4, 0, 3, 0, 0, 1, 3), + (0, 4, 0, 5, 0, 4, 0, 4, 0, 4, 5, 4, 3, 3, 4, 3, 3, 3, 4, 3, 4, 4, 5, 3, 4, 5, 4, 2, 4, 2, 3, 4, 3, 1, 4, 4, 1, 3, 5, 4, 4, 5, 5, 4, 4, 5, 5, 5, 2, 3, 3, 1, 4, 3, 1, 3, 3, 0, 3, 3, 1, 4, 3, 4, 4, 4, 0, 3, 0, 4, 0, 3, 3, 4, 4, 5, 0, 0, 4, 3, 0, 4, 5), + (0, 4, 0, 4, 0, 3, 0, 3, 0, 3, 4, 4, 4, 3, 3, 2, 4, 3, 4, 3, 4, 3, 5, 3, 4, 3, 2, 1, 4, 2, 4, 4, 3, 1, 3, 4, 2, 4, 5, 5, 3, 4, 5, 4, 1, 5, 4, 3, 0, 3, 2, 2, 3, 2, 1, 3, 1, 0, 3, 3, 3, 5, 3, 3, 3, 5, 4, 4, 2, 3, 3, 4, 3, 3, 3, 2, 1, 0, 3, 2, 1, 4, 3), + (0, 4, 0, 5, 0, 4, 0, 3, 0, 3, 5, 5, 3, 2, 4, 3, 4, 0, 5, 4, 4, 1, 4, 4, 4, 3, 3, 3, 4, 3, 5, 5, 2, 3, 3, 4, 1, 2, 5, 5, 3, 5, 5, 2, 3, 5, 5, 4, 0, 3, 2, 0, 3, 3, 1, 1, 5, 1, 4, 1, 0, 4, 3, 2, 3, 5, 0, 4, 0, 3, 0, 5, 4, 3, 4, 3, 0, 0, 4, 1, 0, 4, 4), + (1, 3, 0, 4, 0, 2, 0, 2, 0, 2, 5, 5, 3, 3, 3, 3, 3, 0, 4, 2, 3, 4, 4, 4, 3, 4, 0, 0, 3, 4, 5, 4, 3, 3, 3, 3, 2, 5, 5, 4, 5, 5, 5, 4, 3, 5, 5, 5, 1, 3, 1, 0, 1, 0, 0, 3, 2, 0, 4, 2, 0, 5, 2, 3, 2, 4, 1, 3, 0, 3, 0, 4, 5, 4, 5, 4, 3, 0, 4, 2, 0, 5, 4), + (0, 3, 0, 4, 0, 5, 0, 3, 0, 3, 4, 4, 3, 2, 3, 2, 3, 3, 3, 3, 3, 2, 4, 3, 3, 2, 2, 0, 3, 3, 3, 3, 3, 1, 3, 3, 3, 0, 4, 4, 3, 4, 4, 1, 1, 4, 4, 2, 0, 3, 1, 0, 1, 1, 0, 4, 1, 0, 2, 3, 1, 3, 3, 1, 3, 4, 0, 3, 0, 1, 0, 3, 1, 3, 0, 0, 1, 0, 2, 0, 0, 4, 4), + (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0), + (0, 3, 0, 3, 0, 2, 0, 3, 0, 1, 5, 4, 3, 3, 3, 1, 4, 2, 1, 2, 3, 4, 4, 2, 4, 4, 5, 0, 3, 1, 4, 3, 4, 0, 4, 3, 3, 3, 2, 3, 2, 5, 3, 4, 3, 2, 2, 3, 0, 0, 3, 0, 2, 1, 0, 1, 2, 0, 0, 0, 0, 2, 1, 1, 3, 1, 0, 2, 0, 4, 0, 3, 4, 4, 4, 5, 2, 0, 2, 0, 0, 1, 3), + (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 4, 2, 1, 1, 0, 1, 0, 3, 2, 0, 0, 3, 1, 1, 1, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 1, 0, 0, 0, 2, 0, 0, 0, 1, 4, 0, 4, 2, 1, 0, 0, 0, 0, 0, 1), + (0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 3, 1, 0, 0, 0, 2, 0, 2, 1, 0, 0, 1, 2, 1, 0, 1, 1, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 3, 1, 0, 0, 0, 0, 0, 1, 0, 0, 2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2), + (0, 4, 0, 4, 0, 4, 0, 3, 0, 4, 4, 3, 4, 2, 4, 3, 2, 0, 4, 4, 4, 3, 5, 3, 5, 3, 3, 2, 4, 2, 4, 3, 4, 3, 1, 4, 0, 2, 3, 4, 4, 4, 3, 3, 3, 4, 4, 4, 3, 4, 1, 3, 4, 3, 2, 1, 2, 1, 3, 3, 3, 4, 4, 3, 3, 5, 0, 4, 0, 3, 0, 4, 3, 3, 3, 2, 1, 0, 3, 0, 0, 3, 3), + (0, 4, 0, 3, 0, 3, 0, 3, 0, 3, 5, 5, 3, 3, 3, 3, 4, 3, 4, 3, 3, 3, 4, 4, 4, 3, 3, 3, 3, 4, 3, 5, 3, 3, 1, 3, 2, 4, 5, 5, 5, 5, 4, 3, 4, 5, 5, 3, 2, 2, 3, 3, 3, 3, 2, 3, 3, 1, 2, 3, 2, 4, 3, 3, 3, 4, 0, 4, 0, 2, 0, 4, 3, 2, 2, 1, 2, 0, 3, 0, 0, 4, 1), ) +# fmt: on -class JapaneseContextAnalysis(object): + +class JapaneseContextAnalysis: NUM_OF_CATEGORY = 6 DONT_KNOW = -1 ENOUGH_REL_THRESHOLD = 100 MAX_REL_THRESHOLD = 1000 MINIMUM_DATA_THRESHOLD = 4 - def __init__(self): - self._total_rel = None - self._rel_sample = None - self._need_to_skip_char_num = None - self._last_char_order = None - self._done = None + def __init__(self) -> None: + self._total_rel = 0 + self._rel_sample: List[int] = [] + self._need_to_skip_char_num = 0 + self._last_char_order = -1 + self._done = False self.reset() - def reset(self): + def reset(self) -> None: self._total_rel = 0 # total sequence received # category counters, each integer counts sequence in its category self._rel_sample = [0] * self.NUM_OF_CATEGORY @@ -140,7 +144,7 @@ class JapaneseContextAnalysis(object): # been made self._done = False - def feed(self, byte_str, num_bytes): + def feed(self, byte_str: Union[bytes, bytearray], num_bytes: int) -> None: if self._done: return @@ -153,7 +157,7 @@ class JapaneseContextAnalysis(object): # this character will simply our logic and improve performance. i = self._need_to_skip_char_num while i < num_bytes: - order, char_len = self.get_order(byte_str[i:i + 2]) + order, char_len = self.get_order(byte_str[i : i + 2]) i += char_len if i > num_bytes: self._need_to_skip_char_num = i - num_bytes @@ -164,32 +168,34 @@ class JapaneseContextAnalysis(object): if self._total_rel > self.MAX_REL_THRESHOLD: self._done = True break - self._rel_sample[jp2CharContext[self._last_char_order][order]] += 1 + self._rel_sample[ + jp2_char_context[self._last_char_order][order] + ] += 1 self._last_char_order = order - def got_enough_data(self): + def got_enough_data(self) -> bool: return self._total_rel > self.ENOUGH_REL_THRESHOLD - def get_confidence(self): + def get_confidence(self) -> float: # This is just one way to calculate confidence. It works well for me. if self._total_rel > self.MINIMUM_DATA_THRESHOLD: return (self._total_rel - self._rel_sample[0]) / self._total_rel - else: - return self.DONT_KNOW + return self.DONT_KNOW - def get_order(self, byte_str): + def get_order(self, _: Union[bytes, bytearray]) -> Tuple[int, int]: return -1, 1 + class SJISContextAnalysis(JapaneseContextAnalysis): - def __init__(self): - super(SJISContextAnalysis, self).__init__() + def __init__(self) -> None: + super().__init__() self._charset_name = "SHIFT_JIS" @property - def charset_name(self): + def charset_name(self) -> str: return self._charset_name - def get_order(self, byte_str): + def get_order(self, byte_str: Union[bytes, bytearray]) -> Tuple[int, int]: if not byte_str: return -1, 1 # find out current char's byte length @@ -209,8 +215,9 @@ class SJISContextAnalysis(JapaneseContextAnalysis): return -1, char_len + class EUCJPContextAnalysis(JapaneseContextAnalysis): - def get_order(self, byte_str): + def get_order(self, byte_str: Union[bytes, bytearray]) -> Tuple[int, int]: if not byte_str: return -1, 1 # find out current char's byte length @@ -229,5 +236,3 @@ class EUCJPContextAnalysis(JapaneseContextAnalysis): return second_char - 0xA1, char_len return -1, char_len - - diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py index e963a509..99466821 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py @@ -1,9 +1,5 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- - from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - # 3: Positive # 2: Likely # 1: Unlikely @@ -4115,536 +4111,539 @@ BULGARIAN_LANG_MODEL = { # Character Mapping Table(s): ISO_8859_5_BULGARIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 77, # 'A' - 66: 90, # 'B' - 67: 99, # 'C' - 68: 100, # 'D' - 69: 72, # 'E' - 70: 109, # 'F' - 71: 107, # 'G' - 72: 101, # 'H' - 73: 79, # 'I' - 74: 185, # 'J' - 75: 81, # 'K' - 76: 102, # 'L' - 77: 76, # 'M' - 78: 94, # 'N' - 79: 82, # 'O' - 80: 110, # 'P' - 81: 186, # 'Q' - 82: 108, # 'R' - 83: 91, # 'S' - 84: 74, # 'T' - 85: 119, # 'U' - 86: 84, # 'V' - 87: 96, # 'W' - 88: 111, # 'X' - 89: 187, # 'Y' - 90: 115, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 65, # 'a' - 98: 69, # 'b' - 99: 70, # 'c' - 100: 66, # 'd' - 101: 63, # 'e' - 102: 68, # 'f' - 103: 112, # 'g' - 104: 103, # 'h' - 105: 92, # 'i' - 106: 194, # 'j' - 107: 104, # 'k' - 108: 95, # 'l' - 109: 86, # 'm' - 110: 87, # 'n' - 111: 71, # 'o' - 112: 116, # 'p' - 113: 195, # 'q' - 114: 85, # 'r' - 115: 93, # 's' - 116: 97, # 't' - 117: 113, # 'u' - 118: 196, # 'v' - 119: 197, # 'w' - 120: 198, # 'x' - 121: 199, # 'y' - 122: 200, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 194, # '\x80' - 129: 195, # '\x81' - 130: 196, # '\x82' - 131: 197, # '\x83' - 132: 198, # '\x84' - 133: 199, # '\x85' - 134: 200, # '\x86' - 135: 201, # '\x87' - 136: 202, # '\x88' - 137: 203, # '\x89' - 138: 204, # '\x8a' - 139: 205, # '\x8b' - 140: 206, # '\x8c' - 141: 207, # '\x8d' - 142: 208, # '\x8e' - 143: 209, # '\x8f' - 144: 210, # '\x90' - 145: 211, # '\x91' - 146: 212, # '\x92' - 147: 213, # '\x93' - 148: 214, # '\x94' - 149: 215, # '\x95' - 150: 216, # '\x96' - 151: 217, # '\x97' - 152: 218, # '\x98' - 153: 219, # '\x99' - 154: 220, # '\x9a' - 155: 221, # '\x9b' - 156: 222, # '\x9c' - 157: 223, # '\x9d' - 158: 224, # '\x9e' - 159: 225, # '\x9f' - 160: 81, # '\xa0' - 161: 226, # 'Ё' - 162: 227, # 'Ђ' - 163: 228, # 'Ѓ' - 164: 229, # 'Є' - 165: 230, # 'Ѕ' - 166: 105, # 'І' - 167: 231, # 'Ї' - 168: 232, # 'Ј' - 169: 233, # 'Љ' - 170: 234, # 'Њ' - 171: 235, # 'Ћ' - 172: 236, # 'Ќ' - 173: 45, # '\xad' - 174: 237, # 'Ў' - 175: 238, # 'Џ' - 176: 31, # 'А' - 177: 32, # 'Б' - 178: 35, # 'В' - 179: 43, # 'Г' - 180: 37, # 'Д' - 181: 44, # 'Е' - 182: 55, # 'Ж' - 183: 47, # 'З' - 184: 40, # 'И' - 185: 59, # 'Й' - 186: 33, # 'К' - 187: 46, # 'Л' - 188: 38, # 'М' - 189: 36, # 'Н' - 190: 41, # 'О' - 191: 30, # 'П' - 192: 39, # 'Р' - 193: 28, # 'С' - 194: 34, # 'Т' - 195: 51, # 'У' - 196: 48, # 'Ф' - 197: 49, # 'Х' - 198: 53, # 'Ц' - 199: 50, # 'Ч' - 200: 54, # 'Ш' - 201: 57, # 'Щ' - 202: 61, # 'Ъ' - 203: 239, # 'Ы' - 204: 67, # 'Ь' - 205: 240, # 'Э' - 206: 60, # 'Ю' - 207: 56, # 'Я' - 208: 1, # 'а' - 209: 18, # 'б' - 210: 9, # 'в' - 211: 20, # 'г' - 212: 11, # 'д' - 213: 3, # 'е' - 214: 23, # 'ж' - 215: 15, # 'з' - 216: 2, # 'и' - 217: 26, # 'й' - 218: 12, # 'к' - 219: 10, # 'л' - 220: 14, # 'м' - 221: 6, # 'н' - 222: 4, # 'о' - 223: 13, # 'п' - 224: 7, # 'р' - 225: 8, # 'с' - 226: 5, # 'т' - 227: 19, # 'у' - 228: 29, # 'ф' - 229: 25, # 'х' - 230: 22, # 'ц' - 231: 21, # 'ч' - 232: 27, # 'ш' - 233: 24, # 'щ' - 234: 17, # 'ъ' - 235: 75, # 'ы' - 236: 52, # 'ь' - 237: 241, # 'э' - 238: 42, # 'ю' - 239: 16, # 'я' - 240: 62, # '№' - 241: 242, # 'ё' - 242: 243, # 'ђ' - 243: 244, # 'ѓ' - 244: 58, # 'є' - 245: 245, # 'ѕ' - 246: 98, # 'і' - 247: 246, # 'ї' - 248: 247, # 'ј' - 249: 248, # 'љ' - 250: 249, # 'њ' - 251: 250, # 'ћ' - 252: 251, # 'ќ' - 253: 91, # '§' - 254: 252, # 'ў' - 255: 253, # 'џ' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 77, # 'A' + 66: 90, # 'B' + 67: 99, # 'C' + 68: 100, # 'D' + 69: 72, # 'E' + 70: 109, # 'F' + 71: 107, # 'G' + 72: 101, # 'H' + 73: 79, # 'I' + 74: 185, # 'J' + 75: 81, # 'K' + 76: 102, # 'L' + 77: 76, # 'M' + 78: 94, # 'N' + 79: 82, # 'O' + 80: 110, # 'P' + 81: 186, # 'Q' + 82: 108, # 'R' + 83: 91, # 'S' + 84: 74, # 'T' + 85: 119, # 'U' + 86: 84, # 'V' + 87: 96, # 'W' + 88: 111, # 'X' + 89: 187, # 'Y' + 90: 115, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 65, # 'a' + 98: 69, # 'b' + 99: 70, # 'c' + 100: 66, # 'd' + 101: 63, # 'e' + 102: 68, # 'f' + 103: 112, # 'g' + 104: 103, # 'h' + 105: 92, # 'i' + 106: 194, # 'j' + 107: 104, # 'k' + 108: 95, # 'l' + 109: 86, # 'm' + 110: 87, # 'n' + 111: 71, # 'o' + 112: 116, # 'p' + 113: 195, # 'q' + 114: 85, # 'r' + 115: 93, # 's' + 116: 97, # 't' + 117: 113, # 'u' + 118: 196, # 'v' + 119: 197, # 'w' + 120: 198, # 'x' + 121: 199, # 'y' + 122: 200, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 194, # '\x80' + 129: 195, # '\x81' + 130: 196, # '\x82' + 131: 197, # '\x83' + 132: 198, # '\x84' + 133: 199, # '\x85' + 134: 200, # '\x86' + 135: 201, # '\x87' + 136: 202, # '\x88' + 137: 203, # '\x89' + 138: 204, # '\x8a' + 139: 205, # '\x8b' + 140: 206, # '\x8c' + 141: 207, # '\x8d' + 142: 208, # '\x8e' + 143: 209, # '\x8f' + 144: 210, # '\x90' + 145: 211, # '\x91' + 146: 212, # '\x92' + 147: 213, # '\x93' + 148: 214, # '\x94' + 149: 215, # '\x95' + 150: 216, # '\x96' + 151: 217, # '\x97' + 152: 218, # '\x98' + 153: 219, # '\x99' + 154: 220, # '\x9a' + 155: 221, # '\x9b' + 156: 222, # '\x9c' + 157: 223, # '\x9d' + 158: 224, # '\x9e' + 159: 225, # '\x9f' + 160: 81, # '\xa0' + 161: 226, # 'Ё' + 162: 227, # 'Ђ' + 163: 228, # 'Ѓ' + 164: 229, # 'Є' + 165: 230, # 'Ѕ' + 166: 105, # 'І' + 167: 231, # 'Ї' + 168: 232, # 'Ј' + 169: 233, # 'Љ' + 170: 234, # 'Њ' + 171: 235, # 'Ћ' + 172: 236, # 'Ќ' + 173: 45, # '\xad' + 174: 237, # 'Ў' + 175: 238, # 'Џ' + 176: 31, # 'А' + 177: 32, # 'Б' + 178: 35, # 'В' + 179: 43, # 'Г' + 180: 37, # 'Д' + 181: 44, # 'Е' + 182: 55, # 'Ж' + 183: 47, # 'З' + 184: 40, # 'И' + 185: 59, # 'Й' + 186: 33, # 'К' + 187: 46, # 'Л' + 188: 38, # 'М' + 189: 36, # 'Н' + 190: 41, # 'О' + 191: 30, # 'П' + 192: 39, # 'Р' + 193: 28, # 'С' + 194: 34, # 'Т' + 195: 51, # 'У' + 196: 48, # 'Ф' + 197: 49, # 'Х' + 198: 53, # 'Ц' + 199: 50, # 'Ч' + 200: 54, # 'Ш' + 201: 57, # 'Щ' + 202: 61, # 'Ъ' + 203: 239, # 'Ы' + 204: 67, # 'Ь' + 205: 240, # 'Э' + 206: 60, # 'Ю' + 207: 56, # 'Я' + 208: 1, # 'а' + 209: 18, # 'б' + 210: 9, # 'в' + 211: 20, # 'г' + 212: 11, # 'д' + 213: 3, # 'е' + 214: 23, # 'ж' + 215: 15, # 'з' + 216: 2, # 'и' + 217: 26, # 'й' + 218: 12, # 'к' + 219: 10, # 'л' + 220: 14, # 'м' + 221: 6, # 'н' + 222: 4, # 'о' + 223: 13, # 'п' + 224: 7, # 'р' + 225: 8, # 'с' + 226: 5, # 'т' + 227: 19, # 'у' + 228: 29, # 'ф' + 229: 25, # 'х' + 230: 22, # 'ц' + 231: 21, # 'ч' + 232: 27, # 'ш' + 233: 24, # 'щ' + 234: 17, # 'ъ' + 235: 75, # 'ы' + 236: 52, # 'ь' + 237: 241, # 'э' + 238: 42, # 'ю' + 239: 16, # 'я' + 240: 62, # '№' + 241: 242, # 'ё' + 242: 243, # 'ђ' + 243: 244, # 'ѓ' + 244: 58, # 'є' + 245: 245, # 'ѕ' + 246: 98, # 'і' + 247: 246, # 'ї' + 248: 247, # 'ј' + 249: 248, # 'љ' + 250: 249, # 'њ' + 251: 250, # 'ћ' + 252: 251, # 'ќ' + 253: 91, # '§' + 254: 252, # 'ў' + 255: 253, # 'џ' } -ISO_8859_5_BULGARIAN_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-5', - language='Bulgarian', - char_to_order_map=ISO_8859_5_BULGARIAN_CHAR_TO_ORDER, - language_model=BULGARIAN_LANG_MODEL, - typical_positive_ratio=0.969392, - keep_ascii_letters=False, - alphabet='АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя') +ISO_8859_5_BULGARIAN_MODEL = SingleByteCharSetModel( + charset_name="ISO-8859-5", + language="Bulgarian", + char_to_order_map=ISO_8859_5_BULGARIAN_CHAR_TO_ORDER, + language_model=BULGARIAN_LANG_MODEL, + typical_positive_ratio=0.969392, + keep_ascii_letters=False, + alphabet="АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя", +) WINDOWS_1251_BULGARIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 77, # 'A' - 66: 90, # 'B' - 67: 99, # 'C' - 68: 100, # 'D' - 69: 72, # 'E' - 70: 109, # 'F' - 71: 107, # 'G' - 72: 101, # 'H' - 73: 79, # 'I' - 74: 185, # 'J' - 75: 81, # 'K' - 76: 102, # 'L' - 77: 76, # 'M' - 78: 94, # 'N' - 79: 82, # 'O' - 80: 110, # 'P' - 81: 186, # 'Q' - 82: 108, # 'R' - 83: 91, # 'S' - 84: 74, # 'T' - 85: 119, # 'U' - 86: 84, # 'V' - 87: 96, # 'W' - 88: 111, # 'X' - 89: 187, # 'Y' - 90: 115, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 65, # 'a' - 98: 69, # 'b' - 99: 70, # 'c' - 100: 66, # 'd' - 101: 63, # 'e' - 102: 68, # 'f' - 103: 112, # 'g' - 104: 103, # 'h' - 105: 92, # 'i' - 106: 194, # 'j' - 107: 104, # 'k' - 108: 95, # 'l' - 109: 86, # 'm' - 110: 87, # 'n' - 111: 71, # 'o' - 112: 116, # 'p' - 113: 195, # 'q' - 114: 85, # 'r' - 115: 93, # 's' - 116: 97, # 't' - 117: 113, # 'u' - 118: 196, # 'v' - 119: 197, # 'w' - 120: 198, # 'x' - 121: 199, # 'y' - 122: 200, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 206, # 'Ђ' - 129: 207, # 'Ѓ' - 130: 208, # '‚' - 131: 209, # 'ѓ' - 132: 210, # '„' - 133: 211, # '…' - 134: 212, # '†' - 135: 213, # '‡' - 136: 120, # '€' - 137: 214, # '‰' - 138: 215, # 'Љ' - 139: 216, # '‹' - 140: 217, # 'Њ' - 141: 218, # 'Ќ' - 142: 219, # 'Ћ' - 143: 220, # 'Џ' - 144: 221, # 'ђ' - 145: 78, # '‘' - 146: 64, # '’' - 147: 83, # '“' - 148: 121, # '”' - 149: 98, # '•' - 150: 117, # '–' - 151: 105, # '—' - 152: 222, # None - 153: 223, # '™' - 154: 224, # 'љ' - 155: 225, # '›' - 156: 226, # 'њ' - 157: 227, # 'ќ' - 158: 228, # 'ћ' - 159: 229, # 'џ' - 160: 88, # '\xa0' - 161: 230, # 'Ў' - 162: 231, # 'ў' - 163: 232, # 'Ј' - 164: 233, # '¤' - 165: 122, # 'Ґ' - 166: 89, # '¦' - 167: 106, # '§' - 168: 234, # 'Ё' - 169: 235, # '©' - 170: 236, # 'Є' - 171: 237, # '«' - 172: 238, # '¬' - 173: 45, # '\xad' - 174: 239, # '®' - 175: 240, # 'Ї' - 176: 73, # '°' - 177: 80, # '±' - 178: 118, # 'І' - 179: 114, # 'і' - 180: 241, # 'ґ' - 181: 242, # 'µ' - 182: 243, # '¶' - 183: 244, # '·' - 184: 245, # 'ё' - 185: 62, # '№' - 186: 58, # 'є' - 187: 246, # '»' - 188: 247, # 'ј' - 189: 248, # 'Ѕ' - 190: 249, # 'ѕ' - 191: 250, # 'ї' - 192: 31, # 'А' - 193: 32, # 'Б' - 194: 35, # 'В' - 195: 43, # 'Г' - 196: 37, # 'Д' - 197: 44, # 'Е' - 198: 55, # 'Ж' - 199: 47, # 'З' - 200: 40, # 'И' - 201: 59, # 'Й' - 202: 33, # 'К' - 203: 46, # 'Л' - 204: 38, # 'М' - 205: 36, # 'Н' - 206: 41, # 'О' - 207: 30, # 'П' - 208: 39, # 'Р' - 209: 28, # 'С' - 210: 34, # 'Т' - 211: 51, # 'У' - 212: 48, # 'Ф' - 213: 49, # 'Х' - 214: 53, # 'Ц' - 215: 50, # 'Ч' - 216: 54, # 'Ш' - 217: 57, # 'Щ' - 218: 61, # 'Ъ' - 219: 251, # 'Ы' - 220: 67, # 'Ь' - 221: 252, # 'Э' - 222: 60, # 'Ю' - 223: 56, # 'Я' - 224: 1, # 'а' - 225: 18, # 'б' - 226: 9, # 'в' - 227: 20, # 'г' - 228: 11, # 'д' - 229: 3, # 'е' - 230: 23, # 'ж' - 231: 15, # 'з' - 232: 2, # 'и' - 233: 26, # 'й' - 234: 12, # 'к' - 235: 10, # 'л' - 236: 14, # 'м' - 237: 6, # 'н' - 238: 4, # 'о' - 239: 13, # 'п' - 240: 7, # 'р' - 241: 8, # 'с' - 242: 5, # 'т' - 243: 19, # 'у' - 244: 29, # 'ф' - 245: 25, # 'х' - 246: 22, # 'ц' - 247: 21, # 'ч' - 248: 27, # 'ш' - 249: 24, # 'щ' - 250: 17, # 'ъ' - 251: 75, # 'ы' - 252: 52, # 'ь' - 253: 253, # 'э' - 254: 42, # 'ю' - 255: 16, # 'я' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 77, # 'A' + 66: 90, # 'B' + 67: 99, # 'C' + 68: 100, # 'D' + 69: 72, # 'E' + 70: 109, # 'F' + 71: 107, # 'G' + 72: 101, # 'H' + 73: 79, # 'I' + 74: 185, # 'J' + 75: 81, # 'K' + 76: 102, # 'L' + 77: 76, # 'M' + 78: 94, # 'N' + 79: 82, # 'O' + 80: 110, # 'P' + 81: 186, # 'Q' + 82: 108, # 'R' + 83: 91, # 'S' + 84: 74, # 'T' + 85: 119, # 'U' + 86: 84, # 'V' + 87: 96, # 'W' + 88: 111, # 'X' + 89: 187, # 'Y' + 90: 115, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 65, # 'a' + 98: 69, # 'b' + 99: 70, # 'c' + 100: 66, # 'd' + 101: 63, # 'e' + 102: 68, # 'f' + 103: 112, # 'g' + 104: 103, # 'h' + 105: 92, # 'i' + 106: 194, # 'j' + 107: 104, # 'k' + 108: 95, # 'l' + 109: 86, # 'm' + 110: 87, # 'n' + 111: 71, # 'o' + 112: 116, # 'p' + 113: 195, # 'q' + 114: 85, # 'r' + 115: 93, # 's' + 116: 97, # 't' + 117: 113, # 'u' + 118: 196, # 'v' + 119: 197, # 'w' + 120: 198, # 'x' + 121: 199, # 'y' + 122: 200, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 206, # 'Ђ' + 129: 207, # 'Ѓ' + 130: 208, # '‚' + 131: 209, # 'ѓ' + 132: 210, # '„' + 133: 211, # '…' + 134: 212, # '†' + 135: 213, # '‡' + 136: 120, # '€' + 137: 214, # '‰' + 138: 215, # 'Љ' + 139: 216, # '‹' + 140: 217, # 'Њ' + 141: 218, # 'Ќ' + 142: 219, # 'Ћ' + 143: 220, # 'Џ' + 144: 221, # 'ђ' + 145: 78, # '‘' + 146: 64, # '’' + 147: 83, # '“' + 148: 121, # '”' + 149: 98, # '•' + 150: 117, # '–' + 151: 105, # '—' + 152: 222, # None + 153: 223, # '™' + 154: 224, # 'љ' + 155: 225, # '›' + 156: 226, # 'њ' + 157: 227, # 'ќ' + 158: 228, # 'ћ' + 159: 229, # 'џ' + 160: 88, # '\xa0' + 161: 230, # 'Ў' + 162: 231, # 'ў' + 163: 232, # 'Ј' + 164: 233, # '¤' + 165: 122, # 'Ґ' + 166: 89, # '¦' + 167: 106, # '§' + 168: 234, # 'Ё' + 169: 235, # '©' + 170: 236, # 'Є' + 171: 237, # '«' + 172: 238, # '¬' + 173: 45, # '\xad' + 174: 239, # '®' + 175: 240, # 'Ї' + 176: 73, # '°' + 177: 80, # '±' + 178: 118, # 'І' + 179: 114, # 'і' + 180: 241, # 'ґ' + 181: 242, # 'µ' + 182: 243, # '¶' + 183: 244, # '·' + 184: 245, # 'ё' + 185: 62, # '№' + 186: 58, # 'є' + 187: 246, # '»' + 188: 247, # 'ј' + 189: 248, # 'Ѕ' + 190: 249, # 'ѕ' + 191: 250, # 'ї' + 192: 31, # 'А' + 193: 32, # 'Б' + 194: 35, # 'В' + 195: 43, # 'Г' + 196: 37, # 'Д' + 197: 44, # 'Е' + 198: 55, # 'Ж' + 199: 47, # 'З' + 200: 40, # 'И' + 201: 59, # 'Й' + 202: 33, # 'К' + 203: 46, # 'Л' + 204: 38, # 'М' + 205: 36, # 'Н' + 206: 41, # 'О' + 207: 30, # 'П' + 208: 39, # 'Р' + 209: 28, # 'С' + 210: 34, # 'Т' + 211: 51, # 'У' + 212: 48, # 'Ф' + 213: 49, # 'Х' + 214: 53, # 'Ц' + 215: 50, # 'Ч' + 216: 54, # 'Ш' + 217: 57, # 'Щ' + 218: 61, # 'Ъ' + 219: 251, # 'Ы' + 220: 67, # 'Ь' + 221: 252, # 'Э' + 222: 60, # 'Ю' + 223: 56, # 'Я' + 224: 1, # 'а' + 225: 18, # 'б' + 226: 9, # 'в' + 227: 20, # 'г' + 228: 11, # 'д' + 229: 3, # 'е' + 230: 23, # 'ж' + 231: 15, # 'з' + 232: 2, # 'и' + 233: 26, # 'й' + 234: 12, # 'к' + 235: 10, # 'л' + 236: 14, # 'м' + 237: 6, # 'н' + 238: 4, # 'о' + 239: 13, # 'п' + 240: 7, # 'р' + 241: 8, # 'с' + 242: 5, # 'т' + 243: 19, # 'у' + 244: 29, # 'ф' + 245: 25, # 'х' + 246: 22, # 'ц' + 247: 21, # 'ч' + 248: 27, # 'ш' + 249: 24, # 'щ' + 250: 17, # 'ъ' + 251: 75, # 'ы' + 252: 52, # 'ь' + 253: 253, # 'э' + 254: 42, # 'ю' + 255: 16, # 'я' } -WINDOWS_1251_BULGARIAN_MODEL = SingleByteCharSetModel(charset_name='windows-1251', - language='Bulgarian', - char_to_order_map=WINDOWS_1251_BULGARIAN_CHAR_TO_ORDER, - language_model=BULGARIAN_LANG_MODEL, - typical_positive_ratio=0.969392, - keep_ascii_letters=False, - alphabet='АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя') - +WINDOWS_1251_BULGARIAN_MODEL = SingleByteCharSetModel( + charset_name="windows-1251", + language="Bulgarian", + char_to_order_map=WINDOWS_1251_BULGARIAN_CHAR_TO_ORDER, + language_model=BULGARIAN_LANG_MODEL, + typical_positive_ratio=0.969392, + keep_ascii_letters=False, + alphabet="АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя", +) diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py index d99528ed..cfb8639e 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py @@ -1,9 +1,5 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- - from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - # 3: Positive # 2: Likely # 1: Unlikely @@ -3863,536 +3859,539 @@ GREEK_LANG_MODEL = { # Character Mapping Table(s): WINDOWS_1253_GREEK_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 82, # 'A' - 66: 100, # 'B' - 67: 104, # 'C' - 68: 94, # 'D' - 69: 98, # 'E' - 70: 101, # 'F' - 71: 116, # 'G' - 72: 102, # 'H' - 73: 111, # 'I' - 74: 187, # 'J' - 75: 117, # 'K' - 76: 92, # 'L' - 77: 88, # 'M' - 78: 113, # 'N' - 79: 85, # 'O' - 80: 79, # 'P' - 81: 118, # 'Q' - 82: 105, # 'R' - 83: 83, # 'S' - 84: 67, # 'T' - 85: 114, # 'U' - 86: 119, # 'V' - 87: 95, # 'W' - 88: 99, # 'X' - 89: 109, # 'Y' - 90: 188, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 72, # 'a' - 98: 70, # 'b' - 99: 80, # 'c' - 100: 81, # 'd' - 101: 60, # 'e' - 102: 96, # 'f' - 103: 93, # 'g' - 104: 89, # 'h' - 105: 68, # 'i' - 106: 120, # 'j' - 107: 97, # 'k' - 108: 77, # 'l' - 109: 86, # 'm' - 110: 69, # 'n' - 111: 55, # 'o' - 112: 78, # 'p' - 113: 115, # 'q' - 114: 65, # 'r' - 115: 66, # 's' - 116: 58, # 't' - 117: 76, # 'u' - 118: 106, # 'v' - 119: 103, # 'w' - 120: 87, # 'x' - 121: 107, # 'y' - 122: 112, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 255, # '€' - 129: 255, # None - 130: 255, # '‚' - 131: 255, # 'ƒ' - 132: 255, # '„' - 133: 255, # '…' - 134: 255, # '†' - 135: 255, # '‡' - 136: 255, # None - 137: 255, # '‰' - 138: 255, # None - 139: 255, # '‹' - 140: 255, # None - 141: 255, # None - 142: 255, # None - 143: 255, # None - 144: 255, # None - 145: 255, # '‘' - 146: 255, # '’' - 147: 255, # '“' - 148: 255, # '”' - 149: 255, # '•' - 150: 255, # '–' - 151: 255, # '—' - 152: 255, # None - 153: 255, # '™' - 154: 255, # None - 155: 255, # '›' - 156: 255, # None - 157: 255, # None - 158: 255, # None - 159: 255, # None - 160: 253, # '\xa0' - 161: 233, # '΅' - 162: 61, # 'Ά' - 163: 253, # '£' - 164: 253, # '¤' - 165: 253, # '¥' - 166: 253, # '¦' - 167: 253, # '§' - 168: 253, # '¨' - 169: 253, # '©' - 170: 253, # None - 171: 253, # '«' - 172: 253, # '¬' - 173: 74, # '\xad' - 174: 253, # '®' - 175: 253, # '―' - 176: 253, # '°' - 177: 253, # '±' - 178: 253, # '²' - 179: 253, # '³' - 180: 247, # '΄' - 181: 253, # 'µ' - 182: 253, # '¶' - 183: 36, # '·' - 184: 46, # 'Έ' - 185: 71, # 'Ή' - 186: 73, # 'Ί' - 187: 253, # '»' - 188: 54, # 'Ό' - 189: 253, # '½' - 190: 108, # 'Ύ' - 191: 123, # 'Ώ' - 192: 110, # 'ΐ' - 193: 31, # 'Α' - 194: 51, # 'Β' - 195: 43, # 'Γ' - 196: 41, # 'Δ' - 197: 34, # 'Ε' - 198: 91, # 'Ζ' - 199: 40, # 'Η' - 200: 52, # 'Θ' - 201: 47, # 'Ι' - 202: 44, # 'Κ' - 203: 53, # 'Λ' - 204: 38, # 'Μ' - 205: 49, # 'Ν' - 206: 59, # 'Ξ' - 207: 39, # 'Ο' - 208: 35, # 'Π' - 209: 48, # 'Ρ' - 210: 250, # None - 211: 37, # 'Σ' - 212: 33, # 'Τ' - 213: 45, # 'Υ' - 214: 56, # 'Φ' - 215: 50, # 'Χ' - 216: 84, # 'Ψ' - 217: 57, # 'Ω' - 218: 120, # 'Ϊ' - 219: 121, # 'Ϋ' - 220: 17, # 'ά' - 221: 18, # 'έ' - 222: 22, # 'ή' - 223: 15, # 'ί' - 224: 124, # 'ΰ' - 225: 1, # 'α' - 226: 29, # 'β' - 227: 20, # 'γ' - 228: 21, # 'δ' - 229: 3, # 'ε' - 230: 32, # 'ζ' - 231: 13, # 'η' - 232: 25, # 'θ' - 233: 5, # 'ι' - 234: 11, # 'κ' - 235: 16, # 'λ' - 236: 10, # 'μ' - 237: 6, # 'ν' - 238: 30, # 'ξ' - 239: 4, # 'ο' - 240: 9, # 'π' - 241: 8, # 'ρ' - 242: 14, # 'ς' - 243: 7, # 'σ' - 244: 2, # 'τ' - 245: 12, # 'υ' - 246: 28, # 'φ' - 247: 23, # 'χ' - 248: 42, # 'ψ' - 249: 24, # 'ω' - 250: 64, # 'ϊ' - 251: 75, # 'ϋ' - 252: 19, # 'ό' - 253: 26, # 'ύ' - 254: 27, # 'ώ' - 255: 253, # None + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 82, # 'A' + 66: 100, # 'B' + 67: 104, # 'C' + 68: 94, # 'D' + 69: 98, # 'E' + 70: 101, # 'F' + 71: 116, # 'G' + 72: 102, # 'H' + 73: 111, # 'I' + 74: 187, # 'J' + 75: 117, # 'K' + 76: 92, # 'L' + 77: 88, # 'M' + 78: 113, # 'N' + 79: 85, # 'O' + 80: 79, # 'P' + 81: 118, # 'Q' + 82: 105, # 'R' + 83: 83, # 'S' + 84: 67, # 'T' + 85: 114, # 'U' + 86: 119, # 'V' + 87: 95, # 'W' + 88: 99, # 'X' + 89: 109, # 'Y' + 90: 188, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 72, # 'a' + 98: 70, # 'b' + 99: 80, # 'c' + 100: 81, # 'd' + 101: 60, # 'e' + 102: 96, # 'f' + 103: 93, # 'g' + 104: 89, # 'h' + 105: 68, # 'i' + 106: 120, # 'j' + 107: 97, # 'k' + 108: 77, # 'l' + 109: 86, # 'm' + 110: 69, # 'n' + 111: 55, # 'o' + 112: 78, # 'p' + 113: 115, # 'q' + 114: 65, # 'r' + 115: 66, # 's' + 116: 58, # 't' + 117: 76, # 'u' + 118: 106, # 'v' + 119: 103, # 'w' + 120: 87, # 'x' + 121: 107, # 'y' + 122: 112, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 255, # '€' + 129: 255, # None + 130: 255, # '‚' + 131: 255, # 'ƒ' + 132: 255, # '„' + 133: 255, # '…' + 134: 255, # '†' + 135: 255, # '‡' + 136: 255, # None + 137: 255, # '‰' + 138: 255, # None + 139: 255, # '‹' + 140: 255, # None + 141: 255, # None + 142: 255, # None + 143: 255, # None + 144: 255, # None + 145: 255, # '‘' + 146: 255, # '’' + 147: 255, # '“' + 148: 255, # '”' + 149: 255, # '•' + 150: 255, # '–' + 151: 255, # '—' + 152: 255, # None + 153: 255, # '™' + 154: 255, # None + 155: 255, # '›' + 156: 255, # None + 157: 255, # None + 158: 255, # None + 159: 255, # None + 160: 253, # '\xa0' + 161: 233, # '΅' + 162: 61, # 'Ά' + 163: 253, # '£' + 164: 253, # '¤' + 165: 253, # '¥' + 166: 253, # '¦' + 167: 253, # '§' + 168: 253, # '¨' + 169: 253, # '©' + 170: 253, # None + 171: 253, # '«' + 172: 253, # '¬' + 173: 74, # '\xad' + 174: 253, # '®' + 175: 253, # '―' + 176: 253, # '°' + 177: 253, # '±' + 178: 253, # '²' + 179: 253, # '³' + 180: 247, # '΄' + 181: 253, # 'µ' + 182: 253, # '¶' + 183: 36, # '·' + 184: 46, # 'Έ' + 185: 71, # 'Ή' + 186: 73, # 'Ί' + 187: 253, # '»' + 188: 54, # 'Ό' + 189: 253, # '½' + 190: 108, # 'Ύ' + 191: 123, # 'Ώ' + 192: 110, # 'ΐ' + 193: 31, # 'Α' + 194: 51, # 'Β' + 195: 43, # 'Γ' + 196: 41, # 'Δ' + 197: 34, # 'Ε' + 198: 91, # 'Ζ' + 199: 40, # 'Η' + 200: 52, # 'Θ' + 201: 47, # 'Ι' + 202: 44, # 'Κ' + 203: 53, # 'Λ' + 204: 38, # 'Μ' + 205: 49, # 'Ν' + 206: 59, # 'Ξ' + 207: 39, # 'Ο' + 208: 35, # 'Π' + 209: 48, # 'Ρ' + 210: 250, # None + 211: 37, # 'Σ' + 212: 33, # 'Τ' + 213: 45, # 'Υ' + 214: 56, # 'Φ' + 215: 50, # 'Χ' + 216: 84, # 'Ψ' + 217: 57, # 'Ω' + 218: 120, # 'Ϊ' + 219: 121, # 'Ϋ' + 220: 17, # 'ά' + 221: 18, # 'έ' + 222: 22, # 'ή' + 223: 15, # 'ί' + 224: 124, # 'ΰ' + 225: 1, # 'α' + 226: 29, # 'β' + 227: 20, # 'γ' + 228: 21, # 'δ' + 229: 3, # 'ε' + 230: 32, # 'ζ' + 231: 13, # 'η' + 232: 25, # 'θ' + 233: 5, # 'ι' + 234: 11, # 'κ' + 235: 16, # 'λ' + 236: 10, # 'μ' + 237: 6, # 'ν' + 238: 30, # 'ξ' + 239: 4, # 'ο' + 240: 9, # 'π' + 241: 8, # 'ρ' + 242: 14, # 'ς' + 243: 7, # 'σ' + 244: 2, # 'τ' + 245: 12, # 'υ' + 246: 28, # 'φ' + 247: 23, # 'χ' + 248: 42, # 'ψ' + 249: 24, # 'ω' + 250: 64, # 'ϊ' + 251: 75, # 'ϋ' + 252: 19, # 'ό' + 253: 26, # 'ύ' + 254: 27, # 'ώ' + 255: 253, # None } -WINDOWS_1253_GREEK_MODEL = SingleByteCharSetModel(charset_name='windows-1253', - language='Greek', - char_to_order_map=WINDOWS_1253_GREEK_CHAR_TO_ORDER, - language_model=GREEK_LANG_MODEL, - typical_positive_ratio=0.982851, - keep_ascii_letters=False, - alphabet='ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ') +WINDOWS_1253_GREEK_MODEL = SingleByteCharSetModel( + charset_name="windows-1253", + language="Greek", + char_to_order_map=WINDOWS_1253_GREEK_CHAR_TO_ORDER, + language_model=GREEK_LANG_MODEL, + typical_positive_ratio=0.982851, + keep_ascii_letters=False, + alphabet="ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ", +) ISO_8859_7_GREEK_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 82, # 'A' - 66: 100, # 'B' - 67: 104, # 'C' - 68: 94, # 'D' - 69: 98, # 'E' - 70: 101, # 'F' - 71: 116, # 'G' - 72: 102, # 'H' - 73: 111, # 'I' - 74: 187, # 'J' - 75: 117, # 'K' - 76: 92, # 'L' - 77: 88, # 'M' - 78: 113, # 'N' - 79: 85, # 'O' - 80: 79, # 'P' - 81: 118, # 'Q' - 82: 105, # 'R' - 83: 83, # 'S' - 84: 67, # 'T' - 85: 114, # 'U' - 86: 119, # 'V' - 87: 95, # 'W' - 88: 99, # 'X' - 89: 109, # 'Y' - 90: 188, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 72, # 'a' - 98: 70, # 'b' - 99: 80, # 'c' - 100: 81, # 'd' - 101: 60, # 'e' - 102: 96, # 'f' - 103: 93, # 'g' - 104: 89, # 'h' - 105: 68, # 'i' - 106: 120, # 'j' - 107: 97, # 'k' - 108: 77, # 'l' - 109: 86, # 'm' - 110: 69, # 'n' - 111: 55, # 'o' - 112: 78, # 'p' - 113: 115, # 'q' - 114: 65, # 'r' - 115: 66, # 's' - 116: 58, # 't' - 117: 76, # 'u' - 118: 106, # 'v' - 119: 103, # 'w' - 120: 87, # 'x' - 121: 107, # 'y' - 122: 112, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 255, # '\x80' - 129: 255, # '\x81' - 130: 255, # '\x82' - 131: 255, # '\x83' - 132: 255, # '\x84' - 133: 255, # '\x85' - 134: 255, # '\x86' - 135: 255, # '\x87' - 136: 255, # '\x88' - 137: 255, # '\x89' - 138: 255, # '\x8a' - 139: 255, # '\x8b' - 140: 255, # '\x8c' - 141: 255, # '\x8d' - 142: 255, # '\x8e' - 143: 255, # '\x8f' - 144: 255, # '\x90' - 145: 255, # '\x91' - 146: 255, # '\x92' - 147: 255, # '\x93' - 148: 255, # '\x94' - 149: 255, # '\x95' - 150: 255, # '\x96' - 151: 255, # '\x97' - 152: 255, # '\x98' - 153: 255, # '\x99' - 154: 255, # '\x9a' - 155: 255, # '\x9b' - 156: 255, # '\x9c' - 157: 255, # '\x9d' - 158: 255, # '\x9e' - 159: 255, # '\x9f' - 160: 253, # '\xa0' - 161: 233, # '‘' - 162: 90, # '’' - 163: 253, # '£' - 164: 253, # '€' - 165: 253, # '₯' - 166: 253, # '¦' - 167: 253, # '§' - 168: 253, # '¨' - 169: 253, # '©' - 170: 253, # 'ͺ' - 171: 253, # '«' - 172: 253, # '¬' - 173: 74, # '\xad' - 174: 253, # None - 175: 253, # '―' - 176: 253, # '°' - 177: 253, # '±' - 178: 253, # '²' - 179: 253, # '³' - 180: 247, # '΄' - 181: 248, # '΅' - 182: 61, # 'Ά' - 183: 36, # '·' - 184: 46, # 'Έ' - 185: 71, # 'Ή' - 186: 73, # 'Ί' - 187: 253, # '»' - 188: 54, # 'Ό' - 189: 253, # '½' - 190: 108, # 'Ύ' - 191: 123, # 'Ώ' - 192: 110, # 'ΐ' - 193: 31, # 'Α' - 194: 51, # 'Β' - 195: 43, # 'Γ' - 196: 41, # 'Δ' - 197: 34, # 'Ε' - 198: 91, # 'Ζ' - 199: 40, # 'Η' - 200: 52, # 'Θ' - 201: 47, # 'Ι' - 202: 44, # 'Κ' - 203: 53, # 'Λ' - 204: 38, # 'Μ' - 205: 49, # 'Ν' - 206: 59, # 'Ξ' - 207: 39, # 'Ο' - 208: 35, # 'Π' - 209: 48, # 'Ρ' - 210: 250, # None - 211: 37, # 'Σ' - 212: 33, # 'Τ' - 213: 45, # 'Υ' - 214: 56, # 'Φ' - 215: 50, # 'Χ' - 216: 84, # 'Ψ' - 217: 57, # 'Ω' - 218: 120, # 'Ϊ' - 219: 121, # 'Ϋ' - 220: 17, # 'ά' - 221: 18, # 'έ' - 222: 22, # 'ή' - 223: 15, # 'ί' - 224: 124, # 'ΰ' - 225: 1, # 'α' - 226: 29, # 'β' - 227: 20, # 'γ' - 228: 21, # 'δ' - 229: 3, # 'ε' - 230: 32, # 'ζ' - 231: 13, # 'η' - 232: 25, # 'θ' - 233: 5, # 'ι' - 234: 11, # 'κ' - 235: 16, # 'λ' - 236: 10, # 'μ' - 237: 6, # 'ν' - 238: 30, # 'ξ' - 239: 4, # 'ο' - 240: 9, # 'π' - 241: 8, # 'ρ' - 242: 14, # 'ς' - 243: 7, # 'σ' - 244: 2, # 'τ' - 245: 12, # 'υ' - 246: 28, # 'φ' - 247: 23, # 'χ' - 248: 42, # 'ψ' - 249: 24, # 'ω' - 250: 64, # 'ϊ' - 251: 75, # 'ϋ' - 252: 19, # 'ό' - 253: 26, # 'ύ' - 254: 27, # 'ώ' - 255: 253, # None + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 82, # 'A' + 66: 100, # 'B' + 67: 104, # 'C' + 68: 94, # 'D' + 69: 98, # 'E' + 70: 101, # 'F' + 71: 116, # 'G' + 72: 102, # 'H' + 73: 111, # 'I' + 74: 187, # 'J' + 75: 117, # 'K' + 76: 92, # 'L' + 77: 88, # 'M' + 78: 113, # 'N' + 79: 85, # 'O' + 80: 79, # 'P' + 81: 118, # 'Q' + 82: 105, # 'R' + 83: 83, # 'S' + 84: 67, # 'T' + 85: 114, # 'U' + 86: 119, # 'V' + 87: 95, # 'W' + 88: 99, # 'X' + 89: 109, # 'Y' + 90: 188, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 72, # 'a' + 98: 70, # 'b' + 99: 80, # 'c' + 100: 81, # 'd' + 101: 60, # 'e' + 102: 96, # 'f' + 103: 93, # 'g' + 104: 89, # 'h' + 105: 68, # 'i' + 106: 120, # 'j' + 107: 97, # 'k' + 108: 77, # 'l' + 109: 86, # 'm' + 110: 69, # 'n' + 111: 55, # 'o' + 112: 78, # 'p' + 113: 115, # 'q' + 114: 65, # 'r' + 115: 66, # 's' + 116: 58, # 't' + 117: 76, # 'u' + 118: 106, # 'v' + 119: 103, # 'w' + 120: 87, # 'x' + 121: 107, # 'y' + 122: 112, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 255, # '\x80' + 129: 255, # '\x81' + 130: 255, # '\x82' + 131: 255, # '\x83' + 132: 255, # '\x84' + 133: 255, # '\x85' + 134: 255, # '\x86' + 135: 255, # '\x87' + 136: 255, # '\x88' + 137: 255, # '\x89' + 138: 255, # '\x8a' + 139: 255, # '\x8b' + 140: 255, # '\x8c' + 141: 255, # '\x8d' + 142: 255, # '\x8e' + 143: 255, # '\x8f' + 144: 255, # '\x90' + 145: 255, # '\x91' + 146: 255, # '\x92' + 147: 255, # '\x93' + 148: 255, # '\x94' + 149: 255, # '\x95' + 150: 255, # '\x96' + 151: 255, # '\x97' + 152: 255, # '\x98' + 153: 255, # '\x99' + 154: 255, # '\x9a' + 155: 255, # '\x9b' + 156: 255, # '\x9c' + 157: 255, # '\x9d' + 158: 255, # '\x9e' + 159: 255, # '\x9f' + 160: 253, # '\xa0' + 161: 233, # '‘' + 162: 90, # '’' + 163: 253, # '£' + 164: 253, # '€' + 165: 253, # '₯' + 166: 253, # '¦' + 167: 253, # '§' + 168: 253, # '¨' + 169: 253, # '©' + 170: 253, # 'ͺ' + 171: 253, # '«' + 172: 253, # '¬' + 173: 74, # '\xad' + 174: 253, # None + 175: 253, # '―' + 176: 253, # '°' + 177: 253, # '±' + 178: 253, # '²' + 179: 253, # '³' + 180: 247, # '΄' + 181: 248, # '΅' + 182: 61, # 'Ά' + 183: 36, # '·' + 184: 46, # 'Έ' + 185: 71, # 'Ή' + 186: 73, # 'Ί' + 187: 253, # '»' + 188: 54, # 'Ό' + 189: 253, # '½' + 190: 108, # 'Ύ' + 191: 123, # 'Ώ' + 192: 110, # 'ΐ' + 193: 31, # 'Α' + 194: 51, # 'Β' + 195: 43, # 'Γ' + 196: 41, # 'Δ' + 197: 34, # 'Ε' + 198: 91, # 'Ζ' + 199: 40, # 'Η' + 200: 52, # 'Θ' + 201: 47, # 'Ι' + 202: 44, # 'Κ' + 203: 53, # 'Λ' + 204: 38, # 'Μ' + 205: 49, # 'Ν' + 206: 59, # 'Ξ' + 207: 39, # 'Ο' + 208: 35, # 'Π' + 209: 48, # 'Ρ' + 210: 250, # None + 211: 37, # 'Σ' + 212: 33, # 'Τ' + 213: 45, # 'Υ' + 214: 56, # 'Φ' + 215: 50, # 'Χ' + 216: 84, # 'Ψ' + 217: 57, # 'Ω' + 218: 120, # 'Ϊ' + 219: 121, # 'Ϋ' + 220: 17, # 'ά' + 221: 18, # 'έ' + 222: 22, # 'ή' + 223: 15, # 'ί' + 224: 124, # 'ΰ' + 225: 1, # 'α' + 226: 29, # 'β' + 227: 20, # 'γ' + 228: 21, # 'δ' + 229: 3, # 'ε' + 230: 32, # 'ζ' + 231: 13, # 'η' + 232: 25, # 'θ' + 233: 5, # 'ι' + 234: 11, # 'κ' + 235: 16, # 'λ' + 236: 10, # 'μ' + 237: 6, # 'ν' + 238: 30, # 'ξ' + 239: 4, # 'ο' + 240: 9, # 'π' + 241: 8, # 'ρ' + 242: 14, # 'ς' + 243: 7, # 'σ' + 244: 2, # 'τ' + 245: 12, # 'υ' + 246: 28, # 'φ' + 247: 23, # 'χ' + 248: 42, # 'ψ' + 249: 24, # 'ω' + 250: 64, # 'ϊ' + 251: 75, # 'ϋ' + 252: 19, # 'ό' + 253: 26, # 'ύ' + 254: 27, # 'ώ' + 255: 253, # None } -ISO_8859_7_GREEK_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-7', - language='Greek', - char_to_order_map=ISO_8859_7_GREEK_CHAR_TO_ORDER, - language_model=GREEK_LANG_MODEL, - typical_positive_ratio=0.982851, - keep_ascii_letters=False, - alphabet='ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ') - +ISO_8859_7_GREEK_MODEL = SingleByteCharSetModel( + charset_name="ISO-8859-7", + language="Greek", + char_to_order_map=ISO_8859_7_GREEK_CHAR_TO_ORDER, + language_model=GREEK_LANG_MODEL, + typical_positive_ratio=0.982851, + keep_ascii_letters=False, + alphabet="ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ", +) diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py index 484c652a..56d29758 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py @@ -1,9 +1,5 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- - from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - # 3: Positive # 2: Likely # 1: Unlikely @@ -4115,269 +4111,270 @@ HEBREW_LANG_MODEL = { # Character Mapping Table(s): WINDOWS_1255_HEBREW_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 69, # 'A' - 66: 91, # 'B' - 67: 79, # 'C' - 68: 80, # 'D' - 69: 92, # 'E' - 70: 89, # 'F' - 71: 97, # 'G' - 72: 90, # 'H' - 73: 68, # 'I' - 74: 111, # 'J' - 75: 112, # 'K' - 76: 82, # 'L' - 77: 73, # 'M' - 78: 95, # 'N' - 79: 85, # 'O' - 80: 78, # 'P' - 81: 121, # 'Q' - 82: 86, # 'R' - 83: 71, # 'S' - 84: 67, # 'T' - 85: 102, # 'U' - 86: 107, # 'V' - 87: 84, # 'W' - 88: 114, # 'X' - 89: 103, # 'Y' - 90: 115, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 50, # 'a' - 98: 74, # 'b' - 99: 60, # 'c' - 100: 61, # 'd' - 101: 42, # 'e' - 102: 76, # 'f' - 103: 70, # 'g' - 104: 64, # 'h' - 105: 53, # 'i' - 106: 105, # 'j' - 107: 93, # 'k' - 108: 56, # 'l' - 109: 65, # 'm' - 110: 54, # 'n' - 111: 49, # 'o' - 112: 66, # 'p' - 113: 110, # 'q' - 114: 51, # 'r' - 115: 43, # 's' - 116: 44, # 't' - 117: 63, # 'u' - 118: 81, # 'v' - 119: 77, # 'w' - 120: 98, # 'x' - 121: 75, # 'y' - 122: 108, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 124, # '€' - 129: 202, # None - 130: 203, # '‚' - 131: 204, # 'ƒ' - 132: 205, # '„' - 133: 40, # '…' - 134: 58, # '†' - 135: 206, # '‡' - 136: 207, # 'ˆ' - 137: 208, # '‰' - 138: 209, # None - 139: 210, # '‹' - 140: 211, # None - 141: 212, # None - 142: 213, # None - 143: 214, # None - 144: 215, # None - 145: 83, # '‘' - 146: 52, # '’' - 147: 47, # '“' - 148: 46, # '”' - 149: 72, # '•' - 150: 32, # '–' - 151: 94, # '—' - 152: 216, # '˜' - 153: 113, # '™' - 154: 217, # None - 155: 109, # '›' - 156: 218, # None - 157: 219, # None - 158: 220, # None - 159: 221, # None - 160: 34, # '\xa0' - 161: 116, # '¡' - 162: 222, # '¢' - 163: 118, # '£' - 164: 100, # '₪' - 165: 223, # '¥' - 166: 224, # '¦' - 167: 117, # '§' - 168: 119, # '¨' - 169: 104, # '©' - 170: 125, # '×' - 171: 225, # '«' - 172: 226, # '¬' - 173: 87, # '\xad' - 174: 99, # '®' - 175: 227, # '¯' - 176: 106, # '°' - 177: 122, # '±' - 178: 123, # '²' - 179: 228, # '³' - 180: 55, # '´' - 181: 229, # 'µ' - 182: 230, # '¶' - 183: 101, # '·' - 184: 231, # '¸' - 185: 232, # '¹' - 186: 120, # '÷' - 187: 233, # '»' - 188: 48, # '¼' - 189: 39, # '½' - 190: 57, # '¾' - 191: 234, # '¿' - 192: 30, # 'ְ' - 193: 59, # 'ֱ' - 194: 41, # 'ֲ' - 195: 88, # 'ֳ' - 196: 33, # 'ִ' - 197: 37, # 'ֵ' - 198: 36, # 'ֶ' - 199: 31, # 'ַ' - 200: 29, # 'ָ' - 201: 35, # 'ֹ' - 202: 235, # None - 203: 62, # 'ֻ' - 204: 28, # 'ּ' - 205: 236, # 'ֽ' - 206: 126, # '־' - 207: 237, # 'ֿ' - 208: 238, # '׀' - 209: 38, # 'ׁ' - 210: 45, # 'ׂ' - 211: 239, # '׃' - 212: 240, # 'װ' - 213: 241, # 'ױ' - 214: 242, # 'ײ' - 215: 243, # '׳' - 216: 127, # '״' - 217: 244, # None - 218: 245, # None - 219: 246, # None - 220: 247, # None - 221: 248, # None - 222: 249, # None - 223: 250, # None - 224: 9, # 'א' - 225: 8, # 'ב' - 226: 20, # 'ג' - 227: 16, # 'ד' - 228: 3, # 'ה' - 229: 2, # 'ו' - 230: 24, # 'ז' - 231: 14, # 'ח' - 232: 22, # 'ט' - 233: 1, # 'י' - 234: 25, # 'ך' - 235: 15, # 'כ' - 236: 4, # 'ל' - 237: 11, # 'ם' - 238: 6, # 'מ' - 239: 23, # 'ן' - 240: 12, # 'נ' - 241: 19, # 'ס' - 242: 13, # 'ע' - 243: 26, # 'ף' - 244: 18, # 'פ' - 245: 27, # 'ץ' - 246: 21, # 'צ' - 247: 17, # 'ק' - 248: 7, # 'ר' - 249: 10, # 'ש' - 250: 5, # 'ת' - 251: 251, # None - 252: 252, # None - 253: 128, # '\u200e' - 254: 96, # '\u200f' - 255: 253, # None + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 69, # 'A' + 66: 91, # 'B' + 67: 79, # 'C' + 68: 80, # 'D' + 69: 92, # 'E' + 70: 89, # 'F' + 71: 97, # 'G' + 72: 90, # 'H' + 73: 68, # 'I' + 74: 111, # 'J' + 75: 112, # 'K' + 76: 82, # 'L' + 77: 73, # 'M' + 78: 95, # 'N' + 79: 85, # 'O' + 80: 78, # 'P' + 81: 121, # 'Q' + 82: 86, # 'R' + 83: 71, # 'S' + 84: 67, # 'T' + 85: 102, # 'U' + 86: 107, # 'V' + 87: 84, # 'W' + 88: 114, # 'X' + 89: 103, # 'Y' + 90: 115, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 50, # 'a' + 98: 74, # 'b' + 99: 60, # 'c' + 100: 61, # 'd' + 101: 42, # 'e' + 102: 76, # 'f' + 103: 70, # 'g' + 104: 64, # 'h' + 105: 53, # 'i' + 106: 105, # 'j' + 107: 93, # 'k' + 108: 56, # 'l' + 109: 65, # 'm' + 110: 54, # 'n' + 111: 49, # 'o' + 112: 66, # 'p' + 113: 110, # 'q' + 114: 51, # 'r' + 115: 43, # 's' + 116: 44, # 't' + 117: 63, # 'u' + 118: 81, # 'v' + 119: 77, # 'w' + 120: 98, # 'x' + 121: 75, # 'y' + 122: 108, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 124, # '€' + 129: 202, # None + 130: 203, # '‚' + 131: 204, # 'ƒ' + 132: 205, # '„' + 133: 40, # '…' + 134: 58, # '†' + 135: 206, # '‡' + 136: 207, # 'ˆ' + 137: 208, # '‰' + 138: 209, # None + 139: 210, # '‹' + 140: 211, # None + 141: 212, # None + 142: 213, # None + 143: 214, # None + 144: 215, # None + 145: 83, # '‘' + 146: 52, # '’' + 147: 47, # '“' + 148: 46, # '”' + 149: 72, # '•' + 150: 32, # '–' + 151: 94, # '—' + 152: 216, # '˜' + 153: 113, # '™' + 154: 217, # None + 155: 109, # '›' + 156: 218, # None + 157: 219, # None + 158: 220, # None + 159: 221, # None + 160: 34, # '\xa0' + 161: 116, # '¡' + 162: 222, # '¢' + 163: 118, # '£' + 164: 100, # '₪' + 165: 223, # '¥' + 166: 224, # '¦' + 167: 117, # '§' + 168: 119, # '¨' + 169: 104, # '©' + 170: 125, # '×' + 171: 225, # '«' + 172: 226, # '¬' + 173: 87, # '\xad' + 174: 99, # '®' + 175: 227, # '¯' + 176: 106, # '°' + 177: 122, # '±' + 178: 123, # '²' + 179: 228, # '³' + 180: 55, # '´' + 181: 229, # 'µ' + 182: 230, # '¶' + 183: 101, # '·' + 184: 231, # '¸' + 185: 232, # '¹' + 186: 120, # '÷' + 187: 233, # '»' + 188: 48, # '¼' + 189: 39, # '½' + 190: 57, # '¾' + 191: 234, # '¿' + 192: 30, # 'ְ' + 193: 59, # 'ֱ' + 194: 41, # 'ֲ' + 195: 88, # 'ֳ' + 196: 33, # 'ִ' + 197: 37, # 'ֵ' + 198: 36, # 'ֶ' + 199: 31, # 'ַ' + 200: 29, # 'ָ' + 201: 35, # 'ֹ' + 202: 235, # None + 203: 62, # 'ֻ' + 204: 28, # 'ּ' + 205: 236, # 'ֽ' + 206: 126, # '־' + 207: 237, # 'ֿ' + 208: 238, # '׀' + 209: 38, # 'ׁ' + 210: 45, # 'ׂ' + 211: 239, # '׃' + 212: 240, # 'װ' + 213: 241, # 'ױ' + 214: 242, # 'ײ' + 215: 243, # '׳' + 216: 127, # '״' + 217: 244, # None + 218: 245, # None + 219: 246, # None + 220: 247, # None + 221: 248, # None + 222: 249, # None + 223: 250, # None + 224: 9, # 'א' + 225: 8, # 'ב' + 226: 20, # 'ג' + 227: 16, # 'ד' + 228: 3, # 'ה' + 229: 2, # 'ו' + 230: 24, # 'ז' + 231: 14, # 'ח' + 232: 22, # 'ט' + 233: 1, # 'י' + 234: 25, # 'ך' + 235: 15, # 'כ' + 236: 4, # 'ל' + 237: 11, # 'ם' + 238: 6, # 'מ' + 239: 23, # 'ן' + 240: 12, # 'נ' + 241: 19, # 'ס' + 242: 13, # 'ע' + 243: 26, # 'ף' + 244: 18, # 'פ' + 245: 27, # 'ץ' + 246: 21, # 'צ' + 247: 17, # 'ק' + 248: 7, # 'ר' + 249: 10, # 'ש' + 250: 5, # 'ת' + 251: 251, # None + 252: 252, # None + 253: 128, # '\u200e' + 254: 96, # '\u200f' + 255: 253, # None } -WINDOWS_1255_HEBREW_MODEL = SingleByteCharSetModel(charset_name='windows-1255', - language='Hebrew', - char_to_order_map=WINDOWS_1255_HEBREW_CHAR_TO_ORDER, - language_model=HEBREW_LANG_MODEL, - typical_positive_ratio=0.984004, - keep_ascii_letters=False, - alphabet='אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ') - +WINDOWS_1255_HEBREW_MODEL = SingleByteCharSetModel( + charset_name="windows-1255", + language="Hebrew", + char_to_order_map=WINDOWS_1255_HEBREW_CHAR_TO_ORDER, + language_model=HEBREW_LANG_MODEL, + typical_positive_ratio=0.984004, + keep_ascii_letters=False, + alphabet="אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ", +) diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py index bbc5cda6..09a0d326 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py @@ -1,9 +1,5 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- - from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - # 3: Positive # 2: Likely # 1: Unlikely @@ -4115,536 +4111,539 @@ HUNGARIAN_LANG_MODEL = { # Character Mapping Table(s): WINDOWS_1250_HUNGARIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 28, # 'A' - 66: 40, # 'B' - 67: 54, # 'C' - 68: 45, # 'D' - 69: 32, # 'E' - 70: 50, # 'F' - 71: 49, # 'G' - 72: 38, # 'H' - 73: 39, # 'I' - 74: 53, # 'J' - 75: 36, # 'K' - 76: 41, # 'L' - 77: 34, # 'M' - 78: 35, # 'N' - 79: 47, # 'O' - 80: 46, # 'P' - 81: 72, # 'Q' - 82: 43, # 'R' - 83: 33, # 'S' - 84: 37, # 'T' - 85: 57, # 'U' - 86: 48, # 'V' - 87: 64, # 'W' - 88: 68, # 'X' - 89: 55, # 'Y' - 90: 52, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 2, # 'a' - 98: 18, # 'b' - 99: 26, # 'c' - 100: 17, # 'd' - 101: 1, # 'e' - 102: 27, # 'f' - 103: 12, # 'g' - 104: 20, # 'h' - 105: 9, # 'i' - 106: 22, # 'j' - 107: 7, # 'k' - 108: 6, # 'l' - 109: 13, # 'm' - 110: 4, # 'n' - 111: 8, # 'o' - 112: 23, # 'p' - 113: 67, # 'q' - 114: 10, # 'r' - 115: 5, # 's' - 116: 3, # 't' - 117: 21, # 'u' - 118: 19, # 'v' - 119: 65, # 'w' - 120: 62, # 'x' - 121: 16, # 'y' - 122: 11, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 161, # '€' - 129: 162, # None - 130: 163, # '‚' - 131: 164, # None - 132: 165, # '„' - 133: 166, # '…' - 134: 167, # '†' - 135: 168, # '‡' - 136: 169, # None - 137: 170, # '‰' - 138: 171, # 'Š' - 139: 172, # '‹' - 140: 173, # 'Ś' - 141: 174, # 'Ť' - 142: 175, # 'Ž' - 143: 176, # 'Ź' - 144: 177, # None - 145: 178, # '‘' - 146: 179, # '’' - 147: 180, # '“' - 148: 78, # '”' - 149: 181, # '•' - 150: 69, # '–' - 151: 182, # '—' - 152: 183, # None - 153: 184, # '™' - 154: 185, # 'š' - 155: 186, # '›' - 156: 187, # 'ś' - 157: 188, # 'ť' - 158: 189, # 'ž' - 159: 190, # 'ź' - 160: 191, # '\xa0' - 161: 192, # 'ˇ' - 162: 193, # '˘' - 163: 194, # 'Ł' - 164: 195, # '¤' - 165: 196, # 'Ą' - 166: 197, # '¦' - 167: 76, # '§' - 168: 198, # '¨' - 169: 199, # '©' - 170: 200, # 'Ş' - 171: 201, # '«' - 172: 202, # '¬' - 173: 203, # '\xad' - 174: 204, # '®' - 175: 205, # 'Ż' - 176: 81, # '°' - 177: 206, # '±' - 178: 207, # '˛' - 179: 208, # 'ł' - 180: 209, # '´' - 181: 210, # 'µ' - 182: 211, # '¶' - 183: 212, # '·' - 184: 213, # '¸' - 185: 214, # 'ą' - 186: 215, # 'ş' - 187: 216, # '»' - 188: 217, # 'Ľ' - 189: 218, # '˝' - 190: 219, # 'ľ' - 191: 220, # 'ż' - 192: 221, # 'Ŕ' - 193: 51, # 'Á' - 194: 83, # 'Â' - 195: 222, # 'Ă' - 196: 80, # 'Ä' - 197: 223, # 'Ĺ' - 198: 224, # 'Ć' - 199: 225, # 'Ç' - 200: 226, # 'Č' - 201: 44, # 'É' - 202: 227, # 'Ę' - 203: 228, # 'Ë' - 204: 229, # 'Ě' - 205: 61, # 'Í' - 206: 230, # 'Î' - 207: 231, # 'Ď' - 208: 232, # 'Đ' - 209: 233, # 'Ń' - 210: 234, # 'Ň' - 211: 58, # 'Ó' - 212: 235, # 'Ô' - 213: 66, # 'Ő' - 214: 59, # 'Ö' - 215: 236, # '×' - 216: 237, # 'Ř' - 217: 238, # 'Ů' - 218: 60, # 'Ú' - 219: 70, # 'Ű' - 220: 63, # 'Ü' - 221: 239, # 'Ý' - 222: 240, # 'Ţ' - 223: 241, # 'ß' - 224: 84, # 'ŕ' - 225: 14, # 'á' - 226: 75, # 'â' - 227: 242, # 'ă' - 228: 71, # 'ä' - 229: 82, # 'ĺ' - 230: 243, # 'ć' - 231: 73, # 'ç' - 232: 244, # 'č' - 233: 15, # 'é' - 234: 85, # 'ę' - 235: 79, # 'ë' - 236: 86, # 'ě' - 237: 30, # 'í' - 238: 77, # 'î' - 239: 87, # 'ď' - 240: 245, # 'đ' - 241: 246, # 'ń' - 242: 247, # 'ň' - 243: 25, # 'ó' - 244: 74, # 'ô' - 245: 42, # 'ő' - 246: 24, # 'ö' - 247: 248, # '÷' - 248: 249, # 'ř' - 249: 250, # 'ů' - 250: 31, # 'ú' - 251: 56, # 'ű' - 252: 29, # 'ü' - 253: 251, # 'ý' - 254: 252, # 'ţ' - 255: 253, # '˙' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 28, # 'A' + 66: 40, # 'B' + 67: 54, # 'C' + 68: 45, # 'D' + 69: 32, # 'E' + 70: 50, # 'F' + 71: 49, # 'G' + 72: 38, # 'H' + 73: 39, # 'I' + 74: 53, # 'J' + 75: 36, # 'K' + 76: 41, # 'L' + 77: 34, # 'M' + 78: 35, # 'N' + 79: 47, # 'O' + 80: 46, # 'P' + 81: 72, # 'Q' + 82: 43, # 'R' + 83: 33, # 'S' + 84: 37, # 'T' + 85: 57, # 'U' + 86: 48, # 'V' + 87: 64, # 'W' + 88: 68, # 'X' + 89: 55, # 'Y' + 90: 52, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 2, # 'a' + 98: 18, # 'b' + 99: 26, # 'c' + 100: 17, # 'd' + 101: 1, # 'e' + 102: 27, # 'f' + 103: 12, # 'g' + 104: 20, # 'h' + 105: 9, # 'i' + 106: 22, # 'j' + 107: 7, # 'k' + 108: 6, # 'l' + 109: 13, # 'm' + 110: 4, # 'n' + 111: 8, # 'o' + 112: 23, # 'p' + 113: 67, # 'q' + 114: 10, # 'r' + 115: 5, # 's' + 116: 3, # 't' + 117: 21, # 'u' + 118: 19, # 'v' + 119: 65, # 'w' + 120: 62, # 'x' + 121: 16, # 'y' + 122: 11, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 161, # '€' + 129: 162, # None + 130: 163, # '‚' + 131: 164, # None + 132: 165, # '„' + 133: 166, # '…' + 134: 167, # '†' + 135: 168, # '‡' + 136: 169, # None + 137: 170, # '‰' + 138: 171, # 'Š' + 139: 172, # '‹' + 140: 173, # 'Ś' + 141: 174, # 'Ť' + 142: 175, # 'Ž' + 143: 176, # 'Ź' + 144: 177, # None + 145: 178, # '‘' + 146: 179, # '’' + 147: 180, # '“' + 148: 78, # '”' + 149: 181, # '•' + 150: 69, # '–' + 151: 182, # '—' + 152: 183, # None + 153: 184, # '™' + 154: 185, # 'š' + 155: 186, # '›' + 156: 187, # 'ś' + 157: 188, # 'ť' + 158: 189, # 'ž' + 159: 190, # 'ź' + 160: 191, # '\xa0' + 161: 192, # 'ˇ' + 162: 193, # '˘' + 163: 194, # 'Ł' + 164: 195, # '¤' + 165: 196, # 'Ą' + 166: 197, # '¦' + 167: 76, # '§' + 168: 198, # '¨' + 169: 199, # '©' + 170: 200, # 'Ş' + 171: 201, # '«' + 172: 202, # '¬' + 173: 203, # '\xad' + 174: 204, # '®' + 175: 205, # 'Ż' + 176: 81, # '°' + 177: 206, # '±' + 178: 207, # '˛' + 179: 208, # 'ł' + 180: 209, # '´' + 181: 210, # 'µ' + 182: 211, # '¶' + 183: 212, # '·' + 184: 213, # '¸' + 185: 214, # 'ą' + 186: 215, # 'ş' + 187: 216, # '»' + 188: 217, # 'Ľ' + 189: 218, # '˝' + 190: 219, # 'ľ' + 191: 220, # 'ż' + 192: 221, # 'Ŕ' + 193: 51, # 'Á' + 194: 83, # 'Â' + 195: 222, # 'Ă' + 196: 80, # 'Ä' + 197: 223, # 'Ĺ' + 198: 224, # 'Ć' + 199: 225, # 'Ç' + 200: 226, # 'Č' + 201: 44, # 'É' + 202: 227, # 'Ę' + 203: 228, # 'Ë' + 204: 229, # 'Ě' + 205: 61, # 'Í' + 206: 230, # 'Î' + 207: 231, # 'Ď' + 208: 232, # 'Đ' + 209: 233, # 'Ń' + 210: 234, # 'Ň' + 211: 58, # 'Ó' + 212: 235, # 'Ô' + 213: 66, # 'Ő' + 214: 59, # 'Ö' + 215: 236, # '×' + 216: 237, # 'Ř' + 217: 238, # 'Ů' + 218: 60, # 'Ú' + 219: 70, # 'Ű' + 220: 63, # 'Ü' + 221: 239, # 'Ý' + 222: 240, # 'Ţ' + 223: 241, # 'ß' + 224: 84, # 'ŕ' + 225: 14, # 'á' + 226: 75, # 'â' + 227: 242, # 'ă' + 228: 71, # 'ä' + 229: 82, # 'ĺ' + 230: 243, # 'ć' + 231: 73, # 'ç' + 232: 244, # 'č' + 233: 15, # 'é' + 234: 85, # 'ę' + 235: 79, # 'ë' + 236: 86, # 'ě' + 237: 30, # 'í' + 238: 77, # 'î' + 239: 87, # 'ď' + 240: 245, # 'đ' + 241: 246, # 'ń' + 242: 247, # 'ň' + 243: 25, # 'ó' + 244: 74, # 'ô' + 245: 42, # 'ő' + 246: 24, # 'ö' + 247: 248, # '÷' + 248: 249, # 'ř' + 249: 250, # 'ů' + 250: 31, # 'ú' + 251: 56, # 'ű' + 252: 29, # 'ü' + 253: 251, # 'ý' + 254: 252, # 'ţ' + 255: 253, # '˙' } -WINDOWS_1250_HUNGARIAN_MODEL = SingleByteCharSetModel(charset_name='windows-1250', - language='Hungarian', - char_to_order_map=WINDOWS_1250_HUNGARIAN_CHAR_TO_ORDER, - language_model=HUNGARIAN_LANG_MODEL, - typical_positive_ratio=0.947368, - keep_ascii_letters=True, - alphabet='ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű') +WINDOWS_1250_HUNGARIAN_MODEL = SingleByteCharSetModel( + charset_name="windows-1250", + language="Hungarian", + char_to_order_map=WINDOWS_1250_HUNGARIAN_CHAR_TO_ORDER, + language_model=HUNGARIAN_LANG_MODEL, + typical_positive_ratio=0.947368, + keep_ascii_letters=True, + alphabet="ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű", +) ISO_8859_2_HUNGARIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 28, # 'A' - 66: 40, # 'B' - 67: 54, # 'C' - 68: 45, # 'D' - 69: 32, # 'E' - 70: 50, # 'F' - 71: 49, # 'G' - 72: 38, # 'H' - 73: 39, # 'I' - 74: 53, # 'J' - 75: 36, # 'K' - 76: 41, # 'L' - 77: 34, # 'M' - 78: 35, # 'N' - 79: 47, # 'O' - 80: 46, # 'P' - 81: 71, # 'Q' - 82: 43, # 'R' - 83: 33, # 'S' - 84: 37, # 'T' - 85: 57, # 'U' - 86: 48, # 'V' - 87: 64, # 'W' - 88: 68, # 'X' - 89: 55, # 'Y' - 90: 52, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 2, # 'a' - 98: 18, # 'b' - 99: 26, # 'c' - 100: 17, # 'd' - 101: 1, # 'e' - 102: 27, # 'f' - 103: 12, # 'g' - 104: 20, # 'h' - 105: 9, # 'i' - 106: 22, # 'j' - 107: 7, # 'k' - 108: 6, # 'l' - 109: 13, # 'm' - 110: 4, # 'n' - 111: 8, # 'o' - 112: 23, # 'p' - 113: 67, # 'q' - 114: 10, # 'r' - 115: 5, # 's' - 116: 3, # 't' - 117: 21, # 'u' - 118: 19, # 'v' - 119: 65, # 'w' - 120: 62, # 'x' - 121: 16, # 'y' - 122: 11, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 159, # '\x80' - 129: 160, # '\x81' - 130: 161, # '\x82' - 131: 162, # '\x83' - 132: 163, # '\x84' - 133: 164, # '\x85' - 134: 165, # '\x86' - 135: 166, # '\x87' - 136: 167, # '\x88' - 137: 168, # '\x89' - 138: 169, # '\x8a' - 139: 170, # '\x8b' - 140: 171, # '\x8c' - 141: 172, # '\x8d' - 142: 173, # '\x8e' - 143: 174, # '\x8f' - 144: 175, # '\x90' - 145: 176, # '\x91' - 146: 177, # '\x92' - 147: 178, # '\x93' - 148: 179, # '\x94' - 149: 180, # '\x95' - 150: 181, # '\x96' - 151: 182, # '\x97' - 152: 183, # '\x98' - 153: 184, # '\x99' - 154: 185, # '\x9a' - 155: 186, # '\x9b' - 156: 187, # '\x9c' - 157: 188, # '\x9d' - 158: 189, # '\x9e' - 159: 190, # '\x9f' - 160: 191, # '\xa0' - 161: 192, # 'Ą' - 162: 193, # '˘' - 163: 194, # 'Ł' - 164: 195, # '¤' - 165: 196, # 'Ľ' - 166: 197, # 'Ś' - 167: 75, # '§' - 168: 198, # '¨' - 169: 199, # 'Š' - 170: 200, # 'Ş' - 171: 201, # 'Ť' - 172: 202, # 'Ź' - 173: 203, # '\xad' - 174: 204, # 'Ž' - 175: 205, # 'Ż' - 176: 79, # '°' - 177: 206, # 'ą' - 178: 207, # '˛' - 179: 208, # 'ł' - 180: 209, # '´' - 181: 210, # 'ľ' - 182: 211, # 'ś' - 183: 212, # 'ˇ' - 184: 213, # '¸' - 185: 214, # 'š' - 186: 215, # 'ş' - 187: 216, # 'ť' - 188: 217, # 'ź' - 189: 218, # '˝' - 190: 219, # 'ž' - 191: 220, # 'ż' - 192: 221, # 'Ŕ' - 193: 51, # 'Á' - 194: 81, # 'Â' - 195: 222, # 'Ă' - 196: 78, # 'Ä' - 197: 223, # 'Ĺ' - 198: 224, # 'Ć' - 199: 225, # 'Ç' - 200: 226, # 'Č' - 201: 44, # 'É' - 202: 227, # 'Ę' - 203: 228, # 'Ë' - 204: 229, # 'Ě' - 205: 61, # 'Í' - 206: 230, # 'Î' - 207: 231, # 'Ď' - 208: 232, # 'Đ' - 209: 233, # 'Ń' - 210: 234, # 'Ň' - 211: 58, # 'Ó' - 212: 235, # 'Ô' - 213: 66, # 'Ő' - 214: 59, # 'Ö' - 215: 236, # '×' - 216: 237, # 'Ř' - 217: 238, # 'Ů' - 218: 60, # 'Ú' - 219: 69, # 'Ű' - 220: 63, # 'Ü' - 221: 239, # 'Ý' - 222: 240, # 'Ţ' - 223: 241, # 'ß' - 224: 82, # 'ŕ' - 225: 14, # 'á' - 226: 74, # 'â' - 227: 242, # 'ă' - 228: 70, # 'ä' - 229: 80, # 'ĺ' - 230: 243, # 'ć' - 231: 72, # 'ç' - 232: 244, # 'č' - 233: 15, # 'é' - 234: 83, # 'ę' - 235: 77, # 'ë' - 236: 84, # 'ě' - 237: 30, # 'í' - 238: 76, # 'î' - 239: 85, # 'ď' - 240: 245, # 'đ' - 241: 246, # 'ń' - 242: 247, # 'ň' - 243: 25, # 'ó' - 244: 73, # 'ô' - 245: 42, # 'ő' - 246: 24, # 'ö' - 247: 248, # '÷' - 248: 249, # 'ř' - 249: 250, # 'ů' - 250: 31, # 'ú' - 251: 56, # 'ű' - 252: 29, # 'ü' - 253: 251, # 'ý' - 254: 252, # 'ţ' - 255: 253, # '˙' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 28, # 'A' + 66: 40, # 'B' + 67: 54, # 'C' + 68: 45, # 'D' + 69: 32, # 'E' + 70: 50, # 'F' + 71: 49, # 'G' + 72: 38, # 'H' + 73: 39, # 'I' + 74: 53, # 'J' + 75: 36, # 'K' + 76: 41, # 'L' + 77: 34, # 'M' + 78: 35, # 'N' + 79: 47, # 'O' + 80: 46, # 'P' + 81: 71, # 'Q' + 82: 43, # 'R' + 83: 33, # 'S' + 84: 37, # 'T' + 85: 57, # 'U' + 86: 48, # 'V' + 87: 64, # 'W' + 88: 68, # 'X' + 89: 55, # 'Y' + 90: 52, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 2, # 'a' + 98: 18, # 'b' + 99: 26, # 'c' + 100: 17, # 'd' + 101: 1, # 'e' + 102: 27, # 'f' + 103: 12, # 'g' + 104: 20, # 'h' + 105: 9, # 'i' + 106: 22, # 'j' + 107: 7, # 'k' + 108: 6, # 'l' + 109: 13, # 'm' + 110: 4, # 'n' + 111: 8, # 'o' + 112: 23, # 'p' + 113: 67, # 'q' + 114: 10, # 'r' + 115: 5, # 's' + 116: 3, # 't' + 117: 21, # 'u' + 118: 19, # 'v' + 119: 65, # 'w' + 120: 62, # 'x' + 121: 16, # 'y' + 122: 11, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 159, # '\x80' + 129: 160, # '\x81' + 130: 161, # '\x82' + 131: 162, # '\x83' + 132: 163, # '\x84' + 133: 164, # '\x85' + 134: 165, # '\x86' + 135: 166, # '\x87' + 136: 167, # '\x88' + 137: 168, # '\x89' + 138: 169, # '\x8a' + 139: 170, # '\x8b' + 140: 171, # '\x8c' + 141: 172, # '\x8d' + 142: 173, # '\x8e' + 143: 174, # '\x8f' + 144: 175, # '\x90' + 145: 176, # '\x91' + 146: 177, # '\x92' + 147: 178, # '\x93' + 148: 179, # '\x94' + 149: 180, # '\x95' + 150: 181, # '\x96' + 151: 182, # '\x97' + 152: 183, # '\x98' + 153: 184, # '\x99' + 154: 185, # '\x9a' + 155: 186, # '\x9b' + 156: 187, # '\x9c' + 157: 188, # '\x9d' + 158: 189, # '\x9e' + 159: 190, # '\x9f' + 160: 191, # '\xa0' + 161: 192, # 'Ą' + 162: 193, # '˘' + 163: 194, # 'Ł' + 164: 195, # '¤' + 165: 196, # 'Ľ' + 166: 197, # 'Ś' + 167: 75, # '§' + 168: 198, # '¨' + 169: 199, # 'Š' + 170: 200, # 'Ş' + 171: 201, # 'Ť' + 172: 202, # 'Ź' + 173: 203, # '\xad' + 174: 204, # 'Ž' + 175: 205, # 'Ż' + 176: 79, # '°' + 177: 206, # 'ą' + 178: 207, # '˛' + 179: 208, # 'ł' + 180: 209, # '´' + 181: 210, # 'ľ' + 182: 211, # 'ś' + 183: 212, # 'ˇ' + 184: 213, # '¸' + 185: 214, # 'š' + 186: 215, # 'ş' + 187: 216, # 'ť' + 188: 217, # 'ź' + 189: 218, # '˝' + 190: 219, # 'ž' + 191: 220, # 'ż' + 192: 221, # 'Ŕ' + 193: 51, # 'Á' + 194: 81, # 'Â' + 195: 222, # 'Ă' + 196: 78, # 'Ä' + 197: 223, # 'Ĺ' + 198: 224, # 'Ć' + 199: 225, # 'Ç' + 200: 226, # 'Č' + 201: 44, # 'É' + 202: 227, # 'Ę' + 203: 228, # 'Ë' + 204: 229, # 'Ě' + 205: 61, # 'Í' + 206: 230, # 'Î' + 207: 231, # 'Ď' + 208: 232, # 'Đ' + 209: 233, # 'Ń' + 210: 234, # 'Ň' + 211: 58, # 'Ó' + 212: 235, # 'Ô' + 213: 66, # 'Ő' + 214: 59, # 'Ö' + 215: 236, # '×' + 216: 237, # 'Ř' + 217: 238, # 'Ů' + 218: 60, # 'Ú' + 219: 69, # 'Ű' + 220: 63, # 'Ü' + 221: 239, # 'Ý' + 222: 240, # 'Ţ' + 223: 241, # 'ß' + 224: 82, # 'ŕ' + 225: 14, # 'á' + 226: 74, # 'â' + 227: 242, # 'ă' + 228: 70, # 'ä' + 229: 80, # 'ĺ' + 230: 243, # 'ć' + 231: 72, # 'ç' + 232: 244, # 'č' + 233: 15, # 'é' + 234: 83, # 'ę' + 235: 77, # 'ë' + 236: 84, # 'ě' + 237: 30, # 'í' + 238: 76, # 'î' + 239: 85, # 'ď' + 240: 245, # 'đ' + 241: 246, # 'ń' + 242: 247, # 'ň' + 243: 25, # 'ó' + 244: 73, # 'ô' + 245: 42, # 'ő' + 246: 24, # 'ö' + 247: 248, # '÷' + 248: 249, # 'ř' + 249: 250, # 'ů' + 250: 31, # 'ú' + 251: 56, # 'ű' + 252: 29, # 'ü' + 253: 251, # 'ý' + 254: 252, # 'ţ' + 255: 253, # '˙' } -ISO_8859_2_HUNGARIAN_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-2', - language='Hungarian', - char_to_order_map=ISO_8859_2_HUNGARIAN_CHAR_TO_ORDER, - language_model=HUNGARIAN_LANG_MODEL, - typical_positive_ratio=0.947368, - keep_ascii_letters=True, - alphabet='ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű') - +ISO_8859_2_HUNGARIAN_MODEL = SingleByteCharSetModel( + charset_name="ISO-8859-2", + language="Hungarian", + char_to_order_map=ISO_8859_2_HUNGARIAN_CHAR_TO_ORDER, + language_model=HUNGARIAN_LANG_MODEL, + typical_positive_ratio=0.947368, + keep_ascii_letters=True, + alphabet="ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű", +) diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py index 5594452b..39a53889 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py @@ -1,9 +1,5 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- - from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - # 3: Positive # 2: Likely # 1: Unlikely @@ -4115,1604 +4111,1615 @@ RUSSIAN_LANG_MODEL = { # Character Mapping Table(s): IBM866_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 37, # 'А' - 129: 44, # 'Б' - 130: 33, # 'В' - 131: 46, # 'Г' - 132: 41, # 'Д' - 133: 48, # 'Е' - 134: 56, # 'Ж' - 135: 51, # 'З' - 136: 42, # 'И' - 137: 60, # 'Й' - 138: 36, # 'К' - 139: 49, # 'Л' - 140: 38, # 'М' - 141: 31, # 'Н' - 142: 34, # 'О' - 143: 35, # 'П' - 144: 45, # 'Р' - 145: 32, # 'С' - 146: 40, # 'Т' - 147: 52, # 'У' - 148: 53, # 'Ф' - 149: 55, # 'Х' - 150: 58, # 'Ц' - 151: 50, # 'Ч' - 152: 57, # 'Ш' - 153: 63, # 'Щ' - 154: 70, # 'Ъ' - 155: 62, # 'Ы' - 156: 61, # 'Ь' - 157: 47, # 'Э' - 158: 59, # 'Ю' - 159: 43, # 'Я' - 160: 3, # 'а' - 161: 21, # 'б' - 162: 10, # 'в' - 163: 19, # 'г' - 164: 13, # 'д' - 165: 2, # 'е' - 166: 24, # 'ж' - 167: 20, # 'з' - 168: 4, # 'и' - 169: 23, # 'й' - 170: 11, # 'к' - 171: 8, # 'л' - 172: 12, # 'м' - 173: 5, # 'н' - 174: 1, # 'о' - 175: 15, # 'п' - 176: 191, # '░' - 177: 192, # '▒' - 178: 193, # '▓' - 179: 194, # '│' - 180: 195, # '┤' - 181: 196, # '╡' - 182: 197, # '╢' - 183: 198, # '╖' - 184: 199, # '╕' - 185: 200, # '╣' - 186: 201, # '║' - 187: 202, # '╗' - 188: 203, # '╝' - 189: 204, # '╜' - 190: 205, # '╛' - 191: 206, # '┐' - 192: 207, # '└' - 193: 208, # '┴' - 194: 209, # '┬' - 195: 210, # '├' - 196: 211, # '─' - 197: 212, # '┼' - 198: 213, # '╞' - 199: 214, # '╟' - 200: 215, # '╚' - 201: 216, # '╔' - 202: 217, # '╩' - 203: 218, # '╦' - 204: 219, # '╠' - 205: 220, # '═' - 206: 221, # '╬' - 207: 222, # '╧' - 208: 223, # '╨' - 209: 224, # '╤' - 210: 225, # '╥' - 211: 226, # '╙' - 212: 227, # '╘' - 213: 228, # '╒' - 214: 229, # '╓' - 215: 230, # '╫' - 216: 231, # '╪' - 217: 232, # '┘' - 218: 233, # '┌' - 219: 234, # '█' - 220: 235, # '▄' - 221: 236, # '▌' - 222: 237, # '▐' - 223: 238, # '▀' - 224: 9, # 'р' - 225: 7, # 'с' - 226: 6, # 'т' - 227: 14, # 'у' - 228: 39, # 'ф' - 229: 26, # 'х' - 230: 28, # 'ц' - 231: 22, # 'ч' - 232: 25, # 'ш' - 233: 29, # 'щ' - 234: 54, # 'ъ' - 235: 18, # 'ы' - 236: 17, # 'ь' - 237: 30, # 'э' - 238: 27, # 'ю' - 239: 16, # 'я' - 240: 239, # 'Ё' - 241: 68, # 'ё' - 242: 240, # 'Є' - 243: 241, # 'є' - 244: 242, # 'Ї' - 245: 243, # 'ї' - 246: 244, # 'Ў' - 247: 245, # 'ў' - 248: 246, # '°' - 249: 247, # '∙' - 250: 248, # '·' - 251: 249, # '√' - 252: 250, # '№' - 253: 251, # '¤' - 254: 252, # '■' - 255: 255, # '\xa0' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 142, # 'A' + 66: 143, # 'B' + 67: 144, # 'C' + 68: 145, # 'D' + 69: 146, # 'E' + 70: 147, # 'F' + 71: 148, # 'G' + 72: 149, # 'H' + 73: 150, # 'I' + 74: 151, # 'J' + 75: 152, # 'K' + 76: 74, # 'L' + 77: 153, # 'M' + 78: 75, # 'N' + 79: 154, # 'O' + 80: 155, # 'P' + 81: 156, # 'Q' + 82: 157, # 'R' + 83: 158, # 'S' + 84: 159, # 'T' + 85: 160, # 'U' + 86: 161, # 'V' + 87: 162, # 'W' + 88: 163, # 'X' + 89: 164, # 'Y' + 90: 165, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 71, # 'a' + 98: 172, # 'b' + 99: 66, # 'c' + 100: 173, # 'd' + 101: 65, # 'e' + 102: 174, # 'f' + 103: 76, # 'g' + 104: 175, # 'h' + 105: 64, # 'i' + 106: 176, # 'j' + 107: 177, # 'k' + 108: 77, # 'l' + 109: 72, # 'm' + 110: 178, # 'n' + 111: 69, # 'o' + 112: 67, # 'p' + 113: 179, # 'q' + 114: 78, # 'r' + 115: 73, # 's' + 116: 180, # 't' + 117: 181, # 'u' + 118: 79, # 'v' + 119: 182, # 'w' + 120: 183, # 'x' + 121: 184, # 'y' + 122: 185, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 37, # 'А' + 129: 44, # 'Б' + 130: 33, # 'В' + 131: 46, # 'Г' + 132: 41, # 'Д' + 133: 48, # 'Е' + 134: 56, # 'Ж' + 135: 51, # 'З' + 136: 42, # 'И' + 137: 60, # 'Й' + 138: 36, # 'К' + 139: 49, # 'Л' + 140: 38, # 'М' + 141: 31, # 'Н' + 142: 34, # 'О' + 143: 35, # 'П' + 144: 45, # 'Р' + 145: 32, # 'С' + 146: 40, # 'Т' + 147: 52, # 'У' + 148: 53, # 'Ф' + 149: 55, # 'Х' + 150: 58, # 'Ц' + 151: 50, # 'Ч' + 152: 57, # 'Ш' + 153: 63, # 'Щ' + 154: 70, # 'Ъ' + 155: 62, # 'Ы' + 156: 61, # 'Ь' + 157: 47, # 'Э' + 158: 59, # 'Ю' + 159: 43, # 'Я' + 160: 3, # 'а' + 161: 21, # 'б' + 162: 10, # 'в' + 163: 19, # 'г' + 164: 13, # 'д' + 165: 2, # 'е' + 166: 24, # 'ж' + 167: 20, # 'з' + 168: 4, # 'и' + 169: 23, # 'й' + 170: 11, # 'к' + 171: 8, # 'л' + 172: 12, # 'м' + 173: 5, # 'н' + 174: 1, # 'о' + 175: 15, # 'п' + 176: 191, # '░' + 177: 192, # '▒' + 178: 193, # '▓' + 179: 194, # '│' + 180: 195, # '┤' + 181: 196, # '╡' + 182: 197, # '╢' + 183: 198, # '╖' + 184: 199, # '╕' + 185: 200, # '╣' + 186: 201, # '║' + 187: 202, # '╗' + 188: 203, # '╝' + 189: 204, # '╜' + 190: 205, # '╛' + 191: 206, # '┐' + 192: 207, # '└' + 193: 208, # '┴' + 194: 209, # '┬' + 195: 210, # '├' + 196: 211, # '─' + 197: 212, # '┼' + 198: 213, # '╞' + 199: 214, # '╟' + 200: 215, # '╚' + 201: 216, # '╔' + 202: 217, # '╩' + 203: 218, # '╦' + 204: 219, # '╠' + 205: 220, # '═' + 206: 221, # '╬' + 207: 222, # '╧' + 208: 223, # '╨' + 209: 224, # '╤' + 210: 225, # '╥' + 211: 226, # '╙' + 212: 227, # '╘' + 213: 228, # '╒' + 214: 229, # '╓' + 215: 230, # '╫' + 216: 231, # '╪' + 217: 232, # '┘' + 218: 233, # '┌' + 219: 234, # '█' + 220: 235, # '▄' + 221: 236, # '▌' + 222: 237, # '▐' + 223: 238, # '▀' + 224: 9, # 'р' + 225: 7, # 'с' + 226: 6, # 'т' + 227: 14, # 'у' + 228: 39, # 'ф' + 229: 26, # 'х' + 230: 28, # 'ц' + 231: 22, # 'ч' + 232: 25, # 'ш' + 233: 29, # 'щ' + 234: 54, # 'ъ' + 235: 18, # 'ы' + 236: 17, # 'ь' + 237: 30, # 'э' + 238: 27, # 'ю' + 239: 16, # 'я' + 240: 239, # 'Ё' + 241: 68, # 'ё' + 242: 240, # 'Є' + 243: 241, # 'є' + 244: 242, # 'Ї' + 245: 243, # 'ї' + 246: 244, # 'Ў' + 247: 245, # 'ў' + 248: 246, # '°' + 249: 247, # '∙' + 250: 248, # '·' + 251: 249, # '√' + 252: 250, # '№' + 253: 251, # '¤' + 254: 252, # '■' + 255: 255, # '\xa0' } -IBM866_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='IBM866', - language='Russian', - char_to_order_map=IBM866_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё') +IBM866_RUSSIAN_MODEL = SingleByteCharSetModel( + charset_name="IBM866", + language="Russian", + char_to_order_map=IBM866_RUSSIAN_CHAR_TO_ORDER, + language_model=RUSSIAN_LANG_MODEL, + typical_positive_ratio=0.976601, + keep_ascii_letters=False, + alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", +) WINDOWS_1251_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 191, # 'Ђ' - 129: 192, # 'Ѓ' - 130: 193, # '‚' - 131: 194, # 'ѓ' - 132: 195, # '„' - 133: 196, # '…' - 134: 197, # '†' - 135: 198, # '‡' - 136: 199, # '€' - 137: 200, # '‰' - 138: 201, # 'Љ' - 139: 202, # '‹' - 140: 203, # 'Њ' - 141: 204, # 'Ќ' - 142: 205, # 'Ћ' - 143: 206, # 'Џ' - 144: 207, # 'ђ' - 145: 208, # '‘' - 146: 209, # '’' - 147: 210, # '“' - 148: 211, # '”' - 149: 212, # '•' - 150: 213, # '–' - 151: 214, # '—' - 152: 215, # None - 153: 216, # '™' - 154: 217, # 'љ' - 155: 218, # '›' - 156: 219, # 'њ' - 157: 220, # 'ќ' - 158: 221, # 'ћ' - 159: 222, # 'џ' - 160: 223, # '\xa0' - 161: 224, # 'Ў' - 162: 225, # 'ў' - 163: 226, # 'Ј' - 164: 227, # '¤' - 165: 228, # 'Ґ' - 166: 229, # '¦' - 167: 230, # '§' - 168: 231, # 'Ё' - 169: 232, # '©' - 170: 233, # 'Є' - 171: 234, # '«' - 172: 235, # '¬' - 173: 236, # '\xad' - 174: 237, # '®' - 175: 238, # 'Ї' - 176: 239, # '°' - 177: 240, # '±' - 178: 241, # 'І' - 179: 242, # 'і' - 180: 243, # 'ґ' - 181: 244, # 'µ' - 182: 245, # '¶' - 183: 246, # '·' - 184: 68, # 'ё' - 185: 247, # '№' - 186: 248, # 'є' - 187: 249, # '»' - 188: 250, # 'ј' - 189: 251, # 'Ѕ' - 190: 252, # 'ѕ' - 191: 253, # 'ї' - 192: 37, # 'А' - 193: 44, # 'Б' - 194: 33, # 'В' - 195: 46, # 'Г' - 196: 41, # 'Д' - 197: 48, # 'Е' - 198: 56, # 'Ж' - 199: 51, # 'З' - 200: 42, # 'И' - 201: 60, # 'Й' - 202: 36, # 'К' - 203: 49, # 'Л' - 204: 38, # 'М' - 205: 31, # 'Н' - 206: 34, # 'О' - 207: 35, # 'П' - 208: 45, # 'Р' - 209: 32, # 'С' - 210: 40, # 'Т' - 211: 52, # 'У' - 212: 53, # 'Ф' - 213: 55, # 'Х' - 214: 58, # 'Ц' - 215: 50, # 'Ч' - 216: 57, # 'Ш' - 217: 63, # 'Щ' - 218: 70, # 'Ъ' - 219: 62, # 'Ы' - 220: 61, # 'Ь' - 221: 47, # 'Э' - 222: 59, # 'Ю' - 223: 43, # 'Я' - 224: 3, # 'а' - 225: 21, # 'б' - 226: 10, # 'в' - 227: 19, # 'г' - 228: 13, # 'д' - 229: 2, # 'е' - 230: 24, # 'ж' - 231: 20, # 'з' - 232: 4, # 'и' - 233: 23, # 'й' - 234: 11, # 'к' - 235: 8, # 'л' - 236: 12, # 'м' - 237: 5, # 'н' - 238: 1, # 'о' - 239: 15, # 'п' - 240: 9, # 'р' - 241: 7, # 'с' - 242: 6, # 'т' - 243: 14, # 'у' - 244: 39, # 'ф' - 245: 26, # 'х' - 246: 28, # 'ц' - 247: 22, # 'ч' - 248: 25, # 'ш' - 249: 29, # 'щ' - 250: 54, # 'ъ' - 251: 18, # 'ы' - 252: 17, # 'ь' - 253: 30, # 'э' - 254: 27, # 'ю' - 255: 16, # 'я' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 142, # 'A' + 66: 143, # 'B' + 67: 144, # 'C' + 68: 145, # 'D' + 69: 146, # 'E' + 70: 147, # 'F' + 71: 148, # 'G' + 72: 149, # 'H' + 73: 150, # 'I' + 74: 151, # 'J' + 75: 152, # 'K' + 76: 74, # 'L' + 77: 153, # 'M' + 78: 75, # 'N' + 79: 154, # 'O' + 80: 155, # 'P' + 81: 156, # 'Q' + 82: 157, # 'R' + 83: 158, # 'S' + 84: 159, # 'T' + 85: 160, # 'U' + 86: 161, # 'V' + 87: 162, # 'W' + 88: 163, # 'X' + 89: 164, # 'Y' + 90: 165, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 71, # 'a' + 98: 172, # 'b' + 99: 66, # 'c' + 100: 173, # 'd' + 101: 65, # 'e' + 102: 174, # 'f' + 103: 76, # 'g' + 104: 175, # 'h' + 105: 64, # 'i' + 106: 176, # 'j' + 107: 177, # 'k' + 108: 77, # 'l' + 109: 72, # 'm' + 110: 178, # 'n' + 111: 69, # 'o' + 112: 67, # 'p' + 113: 179, # 'q' + 114: 78, # 'r' + 115: 73, # 's' + 116: 180, # 't' + 117: 181, # 'u' + 118: 79, # 'v' + 119: 182, # 'w' + 120: 183, # 'x' + 121: 184, # 'y' + 122: 185, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 191, # 'Ђ' + 129: 192, # 'Ѓ' + 130: 193, # '‚' + 131: 194, # 'ѓ' + 132: 195, # '„' + 133: 196, # '…' + 134: 197, # '†' + 135: 198, # '‡' + 136: 199, # '€' + 137: 200, # '‰' + 138: 201, # 'Љ' + 139: 202, # '‹' + 140: 203, # 'Њ' + 141: 204, # 'Ќ' + 142: 205, # 'Ћ' + 143: 206, # 'Џ' + 144: 207, # 'ђ' + 145: 208, # '‘' + 146: 209, # '’' + 147: 210, # '“' + 148: 211, # '”' + 149: 212, # '•' + 150: 213, # '–' + 151: 214, # '—' + 152: 215, # None + 153: 216, # '™' + 154: 217, # 'љ' + 155: 218, # '›' + 156: 219, # 'њ' + 157: 220, # 'ќ' + 158: 221, # 'ћ' + 159: 222, # 'џ' + 160: 223, # '\xa0' + 161: 224, # 'Ў' + 162: 225, # 'ў' + 163: 226, # 'Ј' + 164: 227, # '¤' + 165: 228, # 'Ґ' + 166: 229, # '¦' + 167: 230, # '§' + 168: 231, # 'Ё' + 169: 232, # '©' + 170: 233, # 'Є' + 171: 234, # '«' + 172: 235, # '¬' + 173: 236, # '\xad' + 174: 237, # '®' + 175: 238, # 'Ї' + 176: 239, # '°' + 177: 240, # '±' + 178: 241, # 'І' + 179: 242, # 'і' + 180: 243, # 'ґ' + 181: 244, # 'µ' + 182: 245, # '¶' + 183: 246, # '·' + 184: 68, # 'ё' + 185: 247, # '№' + 186: 248, # 'є' + 187: 249, # '»' + 188: 250, # 'ј' + 189: 251, # 'Ѕ' + 190: 252, # 'ѕ' + 191: 253, # 'ї' + 192: 37, # 'А' + 193: 44, # 'Б' + 194: 33, # 'В' + 195: 46, # 'Г' + 196: 41, # 'Д' + 197: 48, # 'Е' + 198: 56, # 'Ж' + 199: 51, # 'З' + 200: 42, # 'И' + 201: 60, # 'Й' + 202: 36, # 'К' + 203: 49, # 'Л' + 204: 38, # 'М' + 205: 31, # 'Н' + 206: 34, # 'О' + 207: 35, # 'П' + 208: 45, # 'Р' + 209: 32, # 'С' + 210: 40, # 'Т' + 211: 52, # 'У' + 212: 53, # 'Ф' + 213: 55, # 'Х' + 214: 58, # 'Ц' + 215: 50, # 'Ч' + 216: 57, # 'Ш' + 217: 63, # 'Щ' + 218: 70, # 'Ъ' + 219: 62, # 'Ы' + 220: 61, # 'Ь' + 221: 47, # 'Э' + 222: 59, # 'Ю' + 223: 43, # 'Я' + 224: 3, # 'а' + 225: 21, # 'б' + 226: 10, # 'в' + 227: 19, # 'г' + 228: 13, # 'д' + 229: 2, # 'е' + 230: 24, # 'ж' + 231: 20, # 'з' + 232: 4, # 'и' + 233: 23, # 'й' + 234: 11, # 'к' + 235: 8, # 'л' + 236: 12, # 'м' + 237: 5, # 'н' + 238: 1, # 'о' + 239: 15, # 'п' + 240: 9, # 'р' + 241: 7, # 'с' + 242: 6, # 'т' + 243: 14, # 'у' + 244: 39, # 'ф' + 245: 26, # 'х' + 246: 28, # 'ц' + 247: 22, # 'ч' + 248: 25, # 'ш' + 249: 29, # 'щ' + 250: 54, # 'ъ' + 251: 18, # 'ы' + 252: 17, # 'ь' + 253: 30, # 'э' + 254: 27, # 'ю' + 255: 16, # 'я' } -WINDOWS_1251_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='windows-1251', - language='Russian', - char_to_order_map=WINDOWS_1251_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё') +WINDOWS_1251_RUSSIAN_MODEL = SingleByteCharSetModel( + charset_name="windows-1251", + language="Russian", + char_to_order_map=WINDOWS_1251_RUSSIAN_CHAR_TO_ORDER, + language_model=RUSSIAN_LANG_MODEL, + typical_positive_ratio=0.976601, + keep_ascii_letters=False, + alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", +) IBM855_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 191, # 'ђ' - 129: 192, # 'Ђ' - 130: 193, # 'ѓ' - 131: 194, # 'Ѓ' - 132: 68, # 'ё' - 133: 195, # 'Ё' - 134: 196, # 'є' - 135: 197, # 'Є' - 136: 198, # 'ѕ' - 137: 199, # 'Ѕ' - 138: 200, # 'і' - 139: 201, # 'І' - 140: 202, # 'ї' - 141: 203, # 'Ї' - 142: 204, # 'ј' - 143: 205, # 'Ј' - 144: 206, # 'љ' - 145: 207, # 'Љ' - 146: 208, # 'њ' - 147: 209, # 'Њ' - 148: 210, # 'ћ' - 149: 211, # 'Ћ' - 150: 212, # 'ќ' - 151: 213, # 'Ќ' - 152: 214, # 'ў' - 153: 215, # 'Ў' - 154: 216, # 'џ' - 155: 217, # 'Џ' - 156: 27, # 'ю' - 157: 59, # 'Ю' - 158: 54, # 'ъ' - 159: 70, # 'Ъ' - 160: 3, # 'а' - 161: 37, # 'А' - 162: 21, # 'б' - 163: 44, # 'Б' - 164: 28, # 'ц' - 165: 58, # 'Ц' - 166: 13, # 'д' - 167: 41, # 'Д' - 168: 2, # 'е' - 169: 48, # 'Е' - 170: 39, # 'ф' - 171: 53, # 'Ф' - 172: 19, # 'г' - 173: 46, # 'Г' - 174: 218, # '«' - 175: 219, # '»' - 176: 220, # '░' - 177: 221, # '▒' - 178: 222, # '▓' - 179: 223, # '│' - 180: 224, # '┤' - 181: 26, # 'х' - 182: 55, # 'Х' - 183: 4, # 'и' - 184: 42, # 'И' - 185: 225, # '╣' - 186: 226, # '║' - 187: 227, # '╗' - 188: 228, # '╝' - 189: 23, # 'й' - 190: 60, # 'Й' - 191: 229, # '┐' - 192: 230, # '└' - 193: 231, # '┴' - 194: 232, # '┬' - 195: 233, # '├' - 196: 234, # '─' - 197: 235, # '┼' - 198: 11, # 'к' - 199: 36, # 'К' - 200: 236, # '╚' - 201: 237, # '╔' - 202: 238, # '╩' - 203: 239, # '╦' - 204: 240, # '╠' - 205: 241, # '═' - 206: 242, # '╬' - 207: 243, # '¤' - 208: 8, # 'л' - 209: 49, # 'Л' - 210: 12, # 'м' - 211: 38, # 'М' - 212: 5, # 'н' - 213: 31, # 'Н' - 214: 1, # 'о' - 215: 34, # 'О' - 216: 15, # 'п' - 217: 244, # '┘' - 218: 245, # '┌' - 219: 246, # '█' - 220: 247, # '▄' - 221: 35, # 'П' - 222: 16, # 'я' - 223: 248, # '▀' - 224: 43, # 'Я' - 225: 9, # 'р' - 226: 45, # 'Р' - 227: 7, # 'с' - 228: 32, # 'С' - 229: 6, # 'т' - 230: 40, # 'Т' - 231: 14, # 'у' - 232: 52, # 'У' - 233: 24, # 'ж' - 234: 56, # 'Ж' - 235: 10, # 'в' - 236: 33, # 'В' - 237: 17, # 'ь' - 238: 61, # 'Ь' - 239: 249, # '№' - 240: 250, # '\xad' - 241: 18, # 'ы' - 242: 62, # 'Ы' - 243: 20, # 'з' - 244: 51, # 'З' - 245: 25, # 'ш' - 246: 57, # 'Ш' - 247: 30, # 'э' - 248: 47, # 'Э' - 249: 29, # 'щ' - 250: 63, # 'Щ' - 251: 22, # 'ч' - 252: 50, # 'Ч' - 253: 251, # '§' - 254: 252, # '■' - 255: 255, # '\xa0' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 142, # 'A' + 66: 143, # 'B' + 67: 144, # 'C' + 68: 145, # 'D' + 69: 146, # 'E' + 70: 147, # 'F' + 71: 148, # 'G' + 72: 149, # 'H' + 73: 150, # 'I' + 74: 151, # 'J' + 75: 152, # 'K' + 76: 74, # 'L' + 77: 153, # 'M' + 78: 75, # 'N' + 79: 154, # 'O' + 80: 155, # 'P' + 81: 156, # 'Q' + 82: 157, # 'R' + 83: 158, # 'S' + 84: 159, # 'T' + 85: 160, # 'U' + 86: 161, # 'V' + 87: 162, # 'W' + 88: 163, # 'X' + 89: 164, # 'Y' + 90: 165, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 71, # 'a' + 98: 172, # 'b' + 99: 66, # 'c' + 100: 173, # 'd' + 101: 65, # 'e' + 102: 174, # 'f' + 103: 76, # 'g' + 104: 175, # 'h' + 105: 64, # 'i' + 106: 176, # 'j' + 107: 177, # 'k' + 108: 77, # 'l' + 109: 72, # 'm' + 110: 178, # 'n' + 111: 69, # 'o' + 112: 67, # 'p' + 113: 179, # 'q' + 114: 78, # 'r' + 115: 73, # 's' + 116: 180, # 't' + 117: 181, # 'u' + 118: 79, # 'v' + 119: 182, # 'w' + 120: 183, # 'x' + 121: 184, # 'y' + 122: 185, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 191, # 'ђ' + 129: 192, # 'Ђ' + 130: 193, # 'ѓ' + 131: 194, # 'Ѓ' + 132: 68, # 'ё' + 133: 195, # 'Ё' + 134: 196, # 'є' + 135: 197, # 'Є' + 136: 198, # 'ѕ' + 137: 199, # 'Ѕ' + 138: 200, # 'і' + 139: 201, # 'І' + 140: 202, # 'ї' + 141: 203, # 'Ї' + 142: 204, # 'ј' + 143: 205, # 'Ј' + 144: 206, # 'љ' + 145: 207, # 'Љ' + 146: 208, # 'њ' + 147: 209, # 'Њ' + 148: 210, # 'ћ' + 149: 211, # 'Ћ' + 150: 212, # 'ќ' + 151: 213, # 'Ќ' + 152: 214, # 'ў' + 153: 215, # 'Ў' + 154: 216, # 'џ' + 155: 217, # 'Џ' + 156: 27, # 'ю' + 157: 59, # 'Ю' + 158: 54, # 'ъ' + 159: 70, # 'Ъ' + 160: 3, # 'а' + 161: 37, # 'А' + 162: 21, # 'б' + 163: 44, # 'Б' + 164: 28, # 'ц' + 165: 58, # 'Ц' + 166: 13, # 'д' + 167: 41, # 'Д' + 168: 2, # 'е' + 169: 48, # 'Е' + 170: 39, # 'ф' + 171: 53, # 'Ф' + 172: 19, # 'г' + 173: 46, # 'Г' + 174: 218, # '«' + 175: 219, # '»' + 176: 220, # '░' + 177: 221, # '▒' + 178: 222, # '▓' + 179: 223, # '│' + 180: 224, # '┤' + 181: 26, # 'х' + 182: 55, # 'Х' + 183: 4, # 'и' + 184: 42, # 'И' + 185: 225, # '╣' + 186: 226, # '║' + 187: 227, # '╗' + 188: 228, # '╝' + 189: 23, # 'й' + 190: 60, # 'Й' + 191: 229, # '┐' + 192: 230, # '└' + 193: 231, # '┴' + 194: 232, # '┬' + 195: 233, # '├' + 196: 234, # '─' + 197: 235, # '┼' + 198: 11, # 'к' + 199: 36, # 'К' + 200: 236, # '╚' + 201: 237, # '╔' + 202: 238, # '╩' + 203: 239, # '╦' + 204: 240, # '╠' + 205: 241, # '═' + 206: 242, # '╬' + 207: 243, # '¤' + 208: 8, # 'л' + 209: 49, # 'Л' + 210: 12, # 'м' + 211: 38, # 'М' + 212: 5, # 'н' + 213: 31, # 'Н' + 214: 1, # 'о' + 215: 34, # 'О' + 216: 15, # 'п' + 217: 244, # '┘' + 218: 245, # '┌' + 219: 246, # '█' + 220: 247, # '▄' + 221: 35, # 'П' + 222: 16, # 'я' + 223: 248, # '▀' + 224: 43, # 'Я' + 225: 9, # 'р' + 226: 45, # 'Р' + 227: 7, # 'с' + 228: 32, # 'С' + 229: 6, # 'т' + 230: 40, # 'Т' + 231: 14, # 'у' + 232: 52, # 'У' + 233: 24, # 'ж' + 234: 56, # 'Ж' + 235: 10, # 'в' + 236: 33, # 'В' + 237: 17, # 'ь' + 238: 61, # 'Ь' + 239: 249, # '№' + 240: 250, # '\xad' + 241: 18, # 'ы' + 242: 62, # 'Ы' + 243: 20, # 'з' + 244: 51, # 'З' + 245: 25, # 'ш' + 246: 57, # 'Ш' + 247: 30, # 'э' + 248: 47, # 'Э' + 249: 29, # 'щ' + 250: 63, # 'Щ' + 251: 22, # 'ч' + 252: 50, # 'Ч' + 253: 251, # '§' + 254: 252, # '■' + 255: 255, # '\xa0' } -IBM855_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='IBM855', - language='Russian', - char_to_order_map=IBM855_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё') +IBM855_RUSSIAN_MODEL = SingleByteCharSetModel( + charset_name="IBM855", + language="Russian", + char_to_order_map=IBM855_RUSSIAN_CHAR_TO_ORDER, + language_model=RUSSIAN_LANG_MODEL, + typical_positive_ratio=0.976601, + keep_ascii_letters=False, + alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", +) KOI8_R_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 191, # '─' - 129: 192, # '│' - 130: 193, # '┌' - 131: 194, # '┐' - 132: 195, # '└' - 133: 196, # '┘' - 134: 197, # '├' - 135: 198, # '┤' - 136: 199, # '┬' - 137: 200, # '┴' - 138: 201, # '┼' - 139: 202, # '▀' - 140: 203, # '▄' - 141: 204, # '█' - 142: 205, # '▌' - 143: 206, # '▐' - 144: 207, # '░' - 145: 208, # '▒' - 146: 209, # '▓' - 147: 210, # '⌠' - 148: 211, # '■' - 149: 212, # '∙' - 150: 213, # '√' - 151: 214, # '≈' - 152: 215, # '≤' - 153: 216, # '≥' - 154: 217, # '\xa0' - 155: 218, # '⌡' - 156: 219, # '°' - 157: 220, # '²' - 158: 221, # '·' - 159: 222, # '÷' - 160: 223, # '═' - 161: 224, # '║' - 162: 225, # '╒' - 163: 68, # 'ё' - 164: 226, # '╓' - 165: 227, # '╔' - 166: 228, # '╕' - 167: 229, # '╖' - 168: 230, # '╗' - 169: 231, # '╘' - 170: 232, # '╙' - 171: 233, # '╚' - 172: 234, # '╛' - 173: 235, # '╜' - 174: 236, # '╝' - 175: 237, # '╞' - 176: 238, # '╟' - 177: 239, # '╠' - 178: 240, # '╡' - 179: 241, # 'Ё' - 180: 242, # '╢' - 181: 243, # '╣' - 182: 244, # '╤' - 183: 245, # '╥' - 184: 246, # '╦' - 185: 247, # '╧' - 186: 248, # '╨' - 187: 249, # '╩' - 188: 250, # '╪' - 189: 251, # '╫' - 190: 252, # '╬' - 191: 253, # '©' - 192: 27, # 'ю' - 193: 3, # 'а' - 194: 21, # 'б' - 195: 28, # 'ц' - 196: 13, # 'д' - 197: 2, # 'е' - 198: 39, # 'ф' - 199: 19, # 'г' - 200: 26, # 'х' - 201: 4, # 'и' - 202: 23, # 'й' - 203: 11, # 'к' - 204: 8, # 'л' - 205: 12, # 'м' - 206: 5, # 'н' - 207: 1, # 'о' - 208: 15, # 'п' - 209: 16, # 'я' - 210: 9, # 'р' - 211: 7, # 'с' - 212: 6, # 'т' - 213: 14, # 'у' - 214: 24, # 'ж' - 215: 10, # 'в' - 216: 17, # 'ь' - 217: 18, # 'ы' - 218: 20, # 'з' - 219: 25, # 'ш' - 220: 30, # 'э' - 221: 29, # 'щ' - 222: 22, # 'ч' - 223: 54, # 'ъ' - 224: 59, # 'Ю' - 225: 37, # 'А' - 226: 44, # 'Б' - 227: 58, # 'Ц' - 228: 41, # 'Д' - 229: 48, # 'Е' - 230: 53, # 'Ф' - 231: 46, # 'Г' - 232: 55, # 'Х' - 233: 42, # 'И' - 234: 60, # 'Й' - 235: 36, # 'К' - 236: 49, # 'Л' - 237: 38, # 'М' - 238: 31, # 'Н' - 239: 34, # 'О' - 240: 35, # 'П' - 241: 43, # 'Я' - 242: 45, # 'Р' - 243: 32, # 'С' - 244: 40, # 'Т' - 245: 52, # 'У' - 246: 56, # 'Ж' - 247: 33, # 'В' - 248: 61, # 'Ь' - 249: 62, # 'Ы' - 250: 51, # 'З' - 251: 57, # 'Ш' - 252: 47, # 'Э' - 253: 63, # 'Щ' - 254: 50, # 'Ч' - 255: 70, # 'Ъ' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 142, # 'A' + 66: 143, # 'B' + 67: 144, # 'C' + 68: 145, # 'D' + 69: 146, # 'E' + 70: 147, # 'F' + 71: 148, # 'G' + 72: 149, # 'H' + 73: 150, # 'I' + 74: 151, # 'J' + 75: 152, # 'K' + 76: 74, # 'L' + 77: 153, # 'M' + 78: 75, # 'N' + 79: 154, # 'O' + 80: 155, # 'P' + 81: 156, # 'Q' + 82: 157, # 'R' + 83: 158, # 'S' + 84: 159, # 'T' + 85: 160, # 'U' + 86: 161, # 'V' + 87: 162, # 'W' + 88: 163, # 'X' + 89: 164, # 'Y' + 90: 165, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 71, # 'a' + 98: 172, # 'b' + 99: 66, # 'c' + 100: 173, # 'd' + 101: 65, # 'e' + 102: 174, # 'f' + 103: 76, # 'g' + 104: 175, # 'h' + 105: 64, # 'i' + 106: 176, # 'j' + 107: 177, # 'k' + 108: 77, # 'l' + 109: 72, # 'm' + 110: 178, # 'n' + 111: 69, # 'o' + 112: 67, # 'p' + 113: 179, # 'q' + 114: 78, # 'r' + 115: 73, # 's' + 116: 180, # 't' + 117: 181, # 'u' + 118: 79, # 'v' + 119: 182, # 'w' + 120: 183, # 'x' + 121: 184, # 'y' + 122: 185, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 191, # '─' + 129: 192, # '│' + 130: 193, # '┌' + 131: 194, # '┐' + 132: 195, # '└' + 133: 196, # '┘' + 134: 197, # '├' + 135: 198, # '┤' + 136: 199, # '┬' + 137: 200, # '┴' + 138: 201, # '┼' + 139: 202, # '▀' + 140: 203, # '▄' + 141: 204, # '█' + 142: 205, # '▌' + 143: 206, # '▐' + 144: 207, # '░' + 145: 208, # '▒' + 146: 209, # '▓' + 147: 210, # '⌠' + 148: 211, # '■' + 149: 212, # '∙' + 150: 213, # '√' + 151: 214, # '≈' + 152: 215, # '≤' + 153: 216, # '≥' + 154: 217, # '\xa0' + 155: 218, # '⌡' + 156: 219, # '°' + 157: 220, # '²' + 158: 221, # '·' + 159: 222, # '÷' + 160: 223, # '═' + 161: 224, # '║' + 162: 225, # '╒' + 163: 68, # 'ё' + 164: 226, # '╓' + 165: 227, # '╔' + 166: 228, # '╕' + 167: 229, # '╖' + 168: 230, # '╗' + 169: 231, # '╘' + 170: 232, # '╙' + 171: 233, # '╚' + 172: 234, # '╛' + 173: 235, # '╜' + 174: 236, # '╝' + 175: 237, # '╞' + 176: 238, # '╟' + 177: 239, # '╠' + 178: 240, # '╡' + 179: 241, # 'Ё' + 180: 242, # '╢' + 181: 243, # '╣' + 182: 244, # '╤' + 183: 245, # '╥' + 184: 246, # '╦' + 185: 247, # '╧' + 186: 248, # '╨' + 187: 249, # '╩' + 188: 250, # '╪' + 189: 251, # '╫' + 190: 252, # '╬' + 191: 253, # '©' + 192: 27, # 'ю' + 193: 3, # 'а' + 194: 21, # 'б' + 195: 28, # 'ц' + 196: 13, # 'д' + 197: 2, # 'е' + 198: 39, # 'ф' + 199: 19, # 'г' + 200: 26, # 'х' + 201: 4, # 'и' + 202: 23, # 'й' + 203: 11, # 'к' + 204: 8, # 'л' + 205: 12, # 'м' + 206: 5, # 'н' + 207: 1, # 'о' + 208: 15, # 'п' + 209: 16, # 'я' + 210: 9, # 'р' + 211: 7, # 'с' + 212: 6, # 'т' + 213: 14, # 'у' + 214: 24, # 'ж' + 215: 10, # 'в' + 216: 17, # 'ь' + 217: 18, # 'ы' + 218: 20, # 'з' + 219: 25, # 'ш' + 220: 30, # 'э' + 221: 29, # 'щ' + 222: 22, # 'ч' + 223: 54, # 'ъ' + 224: 59, # 'Ю' + 225: 37, # 'А' + 226: 44, # 'Б' + 227: 58, # 'Ц' + 228: 41, # 'Д' + 229: 48, # 'Е' + 230: 53, # 'Ф' + 231: 46, # 'Г' + 232: 55, # 'Х' + 233: 42, # 'И' + 234: 60, # 'Й' + 235: 36, # 'К' + 236: 49, # 'Л' + 237: 38, # 'М' + 238: 31, # 'Н' + 239: 34, # 'О' + 240: 35, # 'П' + 241: 43, # 'Я' + 242: 45, # 'Р' + 243: 32, # 'С' + 244: 40, # 'Т' + 245: 52, # 'У' + 246: 56, # 'Ж' + 247: 33, # 'В' + 248: 61, # 'Ь' + 249: 62, # 'Ы' + 250: 51, # 'З' + 251: 57, # 'Ш' + 252: 47, # 'Э' + 253: 63, # 'Щ' + 254: 50, # 'Ч' + 255: 70, # 'Ъ' } -KOI8_R_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='KOI8-R', - language='Russian', - char_to_order_map=KOI8_R_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё') +KOI8_R_RUSSIAN_MODEL = SingleByteCharSetModel( + charset_name="KOI8-R", + language="Russian", + char_to_order_map=KOI8_R_RUSSIAN_CHAR_TO_ORDER, + language_model=RUSSIAN_LANG_MODEL, + typical_positive_ratio=0.976601, + keep_ascii_letters=False, + alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", +) MACCYRILLIC_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 37, # 'А' - 129: 44, # 'Б' - 130: 33, # 'В' - 131: 46, # 'Г' - 132: 41, # 'Д' - 133: 48, # 'Е' - 134: 56, # 'Ж' - 135: 51, # 'З' - 136: 42, # 'И' - 137: 60, # 'Й' - 138: 36, # 'К' - 139: 49, # 'Л' - 140: 38, # 'М' - 141: 31, # 'Н' - 142: 34, # 'О' - 143: 35, # 'П' - 144: 45, # 'Р' - 145: 32, # 'С' - 146: 40, # 'Т' - 147: 52, # 'У' - 148: 53, # 'Ф' - 149: 55, # 'Х' - 150: 58, # 'Ц' - 151: 50, # 'Ч' - 152: 57, # 'Ш' - 153: 63, # 'Щ' - 154: 70, # 'Ъ' - 155: 62, # 'Ы' - 156: 61, # 'Ь' - 157: 47, # 'Э' - 158: 59, # 'Ю' - 159: 43, # 'Я' - 160: 191, # '†' - 161: 192, # '°' - 162: 193, # 'Ґ' - 163: 194, # '£' - 164: 195, # '§' - 165: 196, # '•' - 166: 197, # '¶' - 167: 198, # 'І' - 168: 199, # '®' - 169: 200, # '©' - 170: 201, # '™' - 171: 202, # 'Ђ' - 172: 203, # 'ђ' - 173: 204, # '≠' - 174: 205, # 'Ѓ' - 175: 206, # 'ѓ' - 176: 207, # '∞' - 177: 208, # '±' - 178: 209, # '≤' - 179: 210, # '≥' - 180: 211, # 'і' - 181: 212, # 'µ' - 182: 213, # 'ґ' - 183: 214, # 'Ј' - 184: 215, # 'Є' - 185: 216, # 'є' - 186: 217, # 'Ї' - 187: 218, # 'ї' - 188: 219, # 'Љ' - 189: 220, # 'љ' - 190: 221, # 'Њ' - 191: 222, # 'њ' - 192: 223, # 'ј' - 193: 224, # 'Ѕ' - 194: 225, # '¬' - 195: 226, # '√' - 196: 227, # 'ƒ' - 197: 228, # '≈' - 198: 229, # '∆' - 199: 230, # '«' - 200: 231, # '»' - 201: 232, # '…' - 202: 233, # '\xa0' - 203: 234, # 'Ћ' - 204: 235, # 'ћ' - 205: 236, # 'Ќ' - 206: 237, # 'ќ' - 207: 238, # 'ѕ' - 208: 239, # '–' - 209: 240, # '—' - 210: 241, # '“' - 211: 242, # '”' - 212: 243, # '‘' - 213: 244, # '’' - 214: 245, # '÷' - 215: 246, # '„' - 216: 247, # 'Ў' - 217: 248, # 'ў' - 218: 249, # 'Џ' - 219: 250, # 'џ' - 220: 251, # '№' - 221: 252, # 'Ё' - 222: 68, # 'ё' - 223: 16, # 'я' - 224: 3, # 'а' - 225: 21, # 'б' - 226: 10, # 'в' - 227: 19, # 'г' - 228: 13, # 'д' - 229: 2, # 'е' - 230: 24, # 'ж' - 231: 20, # 'з' - 232: 4, # 'и' - 233: 23, # 'й' - 234: 11, # 'к' - 235: 8, # 'л' - 236: 12, # 'м' - 237: 5, # 'н' - 238: 1, # 'о' - 239: 15, # 'п' - 240: 9, # 'р' - 241: 7, # 'с' - 242: 6, # 'т' - 243: 14, # 'у' - 244: 39, # 'ф' - 245: 26, # 'х' - 246: 28, # 'ц' - 247: 22, # 'ч' - 248: 25, # 'ш' - 249: 29, # 'щ' - 250: 54, # 'ъ' - 251: 18, # 'ы' - 252: 17, # 'ь' - 253: 30, # 'э' - 254: 27, # 'ю' - 255: 255, # '€' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 142, # 'A' + 66: 143, # 'B' + 67: 144, # 'C' + 68: 145, # 'D' + 69: 146, # 'E' + 70: 147, # 'F' + 71: 148, # 'G' + 72: 149, # 'H' + 73: 150, # 'I' + 74: 151, # 'J' + 75: 152, # 'K' + 76: 74, # 'L' + 77: 153, # 'M' + 78: 75, # 'N' + 79: 154, # 'O' + 80: 155, # 'P' + 81: 156, # 'Q' + 82: 157, # 'R' + 83: 158, # 'S' + 84: 159, # 'T' + 85: 160, # 'U' + 86: 161, # 'V' + 87: 162, # 'W' + 88: 163, # 'X' + 89: 164, # 'Y' + 90: 165, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 71, # 'a' + 98: 172, # 'b' + 99: 66, # 'c' + 100: 173, # 'd' + 101: 65, # 'e' + 102: 174, # 'f' + 103: 76, # 'g' + 104: 175, # 'h' + 105: 64, # 'i' + 106: 176, # 'j' + 107: 177, # 'k' + 108: 77, # 'l' + 109: 72, # 'm' + 110: 178, # 'n' + 111: 69, # 'o' + 112: 67, # 'p' + 113: 179, # 'q' + 114: 78, # 'r' + 115: 73, # 's' + 116: 180, # 't' + 117: 181, # 'u' + 118: 79, # 'v' + 119: 182, # 'w' + 120: 183, # 'x' + 121: 184, # 'y' + 122: 185, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 37, # 'А' + 129: 44, # 'Б' + 130: 33, # 'В' + 131: 46, # 'Г' + 132: 41, # 'Д' + 133: 48, # 'Е' + 134: 56, # 'Ж' + 135: 51, # 'З' + 136: 42, # 'И' + 137: 60, # 'Й' + 138: 36, # 'К' + 139: 49, # 'Л' + 140: 38, # 'М' + 141: 31, # 'Н' + 142: 34, # 'О' + 143: 35, # 'П' + 144: 45, # 'Р' + 145: 32, # 'С' + 146: 40, # 'Т' + 147: 52, # 'У' + 148: 53, # 'Ф' + 149: 55, # 'Х' + 150: 58, # 'Ц' + 151: 50, # 'Ч' + 152: 57, # 'Ш' + 153: 63, # 'Щ' + 154: 70, # 'Ъ' + 155: 62, # 'Ы' + 156: 61, # 'Ь' + 157: 47, # 'Э' + 158: 59, # 'Ю' + 159: 43, # 'Я' + 160: 191, # '†' + 161: 192, # '°' + 162: 193, # 'Ґ' + 163: 194, # '£' + 164: 195, # '§' + 165: 196, # '•' + 166: 197, # '¶' + 167: 198, # 'І' + 168: 199, # '®' + 169: 200, # '©' + 170: 201, # '™' + 171: 202, # 'Ђ' + 172: 203, # 'ђ' + 173: 204, # '≠' + 174: 205, # 'Ѓ' + 175: 206, # 'ѓ' + 176: 207, # '∞' + 177: 208, # '±' + 178: 209, # '≤' + 179: 210, # '≥' + 180: 211, # 'і' + 181: 212, # 'µ' + 182: 213, # 'ґ' + 183: 214, # 'Ј' + 184: 215, # 'Є' + 185: 216, # 'є' + 186: 217, # 'Ї' + 187: 218, # 'ї' + 188: 219, # 'Љ' + 189: 220, # 'љ' + 190: 221, # 'Њ' + 191: 222, # 'њ' + 192: 223, # 'ј' + 193: 224, # 'Ѕ' + 194: 225, # '¬' + 195: 226, # '√' + 196: 227, # 'ƒ' + 197: 228, # '≈' + 198: 229, # '∆' + 199: 230, # '«' + 200: 231, # '»' + 201: 232, # '…' + 202: 233, # '\xa0' + 203: 234, # 'Ћ' + 204: 235, # 'ћ' + 205: 236, # 'Ќ' + 206: 237, # 'ќ' + 207: 238, # 'ѕ' + 208: 239, # '–' + 209: 240, # '—' + 210: 241, # '“' + 211: 242, # '”' + 212: 243, # '‘' + 213: 244, # '’' + 214: 245, # '÷' + 215: 246, # '„' + 216: 247, # 'Ў' + 217: 248, # 'ў' + 218: 249, # 'Џ' + 219: 250, # 'џ' + 220: 251, # '№' + 221: 252, # 'Ё' + 222: 68, # 'ё' + 223: 16, # 'я' + 224: 3, # 'а' + 225: 21, # 'б' + 226: 10, # 'в' + 227: 19, # 'г' + 228: 13, # 'д' + 229: 2, # 'е' + 230: 24, # 'ж' + 231: 20, # 'з' + 232: 4, # 'и' + 233: 23, # 'й' + 234: 11, # 'к' + 235: 8, # 'л' + 236: 12, # 'м' + 237: 5, # 'н' + 238: 1, # 'о' + 239: 15, # 'п' + 240: 9, # 'р' + 241: 7, # 'с' + 242: 6, # 'т' + 243: 14, # 'у' + 244: 39, # 'ф' + 245: 26, # 'х' + 246: 28, # 'ц' + 247: 22, # 'ч' + 248: 25, # 'ш' + 249: 29, # 'щ' + 250: 54, # 'ъ' + 251: 18, # 'ы' + 252: 17, # 'ь' + 253: 30, # 'э' + 254: 27, # 'ю' + 255: 255, # '€' } -MACCYRILLIC_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='MacCyrillic', - language='Russian', - char_to_order_map=MACCYRILLIC_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё') +MACCYRILLIC_RUSSIAN_MODEL = SingleByteCharSetModel( + charset_name="MacCyrillic", + language="Russian", + char_to_order_map=MACCYRILLIC_RUSSIAN_CHAR_TO_ORDER, + language_model=RUSSIAN_LANG_MODEL, + typical_positive_ratio=0.976601, + keep_ascii_letters=False, + alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", +) ISO_8859_5_RUSSIAN_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 142, # 'A' - 66: 143, # 'B' - 67: 144, # 'C' - 68: 145, # 'D' - 69: 146, # 'E' - 70: 147, # 'F' - 71: 148, # 'G' - 72: 149, # 'H' - 73: 150, # 'I' - 74: 151, # 'J' - 75: 152, # 'K' - 76: 74, # 'L' - 77: 153, # 'M' - 78: 75, # 'N' - 79: 154, # 'O' - 80: 155, # 'P' - 81: 156, # 'Q' - 82: 157, # 'R' - 83: 158, # 'S' - 84: 159, # 'T' - 85: 160, # 'U' - 86: 161, # 'V' - 87: 162, # 'W' - 88: 163, # 'X' - 89: 164, # 'Y' - 90: 165, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 71, # 'a' - 98: 172, # 'b' - 99: 66, # 'c' - 100: 173, # 'd' - 101: 65, # 'e' - 102: 174, # 'f' - 103: 76, # 'g' - 104: 175, # 'h' - 105: 64, # 'i' - 106: 176, # 'j' - 107: 177, # 'k' - 108: 77, # 'l' - 109: 72, # 'm' - 110: 178, # 'n' - 111: 69, # 'o' - 112: 67, # 'p' - 113: 179, # 'q' - 114: 78, # 'r' - 115: 73, # 's' - 116: 180, # 't' - 117: 181, # 'u' - 118: 79, # 'v' - 119: 182, # 'w' - 120: 183, # 'x' - 121: 184, # 'y' - 122: 185, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 191, # '\x80' - 129: 192, # '\x81' - 130: 193, # '\x82' - 131: 194, # '\x83' - 132: 195, # '\x84' - 133: 196, # '\x85' - 134: 197, # '\x86' - 135: 198, # '\x87' - 136: 199, # '\x88' - 137: 200, # '\x89' - 138: 201, # '\x8a' - 139: 202, # '\x8b' - 140: 203, # '\x8c' - 141: 204, # '\x8d' - 142: 205, # '\x8e' - 143: 206, # '\x8f' - 144: 207, # '\x90' - 145: 208, # '\x91' - 146: 209, # '\x92' - 147: 210, # '\x93' - 148: 211, # '\x94' - 149: 212, # '\x95' - 150: 213, # '\x96' - 151: 214, # '\x97' - 152: 215, # '\x98' - 153: 216, # '\x99' - 154: 217, # '\x9a' - 155: 218, # '\x9b' - 156: 219, # '\x9c' - 157: 220, # '\x9d' - 158: 221, # '\x9e' - 159: 222, # '\x9f' - 160: 223, # '\xa0' - 161: 224, # 'Ё' - 162: 225, # 'Ђ' - 163: 226, # 'Ѓ' - 164: 227, # 'Є' - 165: 228, # 'Ѕ' - 166: 229, # 'І' - 167: 230, # 'Ї' - 168: 231, # 'Ј' - 169: 232, # 'Љ' - 170: 233, # 'Њ' - 171: 234, # 'Ћ' - 172: 235, # 'Ќ' - 173: 236, # '\xad' - 174: 237, # 'Ў' - 175: 238, # 'Џ' - 176: 37, # 'А' - 177: 44, # 'Б' - 178: 33, # 'В' - 179: 46, # 'Г' - 180: 41, # 'Д' - 181: 48, # 'Е' - 182: 56, # 'Ж' - 183: 51, # 'З' - 184: 42, # 'И' - 185: 60, # 'Й' - 186: 36, # 'К' - 187: 49, # 'Л' - 188: 38, # 'М' - 189: 31, # 'Н' - 190: 34, # 'О' - 191: 35, # 'П' - 192: 45, # 'Р' - 193: 32, # 'С' - 194: 40, # 'Т' - 195: 52, # 'У' - 196: 53, # 'Ф' - 197: 55, # 'Х' - 198: 58, # 'Ц' - 199: 50, # 'Ч' - 200: 57, # 'Ш' - 201: 63, # 'Щ' - 202: 70, # 'Ъ' - 203: 62, # 'Ы' - 204: 61, # 'Ь' - 205: 47, # 'Э' - 206: 59, # 'Ю' - 207: 43, # 'Я' - 208: 3, # 'а' - 209: 21, # 'б' - 210: 10, # 'в' - 211: 19, # 'г' - 212: 13, # 'д' - 213: 2, # 'е' - 214: 24, # 'ж' - 215: 20, # 'з' - 216: 4, # 'и' - 217: 23, # 'й' - 218: 11, # 'к' - 219: 8, # 'л' - 220: 12, # 'м' - 221: 5, # 'н' - 222: 1, # 'о' - 223: 15, # 'п' - 224: 9, # 'р' - 225: 7, # 'с' - 226: 6, # 'т' - 227: 14, # 'у' - 228: 39, # 'ф' - 229: 26, # 'х' - 230: 28, # 'ц' - 231: 22, # 'ч' - 232: 25, # 'ш' - 233: 29, # 'щ' - 234: 54, # 'ъ' - 235: 18, # 'ы' - 236: 17, # 'ь' - 237: 30, # 'э' - 238: 27, # 'ю' - 239: 16, # 'я' - 240: 239, # '№' - 241: 68, # 'ё' - 242: 240, # 'ђ' - 243: 241, # 'ѓ' - 244: 242, # 'є' - 245: 243, # 'ѕ' - 246: 244, # 'і' - 247: 245, # 'ї' - 248: 246, # 'ј' - 249: 247, # 'љ' - 250: 248, # 'њ' - 251: 249, # 'ћ' - 252: 250, # 'ќ' - 253: 251, # '§' - 254: 252, # 'ў' - 255: 255, # 'џ' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 142, # 'A' + 66: 143, # 'B' + 67: 144, # 'C' + 68: 145, # 'D' + 69: 146, # 'E' + 70: 147, # 'F' + 71: 148, # 'G' + 72: 149, # 'H' + 73: 150, # 'I' + 74: 151, # 'J' + 75: 152, # 'K' + 76: 74, # 'L' + 77: 153, # 'M' + 78: 75, # 'N' + 79: 154, # 'O' + 80: 155, # 'P' + 81: 156, # 'Q' + 82: 157, # 'R' + 83: 158, # 'S' + 84: 159, # 'T' + 85: 160, # 'U' + 86: 161, # 'V' + 87: 162, # 'W' + 88: 163, # 'X' + 89: 164, # 'Y' + 90: 165, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 71, # 'a' + 98: 172, # 'b' + 99: 66, # 'c' + 100: 173, # 'd' + 101: 65, # 'e' + 102: 174, # 'f' + 103: 76, # 'g' + 104: 175, # 'h' + 105: 64, # 'i' + 106: 176, # 'j' + 107: 177, # 'k' + 108: 77, # 'l' + 109: 72, # 'm' + 110: 178, # 'n' + 111: 69, # 'o' + 112: 67, # 'p' + 113: 179, # 'q' + 114: 78, # 'r' + 115: 73, # 's' + 116: 180, # 't' + 117: 181, # 'u' + 118: 79, # 'v' + 119: 182, # 'w' + 120: 183, # 'x' + 121: 184, # 'y' + 122: 185, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 191, # '\x80' + 129: 192, # '\x81' + 130: 193, # '\x82' + 131: 194, # '\x83' + 132: 195, # '\x84' + 133: 196, # '\x85' + 134: 197, # '\x86' + 135: 198, # '\x87' + 136: 199, # '\x88' + 137: 200, # '\x89' + 138: 201, # '\x8a' + 139: 202, # '\x8b' + 140: 203, # '\x8c' + 141: 204, # '\x8d' + 142: 205, # '\x8e' + 143: 206, # '\x8f' + 144: 207, # '\x90' + 145: 208, # '\x91' + 146: 209, # '\x92' + 147: 210, # '\x93' + 148: 211, # '\x94' + 149: 212, # '\x95' + 150: 213, # '\x96' + 151: 214, # '\x97' + 152: 215, # '\x98' + 153: 216, # '\x99' + 154: 217, # '\x9a' + 155: 218, # '\x9b' + 156: 219, # '\x9c' + 157: 220, # '\x9d' + 158: 221, # '\x9e' + 159: 222, # '\x9f' + 160: 223, # '\xa0' + 161: 224, # 'Ё' + 162: 225, # 'Ђ' + 163: 226, # 'Ѓ' + 164: 227, # 'Є' + 165: 228, # 'Ѕ' + 166: 229, # 'І' + 167: 230, # 'Ї' + 168: 231, # 'Ј' + 169: 232, # 'Љ' + 170: 233, # 'Њ' + 171: 234, # 'Ћ' + 172: 235, # 'Ќ' + 173: 236, # '\xad' + 174: 237, # 'Ў' + 175: 238, # 'Џ' + 176: 37, # 'А' + 177: 44, # 'Б' + 178: 33, # 'В' + 179: 46, # 'Г' + 180: 41, # 'Д' + 181: 48, # 'Е' + 182: 56, # 'Ж' + 183: 51, # 'З' + 184: 42, # 'И' + 185: 60, # 'Й' + 186: 36, # 'К' + 187: 49, # 'Л' + 188: 38, # 'М' + 189: 31, # 'Н' + 190: 34, # 'О' + 191: 35, # 'П' + 192: 45, # 'Р' + 193: 32, # 'С' + 194: 40, # 'Т' + 195: 52, # 'У' + 196: 53, # 'Ф' + 197: 55, # 'Х' + 198: 58, # 'Ц' + 199: 50, # 'Ч' + 200: 57, # 'Ш' + 201: 63, # 'Щ' + 202: 70, # 'Ъ' + 203: 62, # 'Ы' + 204: 61, # 'Ь' + 205: 47, # 'Э' + 206: 59, # 'Ю' + 207: 43, # 'Я' + 208: 3, # 'а' + 209: 21, # 'б' + 210: 10, # 'в' + 211: 19, # 'г' + 212: 13, # 'д' + 213: 2, # 'е' + 214: 24, # 'ж' + 215: 20, # 'з' + 216: 4, # 'и' + 217: 23, # 'й' + 218: 11, # 'к' + 219: 8, # 'л' + 220: 12, # 'м' + 221: 5, # 'н' + 222: 1, # 'о' + 223: 15, # 'п' + 224: 9, # 'р' + 225: 7, # 'с' + 226: 6, # 'т' + 227: 14, # 'у' + 228: 39, # 'ф' + 229: 26, # 'х' + 230: 28, # 'ц' + 231: 22, # 'ч' + 232: 25, # 'ш' + 233: 29, # 'щ' + 234: 54, # 'ъ' + 235: 18, # 'ы' + 236: 17, # 'ь' + 237: 30, # 'э' + 238: 27, # 'ю' + 239: 16, # 'я' + 240: 239, # '№' + 241: 68, # 'ё' + 242: 240, # 'ђ' + 243: 241, # 'ѓ' + 244: 242, # 'є' + 245: 243, # 'ѕ' + 246: 244, # 'і' + 247: 245, # 'ї' + 248: 246, # 'ј' + 249: 247, # 'љ' + 250: 248, # 'њ' + 251: 249, # 'ћ' + 252: 250, # 'ќ' + 253: 251, # '§' + 254: 252, # 'ў' + 255: 255, # 'џ' } -ISO_8859_5_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-5', - language='Russian', - char_to_order_map=ISO_8859_5_RUSSIAN_CHAR_TO_ORDER, - language_model=RUSSIAN_LANG_MODEL, - typical_positive_ratio=0.976601, - keep_ascii_letters=False, - alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё') - +ISO_8859_5_RUSSIAN_MODEL = SingleByteCharSetModel( + charset_name="ISO-8859-5", + language="Russian", + char_to_order_map=ISO_8859_5_RUSSIAN_CHAR_TO_ORDER, + language_model=RUSSIAN_LANG_MODEL, + typical_positive_ratio=0.976601, + keep_ascii_letters=False, + alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё", +) diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py index 9a37db57..489cad93 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py @@ -1,9 +1,5 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- - from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - # 3: Positive # 2: Likely # 1: Unlikely @@ -4115,269 +4111,270 @@ THAI_LANG_MODEL = { # Character Mapping Table(s): TIS_620_THAI_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 254, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 254, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 253, # ' ' - 33: 253, # '!' - 34: 253, # '"' - 35: 253, # '#' - 36: 253, # '$' - 37: 253, # '%' - 38: 253, # '&' - 39: 253, # "'" - 40: 253, # '(' - 41: 253, # ')' - 42: 253, # '*' - 43: 253, # '+' - 44: 253, # ',' - 45: 253, # '-' - 46: 253, # '.' - 47: 253, # '/' - 48: 252, # '0' - 49: 252, # '1' - 50: 252, # '2' - 51: 252, # '3' - 52: 252, # '4' - 53: 252, # '5' - 54: 252, # '6' - 55: 252, # '7' - 56: 252, # '8' - 57: 252, # '9' - 58: 253, # ':' - 59: 253, # ';' - 60: 253, # '<' - 61: 253, # '=' - 62: 253, # '>' - 63: 253, # '?' - 64: 253, # '@' - 65: 182, # 'A' - 66: 106, # 'B' - 67: 107, # 'C' - 68: 100, # 'D' - 69: 183, # 'E' - 70: 184, # 'F' - 71: 185, # 'G' - 72: 101, # 'H' - 73: 94, # 'I' - 74: 186, # 'J' - 75: 187, # 'K' - 76: 108, # 'L' - 77: 109, # 'M' - 78: 110, # 'N' - 79: 111, # 'O' - 80: 188, # 'P' - 81: 189, # 'Q' - 82: 190, # 'R' - 83: 89, # 'S' - 84: 95, # 'T' - 85: 112, # 'U' - 86: 113, # 'V' - 87: 191, # 'W' - 88: 192, # 'X' - 89: 193, # 'Y' - 90: 194, # 'Z' - 91: 253, # '[' - 92: 253, # '\\' - 93: 253, # ']' - 94: 253, # '^' - 95: 253, # '_' - 96: 253, # '`' - 97: 64, # 'a' - 98: 72, # 'b' - 99: 73, # 'c' - 100: 114, # 'd' - 101: 74, # 'e' - 102: 115, # 'f' - 103: 116, # 'g' - 104: 102, # 'h' - 105: 81, # 'i' - 106: 201, # 'j' - 107: 117, # 'k' - 108: 90, # 'l' - 109: 103, # 'm' - 110: 78, # 'n' - 111: 82, # 'o' - 112: 96, # 'p' - 113: 202, # 'q' - 114: 91, # 'r' - 115: 79, # 's' - 116: 84, # 't' - 117: 104, # 'u' - 118: 105, # 'v' - 119: 97, # 'w' - 120: 98, # 'x' - 121: 92, # 'y' - 122: 203, # 'z' - 123: 253, # '{' - 124: 253, # '|' - 125: 253, # '}' - 126: 253, # '~' - 127: 253, # '\x7f' - 128: 209, # '\x80' - 129: 210, # '\x81' - 130: 211, # '\x82' - 131: 212, # '\x83' - 132: 213, # '\x84' - 133: 88, # '\x85' - 134: 214, # '\x86' - 135: 215, # '\x87' - 136: 216, # '\x88' - 137: 217, # '\x89' - 138: 218, # '\x8a' - 139: 219, # '\x8b' - 140: 220, # '\x8c' - 141: 118, # '\x8d' - 142: 221, # '\x8e' - 143: 222, # '\x8f' - 144: 223, # '\x90' - 145: 224, # '\x91' - 146: 99, # '\x92' - 147: 85, # '\x93' - 148: 83, # '\x94' - 149: 225, # '\x95' - 150: 226, # '\x96' - 151: 227, # '\x97' - 152: 228, # '\x98' - 153: 229, # '\x99' - 154: 230, # '\x9a' - 155: 231, # '\x9b' - 156: 232, # '\x9c' - 157: 233, # '\x9d' - 158: 234, # '\x9e' - 159: 235, # '\x9f' - 160: 236, # None - 161: 5, # 'ก' - 162: 30, # 'ข' - 163: 237, # 'ฃ' - 164: 24, # 'ค' - 165: 238, # 'ฅ' - 166: 75, # 'ฆ' - 167: 8, # 'ง' - 168: 26, # 'จ' - 169: 52, # 'ฉ' - 170: 34, # 'ช' - 171: 51, # 'ซ' - 172: 119, # 'ฌ' - 173: 47, # 'ญ' - 174: 58, # 'ฎ' - 175: 57, # 'ฏ' - 176: 49, # 'ฐ' - 177: 53, # 'ฑ' - 178: 55, # 'ฒ' - 179: 43, # 'ณ' - 180: 20, # 'ด' - 181: 19, # 'ต' - 182: 44, # 'ถ' - 183: 14, # 'ท' - 184: 48, # 'ธ' - 185: 3, # 'น' - 186: 17, # 'บ' - 187: 25, # 'ป' - 188: 39, # 'ผ' - 189: 62, # 'ฝ' - 190: 31, # 'พ' - 191: 54, # 'ฟ' - 192: 45, # 'ภ' - 193: 9, # 'ม' - 194: 16, # 'ย' - 195: 2, # 'ร' - 196: 61, # 'ฤ' - 197: 15, # 'ล' - 198: 239, # 'ฦ' - 199: 12, # 'ว' - 200: 42, # 'ศ' - 201: 46, # 'ษ' - 202: 18, # 'ส' - 203: 21, # 'ห' - 204: 76, # 'ฬ' - 205: 4, # 'อ' - 206: 66, # 'ฮ' - 207: 63, # 'ฯ' - 208: 22, # 'ะ' - 209: 10, # 'ั' - 210: 1, # 'า' - 211: 36, # 'ำ' - 212: 23, # 'ิ' - 213: 13, # 'ี' - 214: 40, # 'ึ' - 215: 27, # 'ื' - 216: 32, # 'ุ' - 217: 35, # 'ู' - 218: 86, # 'ฺ' - 219: 240, # None - 220: 241, # None - 221: 242, # None - 222: 243, # None - 223: 244, # '฿' - 224: 11, # 'เ' - 225: 28, # 'แ' - 226: 41, # 'โ' - 227: 29, # 'ใ' - 228: 33, # 'ไ' - 229: 245, # 'ๅ' - 230: 50, # 'ๆ' - 231: 37, # '็' - 232: 6, # '่' - 233: 7, # '้' - 234: 67, # '๊' - 235: 77, # '๋' - 236: 38, # '์' - 237: 93, # 'ํ' - 238: 246, # '๎' - 239: 247, # '๏' - 240: 68, # '๐' - 241: 56, # '๑' - 242: 59, # '๒' - 243: 65, # '๓' - 244: 69, # '๔' - 245: 60, # '๕' - 246: 70, # '๖' - 247: 80, # '๗' - 248: 71, # '๘' - 249: 87, # '๙' - 250: 248, # '๚' - 251: 249, # '๛' - 252: 250, # None - 253: 251, # None - 254: 252, # None - 255: 253, # None + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 254, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 254, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 253, # ' ' + 33: 253, # '!' + 34: 253, # '"' + 35: 253, # '#' + 36: 253, # '$' + 37: 253, # '%' + 38: 253, # '&' + 39: 253, # "'" + 40: 253, # '(' + 41: 253, # ')' + 42: 253, # '*' + 43: 253, # '+' + 44: 253, # ',' + 45: 253, # '-' + 46: 253, # '.' + 47: 253, # '/' + 48: 252, # '0' + 49: 252, # '1' + 50: 252, # '2' + 51: 252, # '3' + 52: 252, # '4' + 53: 252, # '5' + 54: 252, # '6' + 55: 252, # '7' + 56: 252, # '8' + 57: 252, # '9' + 58: 253, # ':' + 59: 253, # ';' + 60: 253, # '<' + 61: 253, # '=' + 62: 253, # '>' + 63: 253, # '?' + 64: 253, # '@' + 65: 182, # 'A' + 66: 106, # 'B' + 67: 107, # 'C' + 68: 100, # 'D' + 69: 183, # 'E' + 70: 184, # 'F' + 71: 185, # 'G' + 72: 101, # 'H' + 73: 94, # 'I' + 74: 186, # 'J' + 75: 187, # 'K' + 76: 108, # 'L' + 77: 109, # 'M' + 78: 110, # 'N' + 79: 111, # 'O' + 80: 188, # 'P' + 81: 189, # 'Q' + 82: 190, # 'R' + 83: 89, # 'S' + 84: 95, # 'T' + 85: 112, # 'U' + 86: 113, # 'V' + 87: 191, # 'W' + 88: 192, # 'X' + 89: 193, # 'Y' + 90: 194, # 'Z' + 91: 253, # '[' + 92: 253, # '\\' + 93: 253, # ']' + 94: 253, # '^' + 95: 253, # '_' + 96: 253, # '`' + 97: 64, # 'a' + 98: 72, # 'b' + 99: 73, # 'c' + 100: 114, # 'd' + 101: 74, # 'e' + 102: 115, # 'f' + 103: 116, # 'g' + 104: 102, # 'h' + 105: 81, # 'i' + 106: 201, # 'j' + 107: 117, # 'k' + 108: 90, # 'l' + 109: 103, # 'm' + 110: 78, # 'n' + 111: 82, # 'o' + 112: 96, # 'p' + 113: 202, # 'q' + 114: 91, # 'r' + 115: 79, # 's' + 116: 84, # 't' + 117: 104, # 'u' + 118: 105, # 'v' + 119: 97, # 'w' + 120: 98, # 'x' + 121: 92, # 'y' + 122: 203, # 'z' + 123: 253, # '{' + 124: 253, # '|' + 125: 253, # '}' + 126: 253, # '~' + 127: 253, # '\x7f' + 128: 209, # '\x80' + 129: 210, # '\x81' + 130: 211, # '\x82' + 131: 212, # '\x83' + 132: 213, # '\x84' + 133: 88, # '\x85' + 134: 214, # '\x86' + 135: 215, # '\x87' + 136: 216, # '\x88' + 137: 217, # '\x89' + 138: 218, # '\x8a' + 139: 219, # '\x8b' + 140: 220, # '\x8c' + 141: 118, # '\x8d' + 142: 221, # '\x8e' + 143: 222, # '\x8f' + 144: 223, # '\x90' + 145: 224, # '\x91' + 146: 99, # '\x92' + 147: 85, # '\x93' + 148: 83, # '\x94' + 149: 225, # '\x95' + 150: 226, # '\x96' + 151: 227, # '\x97' + 152: 228, # '\x98' + 153: 229, # '\x99' + 154: 230, # '\x9a' + 155: 231, # '\x9b' + 156: 232, # '\x9c' + 157: 233, # '\x9d' + 158: 234, # '\x9e' + 159: 235, # '\x9f' + 160: 236, # None + 161: 5, # 'ก' + 162: 30, # 'ข' + 163: 237, # 'ฃ' + 164: 24, # 'ค' + 165: 238, # 'ฅ' + 166: 75, # 'ฆ' + 167: 8, # 'ง' + 168: 26, # 'จ' + 169: 52, # 'ฉ' + 170: 34, # 'ช' + 171: 51, # 'ซ' + 172: 119, # 'ฌ' + 173: 47, # 'ญ' + 174: 58, # 'ฎ' + 175: 57, # 'ฏ' + 176: 49, # 'ฐ' + 177: 53, # 'ฑ' + 178: 55, # 'ฒ' + 179: 43, # 'ณ' + 180: 20, # 'ด' + 181: 19, # 'ต' + 182: 44, # 'ถ' + 183: 14, # 'ท' + 184: 48, # 'ธ' + 185: 3, # 'น' + 186: 17, # 'บ' + 187: 25, # 'ป' + 188: 39, # 'ผ' + 189: 62, # 'ฝ' + 190: 31, # 'พ' + 191: 54, # 'ฟ' + 192: 45, # 'ภ' + 193: 9, # 'ม' + 194: 16, # 'ย' + 195: 2, # 'ร' + 196: 61, # 'ฤ' + 197: 15, # 'ล' + 198: 239, # 'ฦ' + 199: 12, # 'ว' + 200: 42, # 'ศ' + 201: 46, # 'ษ' + 202: 18, # 'ส' + 203: 21, # 'ห' + 204: 76, # 'ฬ' + 205: 4, # 'อ' + 206: 66, # 'ฮ' + 207: 63, # 'ฯ' + 208: 22, # 'ะ' + 209: 10, # 'ั' + 210: 1, # 'า' + 211: 36, # 'ำ' + 212: 23, # 'ิ' + 213: 13, # 'ี' + 214: 40, # 'ึ' + 215: 27, # 'ื' + 216: 32, # 'ุ' + 217: 35, # 'ู' + 218: 86, # 'ฺ' + 219: 240, # None + 220: 241, # None + 221: 242, # None + 222: 243, # None + 223: 244, # '฿' + 224: 11, # 'เ' + 225: 28, # 'แ' + 226: 41, # 'โ' + 227: 29, # 'ใ' + 228: 33, # 'ไ' + 229: 245, # 'ๅ' + 230: 50, # 'ๆ' + 231: 37, # '็' + 232: 6, # '่' + 233: 7, # '้' + 234: 67, # '๊' + 235: 77, # '๋' + 236: 38, # '์' + 237: 93, # 'ํ' + 238: 246, # '๎' + 239: 247, # '๏' + 240: 68, # '๐' + 241: 56, # '๑' + 242: 59, # '๒' + 243: 65, # '๓' + 244: 69, # '๔' + 245: 60, # '๕' + 246: 70, # '๖' + 247: 80, # '๗' + 248: 71, # '๘' + 249: 87, # '๙' + 250: 248, # '๚' + 251: 249, # '๛' + 252: 250, # None + 253: 251, # None + 254: 252, # None + 255: 253, # None } -TIS_620_THAI_MODEL = SingleByteCharSetModel(charset_name='TIS-620', - language='Thai', - char_to_order_map=TIS_620_THAI_CHAR_TO_ORDER, - language_model=THAI_LANG_MODEL, - typical_positive_ratio=0.926386, - keep_ascii_letters=False, - alphabet='กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛') - +TIS_620_THAI_MODEL = SingleByteCharSetModel( + charset_name="TIS-620", + language="Thai", + char_to_order_map=TIS_620_THAI_CHAR_TO_ORDER, + language_model=THAI_LANG_MODEL, + typical_positive_ratio=0.926386, + keep_ascii_letters=False, + alphabet="กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛", +) diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py index 43f4230a..291857c2 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py @@ -1,9 +1,5 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- - from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel - # 3: Positive # 2: Likely # 1: Unlikely @@ -4115,269 +4111,270 @@ TURKISH_LANG_MODEL = { # Character Mapping Table(s): ISO_8859_9_TURKISH_CHAR_TO_ORDER = { - 0: 255, # '\x00' - 1: 255, # '\x01' - 2: 255, # '\x02' - 3: 255, # '\x03' - 4: 255, # '\x04' - 5: 255, # '\x05' - 6: 255, # '\x06' - 7: 255, # '\x07' - 8: 255, # '\x08' - 9: 255, # '\t' - 10: 255, # '\n' - 11: 255, # '\x0b' - 12: 255, # '\x0c' - 13: 255, # '\r' - 14: 255, # '\x0e' - 15: 255, # '\x0f' - 16: 255, # '\x10' - 17: 255, # '\x11' - 18: 255, # '\x12' - 19: 255, # '\x13' - 20: 255, # '\x14' - 21: 255, # '\x15' - 22: 255, # '\x16' - 23: 255, # '\x17' - 24: 255, # '\x18' - 25: 255, # '\x19' - 26: 255, # '\x1a' - 27: 255, # '\x1b' - 28: 255, # '\x1c' - 29: 255, # '\x1d' - 30: 255, # '\x1e' - 31: 255, # '\x1f' - 32: 255, # ' ' - 33: 255, # '!' - 34: 255, # '"' - 35: 255, # '#' - 36: 255, # '$' - 37: 255, # '%' - 38: 255, # '&' - 39: 255, # "'" - 40: 255, # '(' - 41: 255, # ')' - 42: 255, # '*' - 43: 255, # '+' - 44: 255, # ',' - 45: 255, # '-' - 46: 255, # '.' - 47: 255, # '/' - 48: 255, # '0' - 49: 255, # '1' - 50: 255, # '2' - 51: 255, # '3' - 52: 255, # '4' - 53: 255, # '5' - 54: 255, # '6' - 55: 255, # '7' - 56: 255, # '8' - 57: 255, # '9' - 58: 255, # ':' - 59: 255, # ';' - 60: 255, # '<' - 61: 255, # '=' - 62: 255, # '>' - 63: 255, # '?' - 64: 255, # '@' - 65: 23, # 'A' - 66: 37, # 'B' - 67: 47, # 'C' - 68: 39, # 'D' - 69: 29, # 'E' - 70: 52, # 'F' - 71: 36, # 'G' - 72: 45, # 'H' - 73: 53, # 'I' - 74: 60, # 'J' - 75: 16, # 'K' - 76: 49, # 'L' - 77: 20, # 'M' - 78: 46, # 'N' - 79: 42, # 'O' - 80: 48, # 'P' - 81: 69, # 'Q' - 82: 44, # 'R' - 83: 35, # 'S' - 84: 31, # 'T' - 85: 51, # 'U' - 86: 38, # 'V' - 87: 62, # 'W' - 88: 65, # 'X' - 89: 43, # 'Y' - 90: 56, # 'Z' - 91: 255, # '[' - 92: 255, # '\\' - 93: 255, # ']' - 94: 255, # '^' - 95: 255, # '_' - 96: 255, # '`' - 97: 1, # 'a' - 98: 21, # 'b' - 99: 28, # 'c' - 100: 12, # 'd' - 101: 2, # 'e' - 102: 18, # 'f' - 103: 27, # 'g' - 104: 25, # 'h' - 105: 3, # 'i' - 106: 24, # 'j' - 107: 10, # 'k' - 108: 5, # 'l' - 109: 13, # 'm' - 110: 4, # 'n' - 111: 15, # 'o' - 112: 26, # 'p' - 113: 64, # 'q' - 114: 7, # 'r' - 115: 8, # 's' - 116: 9, # 't' - 117: 14, # 'u' - 118: 32, # 'v' - 119: 57, # 'w' - 120: 58, # 'x' - 121: 11, # 'y' - 122: 22, # 'z' - 123: 255, # '{' - 124: 255, # '|' - 125: 255, # '}' - 126: 255, # '~' - 127: 255, # '\x7f' - 128: 180, # '\x80' - 129: 179, # '\x81' - 130: 178, # '\x82' - 131: 177, # '\x83' - 132: 176, # '\x84' - 133: 175, # '\x85' - 134: 174, # '\x86' - 135: 173, # '\x87' - 136: 172, # '\x88' - 137: 171, # '\x89' - 138: 170, # '\x8a' - 139: 169, # '\x8b' - 140: 168, # '\x8c' - 141: 167, # '\x8d' - 142: 166, # '\x8e' - 143: 165, # '\x8f' - 144: 164, # '\x90' - 145: 163, # '\x91' - 146: 162, # '\x92' - 147: 161, # '\x93' - 148: 160, # '\x94' - 149: 159, # '\x95' - 150: 101, # '\x96' - 151: 158, # '\x97' - 152: 157, # '\x98' - 153: 156, # '\x99' - 154: 155, # '\x9a' - 155: 154, # '\x9b' - 156: 153, # '\x9c' - 157: 152, # '\x9d' - 158: 151, # '\x9e' - 159: 106, # '\x9f' - 160: 150, # '\xa0' - 161: 149, # '¡' - 162: 148, # '¢' - 163: 147, # '£' - 164: 146, # '¤' - 165: 145, # '¥' - 166: 144, # '¦' - 167: 100, # '§' - 168: 143, # '¨' - 169: 142, # '©' - 170: 141, # 'ª' - 171: 140, # '«' - 172: 139, # '¬' - 173: 138, # '\xad' - 174: 137, # '®' - 175: 136, # '¯' - 176: 94, # '°' - 177: 80, # '±' - 178: 93, # '²' - 179: 135, # '³' - 180: 105, # '´' - 181: 134, # 'µ' - 182: 133, # '¶' - 183: 63, # '·' - 184: 132, # '¸' - 185: 131, # '¹' - 186: 130, # 'º' - 187: 129, # '»' - 188: 128, # '¼' - 189: 127, # '½' - 190: 126, # '¾' - 191: 125, # '¿' - 192: 124, # 'À' - 193: 104, # 'Á' - 194: 73, # 'Â' - 195: 99, # 'Ã' - 196: 79, # 'Ä' - 197: 85, # 'Å' - 198: 123, # 'Æ' - 199: 54, # 'Ç' - 200: 122, # 'È' - 201: 98, # 'É' - 202: 92, # 'Ê' - 203: 121, # 'Ë' - 204: 120, # 'Ì' - 205: 91, # 'Í' - 206: 103, # 'Î' - 207: 119, # 'Ï' - 208: 68, # 'Ğ' - 209: 118, # 'Ñ' - 210: 117, # 'Ò' - 211: 97, # 'Ó' - 212: 116, # 'Ô' - 213: 115, # 'Õ' - 214: 50, # 'Ö' - 215: 90, # '×' - 216: 114, # 'Ø' - 217: 113, # 'Ù' - 218: 112, # 'Ú' - 219: 111, # 'Û' - 220: 55, # 'Ü' - 221: 41, # 'İ' - 222: 40, # 'Ş' - 223: 86, # 'ß' - 224: 89, # 'à' - 225: 70, # 'á' - 226: 59, # 'â' - 227: 78, # 'ã' - 228: 71, # 'ä' - 229: 82, # 'å' - 230: 88, # 'æ' - 231: 33, # 'ç' - 232: 77, # 'è' - 233: 66, # 'é' - 234: 84, # 'ê' - 235: 83, # 'ë' - 236: 110, # 'ì' - 237: 75, # 'í' - 238: 61, # 'î' - 239: 96, # 'ï' - 240: 30, # 'ğ' - 241: 67, # 'ñ' - 242: 109, # 'ò' - 243: 74, # 'ó' - 244: 87, # 'ô' - 245: 102, # 'õ' - 246: 34, # 'ö' - 247: 95, # '÷' - 248: 81, # 'ø' - 249: 108, # 'ù' - 250: 76, # 'ú' - 251: 72, # 'û' - 252: 17, # 'ü' - 253: 6, # 'ı' - 254: 19, # 'ş' - 255: 107, # 'ÿ' + 0: 255, # '\x00' + 1: 255, # '\x01' + 2: 255, # '\x02' + 3: 255, # '\x03' + 4: 255, # '\x04' + 5: 255, # '\x05' + 6: 255, # '\x06' + 7: 255, # '\x07' + 8: 255, # '\x08' + 9: 255, # '\t' + 10: 255, # '\n' + 11: 255, # '\x0b' + 12: 255, # '\x0c' + 13: 255, # '\r' + 14: 255, # '\x0e' + 15: 255, # '\x0f' + 16: 255, # '\x10' + 17: 255, # '\x11' + 18: 255, # '\x12' + 19: 255, # '\x13' + 20: 255, # '\x14' + 21: 255, # '\x15' + 22: 255, # '\x16' + 23: 255, # '\x17' + 24: 255, # '\x18' + 25: 255, # '\x19' + 26: 255, # '\x1a' + 27: 255, # '\x1b' + 28: 255, # '\x1c' + 29: 255, # '\x1d' + 30: 255, # '\x1e' + 31: 255, # '\x1f' + 32: 255, # ' ' + 33: 255, # '!' + 34: 255, # '"' + 35: 255, # '#' + 36: 255, # '$' + 37: 255, # '%' + 38: 255, # '&' + 39: 255, # "'" + 40: 255, # '(' + 41: 255, # ')' + 42: 255, # '*' + 43: 255, # '+' + 44: 255, # ',' + 45: 255, # '-' + 46: 255, # '.' + 47: 255, # '/' + 48: 255, # '0' + 49: 255, # '1' + 50: 255, # '2' + 51: 255, # '3' + 52: 255, # '4' + 53: 255, # '5' + 54: 255, # '6' + 55: 255, # '7' + 56: 255, # '8' + 57: 255, # '9' + 58: 255, # ':' + 59: 255, # ';' + 60: 255, # '<' + 61: 255, # '=' + 62: 255, # '>' + 63: 255, # '?' + 64: 255, # '@' + 65: 23, # 'A' + 66: 37, # 'B' + 67: 47, # 'C' + 68: 39, # 'D' + 69: 29, # 'E' + 70: 52, # 'F' + 71: 36, # 'G' + 72: 45, # 'H' + 73: 53, # 'I' + 74: 60, # 'J' + 75: 16, # 'K' + 76: 49, # 'L' + 77: 20, # 'M' + 78: 46, # 'N' + 79: 42, # 'O' + 80: 48, # 'P' + 81: 69, # 'Q' + 82: 44, # 'R' + 83: 35, # 'S' + 84: 31, # 'T' + 85: 51, # 'U' + 86: 38, # 'V' + 87: 62, # 'W' + 88: 65, # 'X' + 89: 43, # 'Y' + 90: 56, # 'Z' + 91: 255, # '[' + 92: 255, # '\\' + 93: 255, # ']' + 94: 255, # '^' + 95: 255, # '_' + 96: 255, # '`' + 97: 1, # 'a' + 98: 21, # 'b' + 99: 28, # 'c' + 100: 12, # 'd' + 101: 2, # 'e' + 102: 18, # 'f' + 103: 27, # 'g' + 104: 25, # 'h' + 105: 3, # 'i' + 106: 24, # 'j' + 107: 10, # 'k' + 108: 5, # 'l' + 109: 13, # 'm' + 110: 4, # 'n' + 111: 15, # 'o' + 112: 26, # 'p' + 113: 64, # 'q' + 114: 7, # 'r' + 115: 8, # 's' + 116: 9, # 't' + 117: 14, # 'u' + 118: 32, # 'v' + 119: 57, # 'w' + 120: 58, # 'x' + 121: 11, # 'y' + 122: 22, # 'z' + 123: 255, # '{' + 124: 255, # '|' + 125: 255, # '}' + 126: 255, # '~' + 127: 255, # '\x7f' + 128: 180, # '\x80' + 129: 179, # '\x81' + 130: 178, # '\x82' + 131: 177, # '\x83' + 132: 176, # '\x84' + 133: 175, # '\x85' + 134: 174, # '\x86' + 135: 173, # '\x87' + 136: 172, # '\x88' + 137: 171, # '\x89' + 138: 170, # '\x8a' + 139: 169, # '\x8b' + 140: 168, # '\x8c' + 141: 167, # '\x8d' + 142: 166, # '\x8e' + 143: 165, # '\x8f' + 144: 164, # '\x90' + 145: 163, # '\x91' + 146: 162, # '\x92' + 147: 161, # '\x93' + 148: 160, # '\x94' + 149: 159, # '\x95' + 150: 101, # '\x96' + 151: 158, # '\x97' + 152: 157, # '\x98' + 153: 156, # '\x99' + 154: 155, # '\x9a' + 155: 154, # '\x9b' + 156: 153, # '\x9c' + 157: 152, # '\x9d' + 158: 151, # '\x9e' + 159: 106, # '\x9f' + 160: 150, # '\xa0' + 161: 149, # '¡' + 162: 148, # '¢' + 163: 147, # '£' + 164: 146, # '¤' + 165: 145, # '¥' + 166: 144, # '¦' + 167: 100, # '§' + 168: 143, # '¨' + 169: 142, # '©' + 170: 141, # 'ª' + 171: 140, # '«' + 172: 139, # '¬' + 173: 138, # '\xad' + 174: 137, # '®' + 175: 136, # '¯' + 176: 94, # '°' + 177: 80, # '±' + 178: 93, # '²' + 179: 135, # '³' + 180: 105, # '´' + 181: 134, # 'µ' + 182: 133, # '¶' + 183: 63, # '·' + 184: 132, # '¸' + 185: 131, # '¹' + 186: 130, # 'º' + 187: 129, # '»' + 188: 128, # '¼' + 189: 127, # '½' + 190: 126, # '¾' + 191: 125, # '¿' + 192: 124, # 'À' + 193: 104, # 'Á' + 194: 73, # 'Â' + 195: 99, # 'Ã' + 196: 79, # 'Ä' + 197: 85, # 'Å' + 198: 123, # 'Æ' + 199: 54, # 'Ç' + 200: 122, # 'È' + 201: 98, # 'É' + 202: 92, # 'Ê' + 203: 121, # 'Ë' + 204: 120, # 'Ì' + 205: 91, # 'Í' + 206: 103, # 'Î' + 207: 119, # 'Ï' + 208: 68, # 'Ğ' + 209: 118, # 'Ñ' + 210: 117, # 'Ò' + 211: 97, # 'Ó' + 212: 116, # 'Ô' + 213: 115, # 'Õ' + 214: 50, # 'Ö' + 215: 90, # '×' + 216: 114, # 'Ø' + 217: 113, # 'Ù' + 218: 112, # 'Ú' + 219: 111, # 'Û' + 220: 55, # 'Ü' + 221: 41, # 'İ' + 222: 40, # 'Ş' + 223: 86, # 'ß' + 224: 89, # 'à' + 225: 70, # 'á' + 226: 59, # 'â' + 227: 78, # 'ã' + 228: 71, # 'ä' + 229: 82, # 'å' + 230: 88, # 'æ' + 231: 33, # 'ç' + 232: 77, # 'è' + 233: 66, # 'é' + 234: 84, # 'ê' + 235: 83, # 'ë' + 236: 110, # 'ì' + 237: 75, # 'í' + 238: 61, # 'î' + 239: 96, # 'ï' + 240: 30, # 'ğ' + 241: 67, # 'ñ' + 242: 109, # 'ò' + 243: 74, # 'ó' + 244: 87, # 'ô' + 245: 102, # 'õ' + 246: 34, # 'ö' + 247: 95, # '÷' + 248: 81, # 'ø' + 249: 108, # 'ù' + 250: 76, # 'ú' + 251: 72, # 'û' + 252: 17, # 'ü' + 253: 6, # 'ı' + 254: 19, # 'ş' + 255: 107, # 'ÿ' } -ISO_8859_9_TURKISH_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-9', - language='Turkish', - char_to_order_map=ISO_8859_9_TURKISH_CHAR_TO_ORDER, - language_model=TURKISH_LANG_MODEL, - typical_positive_ratio=0.97029, - keep_ascii_letters=True, - alphabet='ABCDEFGHIJKLMNOPRSTUVYZabcdefghijklmnoprstuvyzÂÇÎÖÛÜâçîöûüĞğİıŞş') - +ISO_8859_9_TURKISH_MODEL = SingleByteCharSetModel( + charset_name="ISO-8859-9", + language="Turkish", + char_to_order_map=ISO_8859_9_TURKISH_CHAR_TO_ORDER, + language_model=TURKISH_LANG_MODEL, + typical_positive_ratio=0.97029, + keep_ascii_letters=True, + alphabet="ABCDEFGHIJKLMNOPRSTUVYZabcdefghijklmnoprstuvyzÂÇÎÖÛÜâçîöûüĞğİıŞş", +) diff --git a/env/Lib/site-packages/pip/_vendor/chardet/latin1prober.py b/env/Lib/site-packages/pip/_vendor/chardet/latin1prober.py index 7d1e8c20..59a01d91 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/latin1prober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/latin1prober.py @@ -26,6 +26,8 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from typing import List, Union + from .charsetprober import CharSetProber from .enums import ProbingState @@ -41,6 +43,7 @@ ASV = 6 # accent small vowel ASO = 7 # accent small other CLASS_NUM = 8 # total classes +# fmt: off Latin1_CharToClass = ( OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 00 - 07 OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH, # 08 - 0F @@ -91,34 +94,34 @@ Latin1ClassModel = ( 0, 3, 1, 3, 1, 1, 1, 3, # ASV 0, 3, 1, 3, 1, 1, 3, 3, # ASO ) +# fmt: on class Latin1Prober(CharSetProber): - def __init__(self): - super(Latin1Prober, self).__init__() - self._last_char_class = None - self._freq_counter = None + def __init__(self) -> None: + super().__init__() + self._last_char_class = OTH + self._freq_counter: List[int] = [] self.reset() - def reset(self): + def reset(self) -> None: self._last_char_class = OTH self._freq_counter = [0] * FREQ_CAT_NUM - CharSetProber.reset(self) + super().reset() @property - def charset_name(self): + def charset_name(self) -> str: return "ISO-8859-1" @property - def language(self): + def language(self) -> str: return "" - def feed(self, byte_str): - byte_str = self.filter_with_english_letters(byte_str) + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: + byte_str = self.remove_xml_tags(byte_str) for c in byte_str: char_class = Latin1_CharToClass[c] - freq = Latin1ClassModel[(self._last_char_class * CLASS_NUM) - + char_class] + freq = Latin1ClassModel[(self._last_char_class * CLASS_NUM) + char_class] if freq == 0: self._state = ProbingState.NOT_ME break @@ -127,19 +130,18 @@ class Latin1Prober(CharSetProber): return self.state - def get_confidence(self): + def get_confidence(self) -> float: if self.state == ProbingState.NOT_ME: return 0.01 total = sum(self._freq_counter) - if total < 0.01: - confidence = 0.0 - else: - confidence = ((self._freq_counter[3] - self._freq_counter[1] * 20.0) - / total) - if confidence < 0.0: - confidence = 0.0 + confidence = ( + 0.0 + if total < 0.01 + else (self._freq_counter[3] - self._freq_counter[1] * 20.0) / total + ) + confidence = max(confidence, 0.0) # lower the confidence of latin1 so that other more accurate # detector can take priority. - confidence = confidence * 0.73 + confidence *= 0.73 return confidence diff --git a/env/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py b/env/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py index 6256ecfd..666307e8 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py @@ -27,8 +27,12 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from typing import Optional, Union + +from .chardistribution import CharDistributionAnalysis from .charsetprober import CharSetProber -from .enums import ProbingState, MachineState +from .codingstatemachine import CodingStateMachine +from .enums import LanguageFilter, MachineState, ProbingState class MultiByteCharSetProber(CharSetProber): @@ -36,56 +40,56 @@ class MultiByteCharSetProber(CharSetProber): MultiByteCharSetProber """ - def __init__(self, lang_filter=None): - super(MultiByteCharSetProber, self).__init__(lang_filter=lang_filter) - self.distribution_analyzer = None - self.coding_sm = None - self._last_char = [0, 0] + def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: + super().__init__(lang_filter=lang_filter) + self.distribution_analyzer: Optional[CharDistributionAnalysis] = None + self.coding_sm: Optional[CodingStateMachine] = None + self._last_char = bytearray(b"\0\0") - def reset(self): - super(MultiByteCharSetProber, self).reset() + def reset(self) -> None: + super().reset() if self.coding_sm: self.coding_sm.reset() if self.distribution_analyzer: self.distribution_analyzer.reset() - self._last_char = [0, 0] - - @property - def charset_name(self): - raise NotImplementedError + self._last_char = bytearray(b"\0\0") - @property - def language(self): - raise NotImplementedError + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: + assert self.coding_sm is not None + assert self.distribution_analyzer is not None - def feed(self, byte_str): - for i in range(len(byte_str)): - coding_state = self.coding_sm.next_state(byte_str[i]) + for i, byte in enumerate(byte_str): + coding_state = self.coding_sm.next_state(byte) if coding_state == MachineState.ERROR: - self.logger.debug('%s %s prober hit error at byte %s', - self.charset_name, self.language, i) + self.logger.debug( + "%s %s prober hit error at byte %s", + self.charset_name, + self.language, + i, + ) self._state = ProbingState.NOT_ME break - elif coding_state == MachineState.ITS_ME: + if coding_state == MachineState.ITS_ME: self._state = ProbingState.FOUND_IT break - elif coding_state == MachineState.START: + if coding_state == MachineState.START: char_len = self.coding_sm.get_current_charlen() if i == 0: - self._last_char[1] = byte_str[0] + self._last_char[1] = byte self.distribution_analyzer.feed(self._last_char, char_len) else: - self.distribution_analyzer.feed(byte_str[i - 1:i + 1], - char_len) + self.distribution_analyzer.feed(byte_str[i - 1 : i + 1], char_len) self._last_char[0] = byte_str[-1] if self.state == ProbingState.DETECTING: - if (self.distribution_analyzer.got_enough_data() and - (self.get_confidence() > self.SHORTCUT_THRESHOLD)): + if self.distribution_analyzer.got_enough_data() and ( + self.get_confidence() > self.SHORTCUT_THRESHOLD + ): self._state = ProbingState.FOUND_IT return self.state - def get_confidence(self): + def get_confidence(self) -> float: + assert self.distribution_analyzer is not None return self.distribution_analyzer.get_confidence() diff --git a/env/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py b/env/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py index 530abe75..6cb9cc7b 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py @@ -27,20 +27,22 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from .big5prober import Big5Prober from .charsetgroupprober import CharSetGroupProber -from .utf8prober import UTF8Prober -from .sjisprober import SJISProber +from .cp949prober import CP949Prober +from .enums import LanguageFilter from .eucjpprober import EUCJPProber -from .gb2312prober import GB2312Prober from .euckrprober import EUCKRProber -from .cp949prober import CP949Prober -from .big5prober import Big5Prober from .euctwprober import EUCTWProber +from .gb2312prober import GB2312Prober +from .johabprober import JOHABProber +from .sjisprober import SJISProber +from .utf8prober import UTF8Prober class MBCSGroupProber(CharSetGroupProber): - def __init__(self, lang_filter=None): - super(MBCSGroupProber, self).__init__(lang_filter=lang_filter) + def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None: + super().__init__(lang_filter=lang_filter) self.probers = [ UTF8Prober(), SJISProber(), @@ -49,6 +51,7 @@ class MBCSGroupProber(CharSetGroupProber): EUCKRProber(), CP949Prober(), Big5Prober(), - EUCTWProber() + EUCTWProber(), + JOHABProber(), ] self.reset() diff --git a/env/Lib/site-packages/pip/_vendor/chardet/mbcssm.py b/env/Lib/site-packages/pip/_vendor/chardet/mbcssm.py index 8360d0f2..7bbe97e6 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/mbcssm.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/mbcssm.py @@ -25,43 +25,45 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from .codingstatemachinedict import CodingStateMachineDict from .enums import MachineState # BIG5 +# fmt: off BIG5_CLS = ( - 1,1,1,1,1,1,1,1, # 00 - 07 #allow 0x00 as legal value - 1,1,1,1,1,1,0,0, # 08 - 0f - 1,1,1,1,1,1,1,1, # 10 - 17 - 1,1,1,0,1,1,1,1, # 18 - 1f - 1,1,1,1,1,1,1,1, # 20 - 27 - 1,1,1,1,1,1,1,1, # 28 - 2f - 1,1,1,1,1,1,1,1, # 30 - 37 - 1,1,1,1,1,1,1,1, # 38 - 3f - 2,2,2,2,2,2,2,2, # 40 - 47 - 2,2,2,2,2,2,2,2, # 48 - 4f - 2,2,2,2,2,2,2,2, # 50 - 57 - 2,2,2,2,2,2,2,2, # 58 - 5f - 2,2,2,2,2,2,2,2, # 60 - 67 - 2,2,2,2,2,2,2,2, # 68 - 6f - 2,2,2,2,2,2,2,2, # 70 - 77 - 2,2,2,2,2,2,2,1, # 78 - 7f - 4,4,4,4,4,4,4,4, # 80 - 87 - 4,4,4,4,4,4,4,4, # 88 - 8f - 4,4,4,4,4,4,4,4, # 90 - 97 - 4,4,4,4,4,4,4,4, # 98 - 9f - 4,3,3,3,3,3,3,3, # a0 - a7 - 3,3,3,3,3,3,3,3, # a8 - af - 3,3,3,3,3,3,3,3, # b0 - b7 - 3,3,3,3,3,3,3,3, # b8 - bf - 3,3,3,3,3,3,3,3, # c0 - c7 - 3,3,3,3,3,3,3,3, # c8 - cf - 3,3,3,3,3,3,3,3, # d0 - d7 - 3,3,3,3,3,3,3,3, # d8 - df - 3,3,3,3,3,3,3,3, # e0 - e7 - 3,3,3,3,3,3,3,3, # e8 - ef - 3,3,3,3,3,3,3,3, # f0 - f7 - 3,3,3,3,3,3,3,0 # f8 - ff + 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 #allow 0x00 as legal value + 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f + 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 + 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f + 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 + 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f + 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 37 + 1, 1, 1, 1, 1, 1, 1, 1, # 38 - 3f + 2, 2, 2, 2, 2, 2, 2, 2, # 40 - 47 + 2, 2, 2, 2, 2, 2, 2, 2, # 48 - 4f + 2, 2, 2, 2, 2, 2, 2, 2, # 50 - 57 + 2, 2, 2, 2, 2, 2, 2, 2, # 58 - 5f + 2, 2, 2, 2, 2, 2, 2, 2, # 60 - 67 + 2, 2, 2, 2, 2, 2, 2, 2, # 68 - 6f + 2, 2, 2, 2, 2, 2, 2, 2, # 70 - 77 + 2, 2, 2, 2, 2, 2, 2, 1, # 78 - 7f + 4, 4, 4, 4, 4, 4, 4, 4, # 80 - 87 + 4, 4, 4, 4, 4, 4, 4, 4, # 88 - 8f + 4, 4, 4, 4, 4, 4, 4, 4, # 90 - 97 + 4, 4, 4, 4, 4, 4, 4, 4, # 98 - 9f + 4, 3, 3, 3, 3, 3, 3, 3, # a0 - a7 + 3, 3, 3, 3, 3, 3, 3, 3, # a8 - af + 3, 3, 3, 3, 3, 3, 3, 3, # b0 - b7 + 3, 3, 3, 3, 3, 3, 3, 3, # b8 - bf + 3, 3, 3, 3, 3, 3, 3, 3, # c0 - c7 + 3, 3, 3, 3, 3, 3, 3, 3, # c8 - cf + 3, 3, 3, 3, 3, 3, 3, 3, # d0 - d7 + 3, 3, 3, 3, 3, 3, 3, 3, # d8 - df + 3, 3, 3, 3, 3, 3, 3, 3, # e0 - e7 + 3, 3, 3, 3, 3, 3, 3, 3, # e8 - ef + 3, 3, 3, 3, 3, 3, 3, 3, # f0 - f7 + 3, 3, 3, 3, 3, 3, 3, 0 # f8 - ff ) BIG5_ST = ( @@ -69,34 +71,37 @@ BIG5_ST = ( MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,#08-0f MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START#10-17 ) +# fmt: on BIG5_CHAR_LEN_TABLE = (0, 1, 1, 2, 0) -BIG5_SM_MODEL = {'class_table': BIG5_CLS, - 'class_factor': 5, - 'state_table': BIG5_ST, - 'char_len_table': BIG5_CHAR_LEN_TABLE, - 'name': 'Big5'} +BIG5_SM_MODEL: CodingStateMachineDict = { + "class_table": BIG5_CLS, + "class_factor": 5, + "state_table": BIG5_ST, + "char_len_table": BIG5_CHAR_LEN_TABLE, + "name": "Big5", +} # CP949 - +# fmt: off CP949_CLS = ( - 1,1,1,1,1,1,1,1, 1,1,1,1,1,1,0,0, # 00 - 0f - 1,1,1,1,1,1,1,1, 1,1,1,0,1,1,1,1, # 10 - 1f - 1,1,1,1,1,1,1,1, 1,1,1,1,1,1,1,1, # 20 - 2f - 1,1,1,1,1,1,1,1, 1,1,1,1,1,1,1,1, # 30 - 3f - 1,4,4,4,4,4,4,4, 4,4,4,4,4,4,4,4, # 40 - 4f - 4,4,5,5,5,5,5,5, 5,5,5,1,1,1,1,1, # 50 - 5f - 1,5,5,5,5,5,5,5, 5,5,5,5,5,5,5,5, # 60 - 6f - 5,5,5,5,5,5,5,5, 5,5,5,1,1,1,1,1, # 70 - 7f - 0,6,6,6,6,6,6,6, 6,6,6,6,6,6,6,6, # 80 - 8f - 6,6,6,6,6,6,6,6, 6,6,6,6,6,6,6,6, # 90 - 9f - 6,7,7,7,7,7,7,7, 7,7,7,7,7,8,8,8, # a0 - af - 7,7,7,7,7,7,7,7, 7,7,7,7,7,7,7,7, # b0 - bf - 7,7,7,7,7,7,9,2, 2,3,2,2,2,2,2,2, # c0 - cf - 2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,2, # d0 - df - 2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,2, # e0 - ef - 2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,0, # f0 - ff + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, # 00 - 0f + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, # 10 - 1f + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 2f + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 3f + 1, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, # 40 - 4f + 4, 4, 5, 5, 5, 5, 5, 5, 5, 5, 5, 1, 1, 1, 1, 1, # 50 - 5f + 1, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, # 60 - 6f + 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 1, 1, 1, 1, 1, # 70 - 7f + 0, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, # 80 - 8f + 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, # 90 - 9f + 6, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 8, 8, 8, # a0 - af + 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, # b0 - bf + 7, 7, 7, 7, 7, 7, 9, 2, 2, 3, 2, 2, 2, 2, 2, 2, # c0 - cf + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, # d0 - df + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, # e0 - ef + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 0, # f0 - ff ) CP949_ST = ( @@ -109,50 +114,53 @@ CP949_ST = ( MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, # 5 MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START, # 6 ) +# fmt: on CP949_CHAR_LEN_TABLE = (0, 1, 2, 0, 1, 1, 2, 2, 0, 2) -CP949_SM_MODEL = {'class_table': CP949_CLS, - 'class_factor': 10, - 'state_table': CP949_ST, - 'char_len_table': CP949_CHAR_LEN_TABLE, - 'name': 'CP949'} +CP949_SM_MODEL: CodingStateMachineDict = { + "class_table": CP949_CLS, + "class_factor": 10, + "state_table": CP949_ST, + "char_len_table": CP949_CHAR_LEN_TABLE, + "name": "CP949", +} # EUC-JP - +# fmt: off EUCJP_CLS = ( - 4,4,4,4,4,4,4,4, # 00 - 07 - 4,4,4,4,4,4,5,5, # 08 - 0f - 4,4,4,4,4,4,4,4, # 10 - 17 - 4,4,4,5,4,4,4,4, # 18 - 1f - 4,4,4,4,4,4,4,4, # 20 - 27 - 4,4,4,4,4,4,4,4, # 28 - 2f - 4,4,4,4,4,4,4,4, # 30 - 37 - 4,4,4,4,4,4,4,4, # 38 - 3f - 4,4,4,4,4,4,4,4, # 40 - 47 - 4,4,4,4,4,4,4,4, # 48 - 4f - 4,4,4,4,4,4,4,4, # 50 - 57 - 4,4,4,4,4,4,4,4, # 58 - 5f - 4,4,4,4,4,4,4,4, # 60 - 67 - 4,4,4,4,4,4,4,4, # 68 - 6f - 4,4,4,4,4,4,4,4, # 70 - 77 - 4,4,4,4,4,4,4,4, # 78 - 7f - 5,5,5,5,5,5,5,5, # 80 - 87 - 5,5,5,5,5,5,1,3, # 88 - 8f - 5,5,5,5,5,5,5,5, # 90 - 97 - 5,5,5,5,5,5,5,5, # 98 - 9f - 5,2,2,2,2,2,2,2, # a0 - a7 - 2,2,2,2,2,2,2,2, # a8 - af - 2,2,2,2,2,2,2,2, # b0 - b7 - 2,2,2,2,2,2,2,2, # b8 - bf - 2,2,2,2,2,2,2,2, # c0 - c7 - 2,2,2,2,2,2,2,2, # c8 - cf - 2,2,2,2,2,2,2,2, # d0 - d7 - 2,2,2,2,2,2,2,2, # d8 - df - 0,0,0,0,0,0,0,0, # e0 - e7 - 0,0,0,0,0,0,0,0, # e8 - ef - 0,0,0,0,0,0,0,0, # f0 - f7 - 0,0,0,0,0,0,0,5 # f8 - ff + 4, 4, 4, 4, 4, 4, 4, 4, # 00 - 07 + 4, 4, 4, 4, 4, 4, 5, 5, # 08 - 0f + 4, 4, 4, 4, 4, 4, 4, 4, # 10 - 17 + 4, 4, 4, 5, 4, 4, 4, 4, # 18 - 1f + 4, 4, 4, 4, 4, 4, 4, 4, # 20 - 27 + 4, 4, 4, 4, 4, 4, 4, 4, # 28 - 2f + 4, 4, 4, 4, 4, 4, 4, 4, # 30 - 37 + 4, 4, 4, 4, 4, 4, 4, 4, # 38 - 3f + 4, 4, 4, 4, 4, 4, 4, 4, # 40 - 47 + 4, 4, 4, 4, 4, 4, 4, 4, # 48 - 4f + 4, 4, 4, 4, 4, 4, 4, 4, # 50 - 57 + 4, 4, 4, 4, 4, 4, 4, 4, # 58 - 5f + 4, 4, 4, 4, 4, 4, 4, 4, # 60 - 67 + 4, 4, 4, 4, 4, 4, 4, 4, # 68 - 6f + 4, 4, 4, 4, 4, 4, 4, 4, # 70 - 77 + 4, 4, 4, 4, 4, 4, 4, 4, # 78 - 7f + 5, 5, 5, 5, 5, 5, 5, 5, # 80 - 87 + 5, 5, 5, 5, 5, 5, 1, 3, # 88 - 8f + 5, 5, 5, 5, 5, 5, 5, 5, # 90 - 97 + 5, 5, 5, 5, 5, 5, 5, 5, # 98 - 9f + 5, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 + 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af + 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 + 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf + 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 + 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf + 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 + 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df + 0, 0, 0, 0, 0, 0, 0, 0, # e0 - e7 + 0, 0, 0, 0, 0, 0, 0, 0, # e8 - ef + 0, 0, 0, 0, 0, 0, 0, 0, # f0 - f7 + 0, 0, 0, 0, 0, 0, 0, 5 # f8 - ff ) EUCJP_ST = ( @@ -162,100 +170,163 @@ EUCJP_ST = ( MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 3,MachineState.ERROR,#18-1f 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START#20-27 ) +# fmt: on EUCJP_CHAR_LEN_TABLE = (2, 2, 2, 3, 1, 0) -EUCJP_SM_MODEL = {'class_table': EUCJP_CLS, - 'class_factor': 6, - 'state_table': EUCJP_ST, - 'char_len_table': EUCJP_CHAR_LEN_TABLE, - 'name': 'EUC-JP'} +EUCJP_SM_MODEL: CodingStateMachineDict = { + "class_table": EUCJP_CLS, + "class_factor": 6, + "state_table": EUCJP_ST, + "char_len_table": EUCJP_CHAR_LEN_TABLE, + "name": "EUC-JP", +} # EUC-KR - +# fmt: off EUCKR_CLS = ( - 1,1,1,1,1,1,1,1, # 00 - 07 - 1,1,1,1,1,1,0,0, # 08 - 0f - 1,1,1,1,1,1,1,1, # 10 - 17 - 1,1,1,0,1,1,1,1, # 18 - 1f - 1,1,1,1,1,1,1,1, # 20 - 27 - 1,1,1,1,1,1,1,1, # 28 - 2f - 1,1,1,1,1,1,1,1, # 30 - 37 - 1,1,1,1,1,1,1,1, # 38 - 3f - 1,1,1,1,1,1,1,1, # 40 - 47 + 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 + 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f + 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 + 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f + 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 + 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f + 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 37 + 1, 1, 1, 1, 1, 1, 1, 1, # 38 - 3f + 1, 1, 1, 1, 1, 1, 1, 1, # 40 - 47 + 1, 1, 1, 1, 1, 1, 1, 1, # 48 - 4f + 1, 1, 1, 1, 1, 1, 1, 1, # 50 - 57 + 1, 1, 1, 1, 1, 1, 1, 1, # 58 - 5f + 1, 1, 1, 1, 1, 1, 1, 1, # 60 - 67 + 1, 1, 1, 1, 1, 1, 1, 1, # 68 - 6f + 1, 1, 1, 1, 1, 1, 1, 1, # 70 - 77 + 1, 1, 1, 1, 1, 1, 1, 1, # 78 - 7f + 0, 0, 0, 0, 0, 0, 0, 0, # 80 - 87 + 0, 0, 0, 0, 0, 0, 0, 0, # 88 - 8f + 0, 0, 0, 0, 0, 0, 0, 0, # 90 - 97 + 0, 0, 0, 0, 0, 0, 0, 0, # 98 - 9f + 0, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 + 2, 2, 2, 2, 2, 3, 3, 3, # a8 - af + 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 + 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf + 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 + 2, 3, 2, 2, 2, 2, 2, 2, # c8 - cf + 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 + 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df + 2, 2, 2, 2, 2, 2, 2, 2, # e0 - e7 + 2, 2, 2, 2, 2, 2, 2, 2, # e8 - ef + 2, 2, 2, 2, 2, 2, 2, 2, # f0 - f7 + 2, 2, 2, 2, 2, 2, 2, 0 # f8 - ff +) + +EUCKR_ST = ( + MachineState.ERROR,MachineState.START, 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #08-0f +) +# fmt: on + +EUCKR_CHAR_LEN_TABLE = (0, 1, 2, 0) + +EUCKR_SM_MODEL: CodingStateMachineDict = { + "class_table": EUCKR_CLS, + "class_factor": 4, + "state_table": EUCKR_ST, + "char_len_table": EUCKR_CHAR_LEN_TABLE, + "name": "EUC-KR", +} + +# JOHAB +# fmt: off +JOHAB_CLS = ( + 4,4,4,4,4,4,4,4, # 00 - 07 + 4,4,4,4,4,4,0,0, # 08 - 0f + 4,4,4,4,4,4,4,4, # 10 - 17 + 4,4,4,0,4,4,4,4, # 18 - 1f + 4,4,4,4,4,4,4,4, # 20 - 27 + 4,4,4,4,4,4,4,4, # 28 - 2f + 4,3,3,3,3,3,3,3, # 30 - 37 + 3,3,3,3,3,3,3,3, # 38 - 3f + 3,1,1,1,1,1,1,1, # 40 - 47 1,1,1,1,1,1,1,1, # 48 - 4f 1,1,1,1,1,1,1,1, # 50 - 57 1,1,1,1,1,1,1,1, # 58 - 5f 1,1,1,1,1,1,1,1, # 60 - 67 1,1,1,1,1,1,1,1, # 68 - 6f 1,1,1,1,1,1,1,1, # 70 - 77 - 1,1,1,1,1,1,1,1, # 78 - 7f - 0,0,0,0,0,0,0,0, # 80 - 87 - 0,0,0,0,0,0,0,0, # 88 - 8f - 0,0,0,0,0,0,0,0, # 90 - 97 - 0,0,0,0,0,0,0,0, # 98 - 9f - 0,2,2,2,2,2,2,2, # a0 - a7 - 2,2,2,2,2,3,3,3, # a8 - af - 2,2,2,2,2,2,2,2, # b0 - b7 - 2,2,2,2,2,2,2,2, # b8 - bf - 2,2,2,2,2,2,2,2, # c0 - c7 - 2,3,2,2,2,2,2,2, # c8 - cf - 2,2,2,2,2,2,2,2, # d0 - d7 - 2,2,2,2,2,2,2,2, # d8 - df - 2,2,2,2,2,2,2,2, # e0 - e7 - 2,2,2,2,2,2,2,2, # e8 - ef - 2,2,2,2,2,2,2,2, # f0 - f7 - 2,2,2,2,2,2,2,0 # f8 - ff + 1,1,1,1,1,1,1,2, # 78 - 7f + 6,6,6,6,8,8,8,8, # 80 - 87 + 8,8,8,8,8,8,8,8, # 88 - 8f + 8,7,7,7,7,7,7,7, # 90 - 97 + 7,7,7,7,7,7,7,7, # 98 - 9f + 7,7,7,7,7,7,7,7, # a0 - a7 + 7,7,7,7,7,7,7,7, # a8 - af + 7,7,7,7,7,7,7,7, # b0 - b7 + 7,7,7,7,7,7,7,7, # b8 - bf + 7,7,7,7,7,7,7,7, # c0 - c7 + 7,7,7,7,7,7,7,7, # c8 - cf + 7,7,7,7,5,5,5,5, # d0 - d7 + 5,9,9,9,9,9,9,5, # d8 - df + 9,9,9,9,9,9,9,9, # e0 - e7 + 9,9,9,9,9,9,9,9, # e8 - ef + 9,9,9,9,9,9,9,9, # f0 - f7 + 9,9,5,5,5,5,5,0 # f8 - ff ) -EUCKR_ST = ( - MachineState.ERROR,MachineState.START, 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 - MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #08-0f +JOHAB_ST = ( +# cls = 0 1 2 3 4 5 6 7 8 9 + MachineState.ERROR ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.ERROR ,MachineState.ERROR ,3 ,3 ,4 , # MachineState.START + MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME, # MachineState.ITS_ME + MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR , # MachineState.ERROR + MachineState.ERROR ,MachineState.START ,MachineState.START ,MachineState.ERROR ,MachineState.ERROR ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.START , # 3 + MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START , # 4 ) +# fmt: on -EUCKR_CHAR_LEN_TABLE = (0, 1, 2, 0) +JOHAB_CHAR_LEN_TABLE = (0, 1, 1, 1, 1, 0, 0, 2, 2, 2) -EUCKR_SM_MODEL = {'class_table': EUCKR_CLS, - 'class_factor': 4, - 'state_table': EUCKR_ST, - 'char_len_table': EUCKR_CHAR_LEN_TABLE, - 'name': 'EUC-KR'} +JOHAB_SM_MODEL: CodingStateMachineDict = { + "class_table": JOHAB_CLS, + "class_factor": 10, + "state_table": JOHAB_ST, + "char_len_table": JOHAB_CHAR_LEN_TABLE, + "name": "Johab", +} # EUC-TW - +# fmt: off EUCTW_CLS = ( - 2,2,2,2,2,2,2,2, # 00 - 07 - 2,2,2,2,2,2,0,0, # 08 - 0f - 2,2,2,2,2,2,2,2, # 10 - 17 - 2,2,2,0,2,2,2,2, # 18 - 1f - 2,2,2,2,2,2,2,2, # 20 - 27 - 2,2,2,2,2,2,2,2, # 28 - 2f - 2,2,2,2,2,2,2,2, # 30 - 37 - 2,2,2,2,2,2,2,2, # 38 - 3f - 2,2,2,2,2,2,2,2, # 40 - 47 - 2,2,2,2,2,2,2,2, # 48 - 4f - 2,2,2,2,2,2,2,2, # 50 - 57 - 2,2,2,2,2,2,2,2, # 58 - 5f - 2,2,2,2,2,2,2,2, # 60 - 67 - 2,2,2,2,2,2,2,2, # 68 - 6f - 2,2,2,2,2,2,2,2, # 70 - 77 - 2,2,2,2,2,2,2,2, # 78 - 7f - 0,0,0,0,0,0,0,0, # 80 - 87 - 0,0,0,0,0,0,6,0, # 88 - 8f - 0,0,0,0,0,0,0,0, # 90 - 97 - 0,0,0,0,0,0,0,0, # 98 - 9f - 0,3,4,4,4,4,4,4, # a0 - a7 - 5,5,1,1,1,1,1,1, # a8 - af - 1,1,1,1,1,1,1,1, # b0 - b7 - 1,1,1,1,1,1,1,1, # b8 - bf - 1,1,3,1,3,3,3,3, # c0 - c7 - 3,3,3,3,3,3,3,3, # c8 - cf - 3,3,3,3,3,3,3,3, # d0 - d7 - 3,3,3,3,3,3,3,3, # d8 - df - 3,3,3,3,3,3,3,3, # e0 - e7 - 3,3,3,3,3,3,3,3, # e8 - ef - 3,3,3,3,3,3,3,3, # f0 - f7 - 3,3,3,3,3,3,3,0 # f8 - ff + 2, 2, 2, 2, 2, 2, 2, 2, # 00 - 07 + 2, 2, 2, 2, 2, 2, 0, 0, # 08 - 0f + 2, 2, 2, 2, 2, 2, 2, 2, # 10 - 17 + 2, 2, 2, 0, 2, 2, 2, 2, # 18 - 1f + 2, 2, 2, 2, 2, 2, 2, 2, # 20 - 27 + 2, 2, 2, 2, 2, 2, 2, 2, # 28 - 2f + 2, 2, 2, 2, 2, 2, 2, 2, # 30 - 37 + 2, 2, 2, 2, 2, 2, 2, 2, # 38 - 3f + 2, 2, 2, 2, 2, 2, 2, 2, # 40 - 47 + 2, 2, 2, 2, 2, 2, 2, 2, # 48 - 4f + 2, 2, 2, 2, 2, 2, 2, 2, # 50 - 57 + 2, 2, 2, 2, 2, 2, 2, 2, # 58 - 5f + 2, 2, 2, 2, 2, 2, 2, 2, # 60 - 67 + 2, 2, 2, 2, 2, 2, 2, 2, # 68 - 6f + 2, 2, 2, 2, 2, 2, 2, 2, # 70 - 77 + 2, 2, 2, 2, 2, 2, 2, 2, # 78 - 7f + 0, 0, 0, 0, 0, 0, 0, 0, # 80 - 87 + 0, 0, 0, 0, 0, 0, 6, 0, # 88 - 8f + 0, 0, 0, 0, 0, 0, 0, 0, # 90 - 97 + 0, 0, 0, 0, 0, 0, 0, 0, # 98 - 9f + 0, 3, 4, 4, 4, 4, 4, 4, # a0 - a7 + 5, 5, 1, 1, 1, 1, 1, 1, # a8 - af + 1, 1, 1, 1, 1, 1, 1, 1, # b0 - b7 + 1, 1, 1, 1, 1, 1, 1, 1, # b8 - bf + 1, 1, 3, 1, 3, 3, 3, 3, # c0 - c7 + 3, 3, 3, 3, 3, 3, 3, 3, # c8 - cf + 3, 3, 3, 3, 3, 3, 3, 3, # d0 - d7 + 3, 3, 3, 3, 3, 3, 3, 3, # d8 - df + 3, 3, 3, 3, 3, 3, 3, 3, # e0 - e7 + 3, 3, 3, 3, 3, 3, 3, 3, # e8 - ef + 3, 3, 3, 3, 3, 3, 3, 3, # f0 - f7 + 3, 3, 3, 3, 3, 3, 3, 0 # f8 - ff ) EUCTW_ST = ( @@ -266,50 +337,53 @@ EUCTW_ST = ( 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,#20-27 MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f ) +# fmt: on EUCTW_CHAR_LEN_TABLE = (0, 0, 1, 2, 2, 2, 3) -EUCTW_SM_MODEL = {'class_table': EUCTW_CLS, - 'class_factor': 7, - 'state_table': EUCTW_ST, - 'char_len_table': EUCTW_CHAR_LEN_TABLE, - 'name': 'x-euc-tw'} +EUCTW_SM_MODEL: CodingStateMachineDict = { + "class_table": EUCTW_CLS, + "class_factor": 7, + "state_table": EUCTW_ST, + "char_len_table": EUCTW_CHAR_LEN_TABLE, + "name": "x-euc-tw", +} # GB2312 - +# fmt: off GB2312_CLS = ( - 1,1,1,1,1,1,1,1, # 00 - 07 - 1,1,1,1,1,1,0,0, # 08 - 0f - 1,1,1,1,1,1,1,1, # 10 - 17 - 1,1,1,0,1,1,1,1, # 18 - 1f - 1,1,1,1,1,1,1,1, # 20 - 27 - 1,1,1,1,1,1,1,1, # 28 - 2f - 3,3,3,3,3,3,3,3, # 30 - 37 - 3,3,1,1,1,1,1,1, # 38 - 3f - 2,2,2,2,2,2,2,2, # 40 - 47 - 2,2,2,2,2,2,2,2, # 48 - 4f - 2,2,2,2,2,2,2,2, # 50 - 57 - 2,2,2,2,2,2,2,2, # 58 - 5f - 2,2,2,2,2,2,2,2, # 60 - 67 - 2,2,2,2,2,2,2,2, # 68 - 6f - 2,2,2,2,2,2,2,2, # 70 - 77 - 2,2,2,2,2,2,2,4, # 78 - 7f - 5,6,6,6,6,6,6,6, # 80 - 87 - 6,6,6,6,6,6,6,6, # 88 - 8f - 6,6,6,6,6,6,6,6, # 90 - 97 - 6,6,6,6,6,6,6,6, # 98 - 9f - 6,6,6,6,6,6,6,6, # a0 - a7 - 6,6,6,6,6,6,6,6, # a8 - af - 6,6,6,6,6,6,6,6, # b0 - b7 - 6,6,6,6,6,6,6,6, # b8 - bf - 6,6,6,6,6,6,6,6, # c0 - c7 - 6,6,6,6,6,6,6,6, # c8 - cf - 6,6,6,6,6,6,6,6, # d0 - d7 - 6,6,6,6,6,6,6,6, # d8 - df - 6,6,6,6,6,6,6,6, # e0 - e7 - 6,6,6,6,6,6,6,6, # e8 - ef - 6,6,6,6,6,6,6,6, # f0 - f7 - 6,6,6,6,6,6,6,0 # f8 - ff + 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 + 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f + 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 + 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f + 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 + 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f + 3, 3, 3, 3, 3, 3, 3, 3, # 30 - 37 + 3, 3, 1, 1, 1, 1, 1, 1, # 38 - 3f + 2, 2, 2, 2, 2, 2, 2, 2, # 40 - 47 + 2, 2, 2, 2, 2, 2, 2, 2, # 48 - 4f + 2, 2, 2, 2, 2, 2, 2, 2, # 50 - 57 + 2, 2, 2, 2, 2, 2, 2, 2, # 58 - 5f + 2, 2, 2, 2, 2, 2, 2, 2, # 60 - 67 + 2, 2, 2, 2, 2, 2, 2, 2, # 68 - 6f + 2, 2, 2, 2, 2, 2, 2, 2, # 70 - 77 + 2, 2, 2, 2, 2, 2, 2, 4, # 78 - 7f + 5, 6, 6, 6, 6, 6, 6, 6, # 80 - 87 + 6, 6, 6, 6, 6, 6, 6, 6, # 88 - 8f + 6, 6, 6, 6, 6, 6, 6, 6, # 90 - 97 + 6, 6, 6, 6, 6, 6, 6, 6, # 98 - 9f + 6, 6, 6, 6, 6, 6, 6, 6, # a0 - a7 + 6, 6, 6, 6, 6, 6, 6, 6, # a8 - af + 6, 6, 6, 6, 6, 6, 6, 6, # b0 - b7 + 6, 6, 6, 6, 6, 6, 6, 6, # b8 - bf + 6, 6, 6, 6, 6, 6, 6, 6, # c0 - c7 + 6, 6, 6, 6, 6, 6, 6, 6, # c8 - cf + 6, 6, 6, 6, 6, 6, 6, 6, # d0 - d7 + 6, 6, 6, 6, 6, 6, 6, 6, # d8 - df + 6, 6, 6, 6, 6, 6, 6, 6, # e0 - e7 + 6, 6, 6, 6, 6, 6, 6, 6, # e8 - ef + 6, 6, 6, 6, 6, 6, 6, 6, # f0 - f7 + 6, 6, 6, 6, 6, 6, 6, 0 # f8 - ff ) GB2312_ST = ( @@ -320,6 +394,7 @@ GB2312_ST = ( MachineState.ERROR,MachineState.ERROR, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,#20-27 MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f ) +# fmt: on # To be accurate, the length of class 6 can be either 2 or 4. # But it is not necessary to discriminate between the two since @@ -328,100 +403,105 @@ GB2312_ST = ( # 2 here. GB2312_CHAR_LEN_TABLE = (0, 1, 1, 1, 1, 1, 2) -GB2312_SM_MODEL = {'class_table': GB2312_CLS, - 'class_factor': 7, - 'state_table': GB2312_ST, - 'char_len_table': GB2312_CHAR_LEN_TABLE, - 'name': 'GB2312'} +GB2312_SM_MODEL: CodingStateMachineDict = { + "class_table": GB2312_CLS, + "class_factor": 7, + "state_table": GB2312_ST, + "char_len_table": GB2312_CHAR_LEN_TABLE, + "name": "GB2312", +} # Shift_JIS - +# fmt: off SJIS_CLS = ( - 1,1,1,1,1,1,1,1, # 00 - 07 - 1,1,1,1,1,1,0,0, # 08 - 0f - 1,1,1,1,1,1,1,1, # 10 - 17 - 1,1,1,0,1,1,1,1, # 18 - 1f - 1,1,1,1,1,1,1,1, # 20 - 27 - 1,1,1,1,1,1,1,1, # 28 - 2f - 1,1,1,1,1,1,1,1, # 30 - 37 - 1,1,1,1,1,1,1,1, # 38 - 3f - 2,2,2,2,2,2,2,2, # 40 - 47 - 2,2,2,2,2,2,2,2, # 48 - 4f - 2,2,2,2,2,2,2,2, # 50 - 57 - 2,2,2,2,2,2,2,2, # 58 - 5f - 2,2,2,2,2,2,2,2, # 60 - 67 - 2,2,2,2,2,2,2,2, # 68 - 6f - 2,2,2,2,2,2,2,2, # 70 - 77 - 2,2,2,2,2,2,2,1, # 78 - 7f - 3,3,3,3,3,2,2,3, # 80 - 87 - 3,3,3,3,3,3,3,3, # 88 - 8f - 3,3,3,3,3,3,3,3, # 90 - 97 - 3,3,3,3,3,3,3,3, # 98 - 9f + 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 + 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f + 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 + 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f + 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 + 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f + 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 37 + 1, 1, 1, 1, 1, 1, 1, 1, # 38 - 3f + 2, 2, 2, 2, 2, 2, 2, 2, # 40 - 47 + 2, 2, 2, 2, 2, 2, 2, 2, # 48 - 4f + 2, 2, 2, 2, 2, 2, 2, 2, # 50 - 57 + 2, 2, 2, 2, 2, 2, 2, 2, # 58 - 5f + 2, 2, 2, 2, 2, 2, 2, 2, # 60 - 67 + 2, 2, 2, 2, 2, 2, 2, 2, # 68 - 6f + 2, 2, 2, 2, 2, 2, 2, 2, # 70 - 77 + 2, 2, 2, 2, 2, 2, 2, 1, # 78 - 7f + 3, 3, 3, 3, 3, 2, 2, 3, # 80 - 87 + 3, 3, 3, 3, 3, 3, 3, 3, # 88 - 8f + 3, 3, 3, 3, 3, 3, 3, 3, # 90 - 97 + 3, 3, 3, 3, 3, 3, 3, 3, # 98 - 9f #0xa0 is illegal in sjis encoding, but some pages does #contain such byte. We need to be more error forgiven. - 2,2,2,2,2,2,2,2, # a0 - a7 - 2,2,2,2,2,2,2,2, # a8 - af - 2,2,2,2,2,2,2,2, # b0 - b7 - 2,2,2,2,2,2,2,2, # b8 - bf - 2,2,2,2,2,2,2,2, # c0 - c7 - 2,2,2,2,2,2,2,2, # c8 - cf - 2,2,2,2,2,2,2,2, # d0 - d7 - 2,2,2,2,2,2,2,2, # d8 - df - 3,3,3,3,3,3,3,3, # e0 - e7 - 3,3,3,3,3,4,4,4, # e8 - ef - 3,3,3,3,3,3,3,3, # f0 - f7 - 3,3,3,3,3,0,0,0) # f8 - ff - + 2, 2, 2, 2, 2, 2, 2, 2, # a0 - a7 + 2, 2, 2, 2, 2, 2, 2, 2, # a8 - af + 2, 2, 2, 2, 2, 2, 2, 2, # b0 - b7 + 2, 2, 2, 2, 2, 2, 2, 2, # b8 - bf + 2, 2, 2, 2, 2, 2, 2, 2, # c0 - c7 + 2, 2, 2, 2, 2, 2, 2, 2, # c8 - cf + 2, 2, 2, 2, 2, 2, 2, 2, # d0 - d7 + 2, 2, 2, 2, 2, 2, 2, 2, # d8 - df + 3, 3, 3, 3, 3, 3, 3, 3, # e0 - e7 + 3, 3, 3, 3, 3, 4, 4, 4, # e8 - ef + 3, 3, 3, 3, 3, 3, 3, 3, # f0 - f7 + 3, 3, 3, 3, 3, 0, 0, 0, # f8 - ff +) SJIS_ST = ( MachineState.ERROR,MachineState.START,MachineState.START, 3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07 MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START #10-17 ) +# fmt: on SJIS_CHAR_LEN_TABLE = (0, 1, 1, 2, 0, 0) -SJIS_SM_MODEL = {'class_table': SJIS_CLS, - 'class_factor': 6, - 'state_table': SJIS_ST, - 'char_len_table': SJIS_CHAR_LEN_TABLE, - 'name': 'Shift_JIS'} +SJIS_SM_MODEL: CodingStateMachineDict = { + "class_table": SJIS_CLS, + "class_factor": 6, + "state_table": SJIS_ST, + "char_len_table": SJIS_CHAR_LEN_TABLE, + "name": "Shift_JIS", +} # UCS2-BE - +# fmt: off UCS2BE_CLS = ( - 0,0,0,0,0,0,0,0, # 00 - 07 - 0,0,1,0,0,2,0,0, # 08 - 0f - 0,0,0,0,0,0,0,0, # 10 - 17 - 0,0,0,3,0,0,0,0, # 18 - 1f - 0,0,0,0,0,0,0,0, # 20 - 27 - 0,3,3,3,3,3,0,0, # 28 - 2f - 0,0,0,0,0,0,0,0, # 30 - 37 - 0,0,0,0,0,0,0,0, # 38 - 3f - 0,0,0,0,0,0,0,0, # 40 - 47 - 0,0,0,0,0,0,0,0, # 48 - 4f - 0,0,0,0,0,0,0,0, # 50 - 57 - 0,0,0,0,0,0,0,0, # 58 - 5f - 0,0,0,0,0,0,0,0, # 60 - 67 - 0,0,0,0,0,0,0,0, # 68 - 6f - 0,0,0,0,0,0,0,0, # 70 - 77 - 0,0,0,0,0,0,0,0, # 78 - 7f - 0,0,0,0,0,0,0,0, # 80 - 87 - 0,0,0,0,0,0,0,0, # 88 - 8f - 0,0,0,0,0,0,0,0, # 90 - 97 - 0,0,0,0,0,0,0,0, # 98 - 9f - 0,0,0,0,0,0,0,0, # a0 - a7 - 0,0,0,0,0,0,0,0, # a8 - af - 0,0,0,0,0,0,0,0, # b0 - b7 - 0,0,0,0,0,0,0,0, # b8 - bf - 0,0,0,0,0,0,0,0, # c0 - c7 - 0,0,0,0,0,0,0,0, # c8 - cf - 0,0,0,0,0,0,0,0, # d0 - d7 - 0,0,0,0,0,0,0,0, # d8 - df - 0,0,0,0,0,0,0,0, # e0 - e7 - 0,0,0,0,0,0,0,0, # e8 - ef - 0,0,0,0,0,0,0,0, # f0 - f7 - 0,0,0,0,0,0,4,5 # f8 - ff + 0, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 + 0, 0, 1, 0, 0, 2, 0, 0, # 08 - 0f + 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 + 0, 0, 0, 3, 0, 0, 0, 0, # 18 - 1f + 0, 0, 0, 0, 0, 0, 0, 0, # 20 - 27 + 0, 3, 3, 3, 3, 3, 0, 0, # 28 - 2f + 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 + 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f + 0, 0, 0, 0, 0, 0, 0, 0, # 40 - 47 + 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f + 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 + 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f + 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 + 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f + 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 + 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f + 0, 0, 0, 0, 0, 0, 0, 0, # 80 - 87 + 0, 0, 0, 0, 0, 0, 0, 0, # 88 - 8f + 0, 0, 0, 0, 0, 0, 0, 0, # 90 - 97 + 0, 0, 0, 0, 0, 0, 0, 0, # 98 - 9f + 0, 0, 0, 0, 0, 0, 0, 0, # a0 - a7 + 0, 0, 0, 0, 0, 0, 0, 0, # a8 - af + 0, 0, 0, 0, 0, 0, 0, 0, # b0 - b7 + 0, 0, 0, 0, 0, 0, 0, 0, # b8 - bf + 0, 0, 0, 0, 0, 0, 0, 0, # c0 - c7 + 0, 0, 0, 0, 0, 0, 0, 0, # c8 - cf + 0, 0, 0, 0, 0, 0, 0, 0, # d0 - d7 + 0, 0, 0, 0, 0, 0, 0, 0, # d8 - df + 0, 0, 0, 0, 0, 0, 0, 0, # e0 - e7 + 0, 0, 0, 0, 0, 0, 0, 0, # e8 - ef + 0, 0, 0, 0, 0, 0, 0, 0, # f0 - f7 + 0, 0, 0, 0, 0, 0, 4, 5 # f8 - ff ) UCS2BE_ST = ( @@ -433,50 +513,53 @@ UCS2BE_ST = ( 5, 8, 6, 6,MachineState.ERROR, 6, 6, 6,#28-2f 6, 6, 6, 6,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #30-37 ) +# fmt: on UCS2BE_CHAR_LEN_TABLE = (2, 2, 2, 0, 2, 2) -UCS2BE_SM_MODEL = {'class_table': UCS2BE_CLS, - 'class_factor': 6, - 'state_table': UCS2BE_ST, - 'char_len_table': UCS2BE_CHAR_LEN_TABLE, - 'name': 'UTF-16BE'} +UCS2BE_SM_MODEL: CodingStateMachineDict = { + "class_table": UCS2BE_CLS, + "class_factor": 6, + "state_table": UCS2BE_ST, + "char_len_table": UCS2BE_CHAR_LEN_TABLE, + "name": "UTF-16BE", +} # UCS2-LE - +# fmt: off UCS2LE_CLS = ( - 0,0,0,0,0,0,0,0, # 00 - 07 - 0,0,1,0,0,2,0,0, # 08 - 0f - 0,0,0,0,0,0,0,0, # 10 - 17 - 0,0,0,3,0,0,0,0, # 18 - 1f - 0,0,0,0,0,0,0,0, # 20 - 27 - 0,3,3,3,3,3,0,0, # 28 - 2f - 0,0,0,0,0,0,0,0, # 30 - 37 - 0,0,0,0,0,0,0,0, # 38 - 3f - 0,0,0,0,0,0,0,0, # 40 - 47 - 0,0,0,0,0,0,0,0, # 48 - 4f - 0,0,0,0,0,0,0,0, # 50 - 57 - 0,0,0,0,0,0,0,0, # 58 - 5f - 0,0,0,0,0,0,0,0, # 60 - 67 - 0,0,0,0,0,0,0,0, # 68 - 6f - 0,0,0,0,0,0,0,0, # 70 - 77 - 0,0,0,0,0,0,0,0, # 78 - 7f - 0,0,0,0,0,0,0,0, # 80 - 87 - 0,0,0,0,0,0,0,0, # 88 - 8f - 0,0,0,0,0,0,0,0, # 90 - 97 - 0,0,0,0,0,0,0,0, # 98 - 9f - 0,0,0,0,0,0,0,0, # a0 - a7 - 0,0,0,0,0,0,0,0, # a8 - af - 0,0,0,0,0,0,0,0, # b0 - b7 - 0,0,0,0,0,0,0,0, # b8 - bf - 0,0,0,0,0,0,0,0, # c0 - c7 - 0,0,0,0,0,0,0,0, # c8 - cf - 0,0,0,0,0,0,0,0, # d0 - d7 - 0,0,0,0,0,0,0,0, # d8 - df - 0,0,0,0,0,0,0,0, # e0 - e7 - 0,0,0,0,0,0,0,0, # e8 - ef - 0,0,0,0,0,0,0,0, # f0 - f7 - 0,0,0,0,0,0,4,5 # f8 - ff + 0, 0, 0, 0, 0, 0, 0, 0, # 00 - 07 + 0, 0, 1, 0, 0, 2, 0, 0, # 08 - 0f + 0, 0, 0, 0, 0, 0, 0, 0, # 10 - 17 + 0, 0, 0, 3, 0, 0, 0, 0, # 18 - 1f + 0, 0, 0, 0, 0, 0, 0, 0, # 20 - 27 + 0, 3, 3, 3, 3, 3, 0, 0, # 28 - 2f + 0, 0, 0, 0, 0, 0, 0, 0, # 30 - 37 + 0, 0, 0, 0, 0, 0, 0, 0, # 38 - 3f + 0, 0, 0, 0, 0, 0, 0, 0, # 40 - 47 + 0, 0, 0, 0, 0, 0, 0, 0, # 48 - 4f + 0, 0, 0, 0, 0, 0, 0, 0, # 50 - 57 + 0, 0, 0, 0, 0, 0, 0, 0, # 58 - 5f + 0, 0, 0, 0, 0, 0, 0, 0, # 60 - 67 + 0, 0, 0, 0, 0, 0, 0, 0, # 68 - 6f + 0, 0, 0, 0, 0, 0, 0, 0, # 70 - 77 + 0, 0, 0, 0, 0, 0, 0, 0, # 78 - 7f + 0, 0, 0, 0, 0, 0, 0, 0, # 80 - 87 + 0, 0, 0, 0, 0, 0, 0, 0, # 88 - 8f + 0, 0, 0, 0, 0, 0, 0, 0, # 90 - 97 + 0, 0, 0, 0, 0, 0, 0, 0, # 98 - 9f + 0, 0, 0, 0, 0, 0, 0, 0, # a0 - a7 + 0, 0, 0, 0, 0, 0, 0, 0, # a8 - af + 0, 0, 0, 0, 0, 0, 0, 0, # b0 - b7 + 0, 0, 0, 0, 0, 0, 0, 0, # b8 - bf + 0, 0, 0, 0, 0, 0, 0, 0, # c0 - c7 + 0, 0, 0, 0, 0, 0, 0, 0, # c8 - cf + 0, 0, 0, 0, 0, 0, 0, 0, # d0 - d7 + 0, 0, 0, 0, 0, 0, 0, 0, # d8 - df + 0, 0, 0, 0, 0, 0, 0, 0, # e0 - e7 + 0, 0, 0, 0, 0, 0, 0, 0, # e8 - ef + 0, 0, 0, 0, 0, 0, 0, 0, # f0 - f7 + 0, 0, 0, 0, 0, 0, 4, 5 # f8 - ff ) UCS2LE_ST = ( @@ -488,50 +571,53 @@ UCS2LE_ST = ( 5, 5, 5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR, 5, 5,#28-2f 5, 5, 5,MachineState.ERROR, 5,MachineState.ERROR,MachineState.START,MachineState.START #30-37 ) +# fmt: on UCS2LE_CHAR_LEN_TABLE = (2, 2, 2, 2, 2, 2) -UCS2LE_SM_MODEL = {'class_table': UCS2LE_CLS, - 'class_factor': 6, - 'state_table': UCS2LE_ST, - 'char_len_table': UCS2LE_CHAR_LEN_TABLE, - 'name': 'UTF-16LE'} +UCS2LE_SM_MODEL: CodingStateMachineDict = { + "class_table": UCS2LE_CLS, + "class_factor": 6, + "state_table": UCS2LE_ST, + "char_len_table": UCS2LE_CHAR_LEN_TABLE, + "name": "UTF-16LE", +} # UTF-8 - +# fmt: off UTF8_CLS = ( - 1,1,1,1,1,1,1,1, # 00 - 07 #allow 0x00 as a legal value - 1,1,1,1,1,1,0,0, # 08 - 0f - 1,1,1,1,1,1,1,1, # 10 - 17 - 1,1,1,0,1,1,1,1, # 18 - 1f - 1,1,1,1,1,1,1,1, # 20 - 27 - 1,1,1,1,1,1,1,1, # 28 - 2f - 1,1,1,1,1,1,1,1, # 30 - 37 - 1,1,1,1,1,1,1,1, # 38 - 3f - 1,1,1,1,1,1,1,1, # 40 - 47 - 1,1,1,1,1,1,1,1, # 48 - 4f - 1,1,1,1,1,1,1,1, # 50 - 57 - 1,1,1,1,1,1,1,1, # 58 - 5f - 1,1,1,1,1,1,1,1, # 60 - 67 - 1,1,1,1,1,1,1,1, # 68 - 6f - 1,1,1,1,1,1,1,1, # 70 - 77 - 1,1,1,1,1,1,1,1, # 78 - 7f - 2,2,2,2,3,3,3,3, # 80 - 87 - 4,4,4,4,4,4,4,4, # 88 - 8f - 4,4,4,4,4,4,4,4, # 90 - 97 - 4,4,4,4,4,4,4,4, # 98 - 9f - 5,5,5,5,5,5,5,5, # a0 - a7 - 5,5,5,5,5,5,5,5, # a8 - af - 5,5,5,5,5,5,5,5, # b0 - b7 - 5,5,5,5,5,5,5,5, # b8 - bf - 0,0,6,6,6,6,6,6, # c0 - c7 - 6,6,6,6,6,6,6,6, # c8 - cf - 6,6,6,6,6,6,6,6, # d0 - d7 - 6,6,6,6,6,6,6,6, # d8 - df - 7,8,8,8,8,8,8,8, # e0 - e7 - 8,8,8,8,8,9,8,8, # e8 - ef - 10,11,11,11,11,11,11,11, # f0 - f7 - 12,13,13,13,14,15,0,0 # f8 - ff + 1, 1, 1, 1, 1, 1, 1, 1, # 00 - 07 #allow 0x00 as a legal value + 1, 1, 1, 1, 1, 1, 0, 0, # 08 - 0f + 1, 1, 1, 1, 1, 1, 1, 1, # 10 - 17 + 1, 1, 1, 0, 1, 1, 1, 1, # 18 - 1f + 1, 1, 1, 1, 1, 1, 1, 1, # 20 - 27 + 1, 1, 1, 1, 1, 1, 1, 1, # 28 - 2f + 1, 1, 1, 1, 1, 1, 1, 1, # 30 - 37 + 1, 1, 1, 1, 1, 1, 1, 1, # 38 - 3f + 1, 1, 1, 1, 1, 1, 1, 1, # 40 - 47 + 1, 1, 1, 1, 1, 1, 1, 1, # 48 - 4f + 1, 1, 1, 1, 1, 1, 1, 1, # 50 - 57 + 1, 1, 1, 1, 1, 1, 1, 1, # 58 - 5f + 1, 1, 1, 1, 1, 1, 1, 1, # 60 - 67 + 1, 1, 1, 1, 1, 1, 1, 1, # 68 - 6f + 1, 1, 1, 1, 1, 1, 1, 1, # 70 - 77 + 1, 1, 1, 1, 1, 1, 1, 1, # 78 - 7f + 2, 2, 2, 2, 3, 3, 3, 3, # 80 - 87 + 4, 4, 4, 4, 4, 4, 4, 4, # 88 - 8f + 4, 4, 4, 4, 4, 4, 4, 4, # 90 - 97 + 4, 4, 4, 4, 4, 4, 4, 4, # 98 - 9f + 5, 5, 5, 5, 5, 5, 5, 5, # a0 - a7 + 5, 5, 5, 5, 5, 5, 5, 5, # a8 - af + 5, 5, 5, 5, 5, 5, 5, 5, # b0 - b7 + 5, 5, 5, 5, 5, 5, 5, 5, # b8 - bf + 0, 0, 6, 6, 6, 6, 6, 6, # c0 - c7 + 6, 6, 6, 6, 6, 6, 6, 6, # c8 - cf + 6, 6, 6, 6, 6, 6, 6, 6, # d0 - d7 + 6, 6, 6, 6, 6, 6, 6, 6, # d8 - df + 7, 8, 8, 8, 8, 8, 8, 8, # e0 - e7 + 8, 8, 8, 8, 8, 9, 8, 8, # e8 - ef + 10, 11, 11, 11, 11, 11, 11, 11, # f0 - f7 + 12, 13, 13, 13, 14, 15, 0, 0 # f8 - ff ) UTF8_ST = ( @@ -562,11 +648,14 @@ UTF8_ST = ( MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,#c0-c7 MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR #c8-cf ) +# fmt: on UTF8_CHAR_LEN_TABLE = (0, 1, 0, 0, 0, 0, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6) -UTF8_SM_MODEL = {'class_table': UTF8_CLS, - 'class_factor': 16, - 'state_table': UTF8_ST, - 'char_len_table': UTF8_CHAR_LEN_TABLE, - 'name': 'UTF-8'} +UTF8_SM_MODEL: CodingStateMachineDict = { + "class_table": UTF8_CLS, + "class_factor": 16, + "state_table": UTF8_ST, + "char_len_table": UTF8_CHAR_LEN_TABLE, + "name": "UTF-8", +} diff --git a/env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index f20fa90dfbfd044f2ed07632e8c63551c1f68955..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 228 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>U6e> z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk yFVauWNGwW8Ez!?SElEsCEJ@UlkI&4@EQycTE2zB1VUwGmQks)$2Xf+PkXHcP<~{@f diff --git a/env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-39.pyc deleted file mode 100644 index 89a848bfcfb9b4e13f7f563f9c97ae182615ec54..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7959 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 VwjgyNcfi~z2nsotS1b(-a{=`75ElRd diff --git a/env/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py b/env/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py index 3237d5ab..eb40c5f0 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py @@ -1,19 +1,17 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- """ Metadata about languages used by our model training code for our SingleByteCharSetProbers. Could be used for other things in the future. This code is based on the language metadata from the uchardet project. """ -from __future__ import absolute_import, print_function from string import ascii_letters +from typing import List, Optional +# TODO: Add Ukrainian (KOI8-U) -# TODO: Add Ukranian (KOI8-U) -class Language(object): +class Language: """Metadata about a language useful for training models :ivar name: The human name for the language, in English. @@ -33,9 +31,17 @@ class Language(object): Wikipedia for training data. :type wiki_start_pages: list of str """ - def __init__(self, name=None, iso_code=None, use_ascii=True, charsets=None, - alphabet=None, wiki_start_pages=None): - super(Language, self).__init__() + + def __init__( + self, + name: Optional[str] = None, + iso_code: Optional[str] = None, + use_ascii: bool = True, + charsets: Optional[List[str]] = None, + alphabet: Optional[str] = None, + wiki_start_pages: Optional[List[str]] = None, + ) -> None: + super().__init__() self.name = name self.iso_code = iso_code self.use_ascii = use_ascii @@ -46,265 +52,301 @@ class Language(object): else: alphabet = ascii_letters elif not alphabet: - raise ValueError('Must supply alphabet if use_ascii is False') - self.alphabet = ''.join(sorted(set(alphabet))) if alphabet else None + raise ValueError("Must supply alphabet if use_ascii is False") + self.alphabet = "".join(sorted(set(alphabet))) if alphabet else None self.wiki_start_pages = wiki_start_pages - def __repr__(self): - return '{}({})'.format(self.__class__.__name__, - ', '.join('{}={!r}'.format(k, v) - for k, v in self.__dict__.items() - if not k.startswith('_'))) + def __repr__(self) -> str: + param_str = ", ".join( + f"{k}={v!r}" for k, v in self.__dict__.items() if not k.startswith("_") + ) + return f"{self.__class__.__name__}({param_str})" -LANGUAGES = {'Arabic': Language(name='Arabic', - iso_code='ar', - use_ascii=False, - # We only support encodings that use isolated - # forms, because the current recommendation is - # that the rendering system handles presentation - # forms. This means we purposefully skip IBM864. - charsets=['ISO-8859-6', 'WINDOWS-1256', - 'CP720', 'CP864'], - alphabet=u'ءآأؤإئابةتثجحخدذرزسشصضطظعغػؼؽؾؿـفقكلمنهوىيًٌٍَُِّ', - wiki_start_pages=[u'الصفحة_الرئيسية']), - 'Belarusian': Language(name='Belarusian', - iso_code='be', - use_ascii=False, - charsets=['ISO-8859-5', 'WINDOWS-1251', - 'IBM866', 'MacCyrillic'], - alphabet=(u'АБВГДЕЁЖЗІЙКЛМНОПРСТУЎФХЦЧШЫЬЭЮЯ' - u'абвгдеёжзійклмнопрстуўфхцчшыьэюяʼ'), - wiki_start_pages=[u'Галоўная_старонка']), - 'Bulgarian': Language(name='Bulgarian', - iso_code='bg', - use_ascii=False, - charsets=['ISO-8859-5', 'WINDOWS-1251', - 'IBM855'], - alphabet=(u'АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯ' - u'абвгдежзийклмнопрстуфхцчшщъьюя'), - wiki_start_pages=[u'Начална_страница']), - 'Czech': Language(name='Czech', - iso_code='cz', - use_ascii=True, - charsets=['ISO-8859-2', 'WINDOWS-1250'], - alphabet=u'áčďéěíňóřšťúůýžÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ', - wiki_start_pages=[u'Hlavní_strana']), - 'Danish': Language(name='Danish', - iso_code='da', - use_ascii=True, - charsets=['ISO-8859-1', 'ISO-8859-15', - 'WINDOWS-1252'], - alphabet=u'æøåÆØÅ', - wiki_start_pages=[u'Forside']), - 'German': Language(name='German', - iso_code='de', - use_ascii=True, - charsets=['ISO-8859-1', 'WINDOWS-1252'], - alphabet=u'äöüßÄÖÜ', - wiki_start_pages=[u'Wikipedia:Hauptseite']), - 'Greek': Language(name='Greek', - iso_code='el', - use_ascii=False, - charsets=['ISO-8859-7', 'WINDOWS-1253'], - alphabet=(u'αβγδεζηθικλμνξοπρσςτυφχψωάέήίόύώ' - u'ΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΣΤΥΦΧΨΩΆΈΉΊΌΎΏ'), - wiki_start_pages=[u'Πύλη:Κύρια']), - 'English': Language(name='English', - iso_code='en', - use_ascii=True, - charsets=['ISO-8859-1', 'WINDOWS-1252'], - wiki_start_pages=[u'Main_Page']), - 'Esperanto': Language(name='Esperanto', - iso_code='eo', - # Q, W, X, and Y not used at all - use_ascii=False, - charsets=['ISO-8859-3'], - alphabet=(u'abcĉdefgĝhĥijĵklmnoprsŝtuŭvz' - u'ABCĈDEFGĜHĤIJĴKLMNOPRSŜTUŬVZ'), - wiki_start_pages=[u'Vikipedio:Ĉefpaĝo']), - 'Spanish': Language(name='Spanish', - iso_code='es', - use_ascii=True, - charsets=['ISO-8859-1', 'ISO-8859-15', - 'WINDOWS-1252'], - alphabet=u'ñáéíóúüÑÁÉÍÓÚÜ', - wiki_start_pages=[u'Wikipedia:Portada']), - 'Estonian': Language(name='Estonian', - iso_code='et', - use_ascii=False, - charsets=['ISO-8859-4', 'ISO-8859-13', - 'WINDOWS-1257'], - # C, F, Š, Q, W, X, Y, Z, Ž are only for - # loanwords - alphabet=(u'ABDEGHIJKLMNOPRSTUVÕÄÖÜ' - u'abdeghijklmnoprstuvõäöü'), - wiki_start_pages=[u'Esileht']), - 'Finnish': Language(name='Finnish', - iso_code='fi', - use_ascii=True, - charsets=['ISO-8859-1', 'ISO-8859-15', - 'WINDOWS-1252'], - alphabet=u'ÅÄÖŠŽåäöšž', - wiki_start_pages=[u'Wikipedia:Etusivu']), - 'French': Language(name='French', - iso_code='fr', - use_ascii=True, - charsets=['ISO-8859-1', 'ISO-8859-15', - 'WINDOWS-1252'], - alphabet=u'œàâçèéîïùûêŒÀÂÇÈÉÎÏÙÛÊ', - wiki_start_pages=[u'Wikipédia:Accueil_principal', - u'Bœuf (animal)']), - 'Hebrew': Language(name='Hebrew', - iso_code='he', - use_ascii=False, - charsets=['ISO-8859-8', 'WINDOWS-1255'], - alphabet=u'אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ', - wiki_start_pages=[u'עמוד_ראשי']), - 'Croatian': Language(name='Croatian', - iso_code='hr', - # Q, W, X, Y are only used for foreign words. - use_ascii=False, - charsets=['ISO-8859-2', 'WINDOWS-1250'], - alphabet=(u'abcčćdđefghijklmnoprsštuvzž' - u'ABCČĆDĐEFGHIJKLMNOPRSŠTUVZŽ'), - wiki_start_pages=[u'Glavna_stranica']), - 'Hungarian': Language(name='Hungarian', - iso_code='hu', - # Q, W, X, Y are only used for foreign words. - use_ascii=False, - charsets=['ISO-8859-2', 'WINDOWS-1250'], - alphabet=(u'abcdefghijklmnoprstuvzáéíóöőúüű' - u'ABCDEFGHIJKLMNOPRSTUVZÁÉÍÓÖŐÚÜŰ'), - wiki_start_pages=[u'Kezdőlap']), - 'Italian': Language(name='Italian', - iso_code='it', - use_ascii=True, - charsets=['ISO-8859-1', 'ISO-8859-15', - 'WINDOWS-1252'], - alphabet=u'ÀÈÉÌÒÓÙàèéìòóù', - wiki_start_pages=[u'Pagina_principale']), - 'Lithuanian': Language(name='Lithuanian', - iso_code='lt', - use_ascii=False, - charsets=['ISO-8859-13', 'WINDOWS-1257', - 'ISO-8859-4'], - # Q, W, and X not used at all - alphabet=(u'AĄBCČDEĘĖFGHIĮYJKLMNOPRSŠTUŲŪVZŽ' - u'aąbcčdeęėfghiįyjklmnoprsštuųūvzž'), - wiki_start_pages=[u'Pagrindinis_puslapis']), - 'Latvian': Language(name='Latvian', - iso_code='lv', - use_ascii=False, - charsets=['ISO-8859-13', 'WINDOWS-1257', - 'ISO-8859-4'], - # Q, W, X, Y are only for loanwords - alphabet=(u'AĀBCČDEĒFGĢHIĪJKĶLĻMNŅOPRSŠTUŪVZŽ' - u'aābcčdeēfgģhiījkķlļmnņoprsštuūvzž'), - wiki_start_pages=[u'Sākumlapa']), - 'Macedonian': Language(name='Macedonian', - iso_code='mk', - use_ascii=False, - charsets=['ISO-8859-5', 'WINDOWS-1251', - 'MacCyrillic', 'IBM855'], - alphabet=(u'АБВГДЃЕЖЗЅИЈКЛЉМНЊОПРСТЌУФХЦЧЏШ' - u'абвгдѓежзѕијклљмнњопрстќуфхцчџш'), - wiki_start_pages=[u'Главна_страница']), - 'Dutch': Language(name='Dutch', - iso_code='nl', - use_ascii=True, - charsets=['ISO-8859-1', 'WINDOWS-1252'], - wiki_start_pages=[u'Hoofdpagina']), - 'Polish': Language(name='Polish', - iso_code='pl', - # Q and X are only used for foreign words. - use_ascii=False, - charsets=['ISO-8859-2', 'WINDOWS-1250'], - alphabet=(u'AĄBCĆDEĘFGHIJKLŁMNŃOÓPRSŚTUWYZŹŻ' - u'aąbcćdeęfghijklłmnńoóprsśtuwyzźż'), - wiki_start_pages=[u'Wikipedia:Strona_główna']), - 'Portuguese': Language(name='Portuguese', - iso_code='pt', - use_ascii=True, - charsets=['ISO-8859-1', 'ISO-8859-15', - 'WINDOWS-1252'], - alphabet=u'ÁÂÃÀÇÉÊÍÓÔÕÚáâãàçéêíóôõú', - wiki_start_pages=[u'Wikipédia:Página_principal']), - 'Romanian': Language(name='Romanian', - iso_code='ro', - use_ascii=True, - charsets=['ISO-8859-2', 'WINDOWS-1250'], - alphabet=u'ăâîșțĂÂÎȘȚ', - wiki_start_pages=[u'Pagina_principală']), - 'Russian': Language(name='Russian', - iso_code='ru', - use_ascii=False, - charsets=['ISO-8859-5', 'WINDOWS-1251', - 'KOI8-R', 'MacCyrillic', 'IBM866', - 'IBM855'], - alphabet=(u'абвгдеёжзийклмнопрстуфхцчшщъыьэюя' - u'АБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ'), - wiki_start_pages=[u'Заглавная_страница']), - 'Slovak': Language(name='Slovak', - iso_code='sk', - use_ascii=True, - charsets=['ISO-8859-2', 'WINDOWS-1250'], - alphabet=u'áäčďéíĺľňóôŕšťúýžÁÄČĎÉÍĹĽŇÓÔŔŠŤÚÝŽ', - wiki_start_pages=[u'Hlavná_stránka']), - 'Slovene': Language(name='Slovene', - iso_code='sl', - # Q, W, X, Y are only used for foreign words. - use_ascii=False, - charsets=['ISO-8859-2', 'WINDOWS-1250'], - alphabet=(u'abcčdefghijklmnoprsštuvzž' - u'ABCČDEFGHIJKLMNOPRSŠTUVZŽ'), - wiki_start_pages=[u'Glavna_stran']), - # Serbian can be written in both Latin and Cyrillic, but there's no - # simple way to get the Latin alphabet pages from Wikipedia through - # the API, so for now we just support Cyrillic. - 'Serbian': Language(name='Serbian', - iso_code='sr', - alphabet=(u'АБВГДЂЕЖЗИЈКЛЉМНЊОПРСТЋУФХЦЧЏШ' - u'абвгдђежзијклљмнњопрстћуфхцчџш'), - charsets=['ISO-8859-5', 'WINDOWS-1251', - 'MacCyrillic', 'IBM855'], - wiki_start_pages=[u'Главна_страна']), - 'Thai': Language(name='Thai', - iso_code='th', - use_ascii=False, - charsets=['ISO-8859-11', 'TIS-620', 'CP874'], - alphabet=u'กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛', - wiki_start_pages=[u'หน้าหลัก']), - 'Turkish': Language(name='Turkish', - iso_code='tr', - # Q, W, and X are not used by Turkish - use_ascii=False, - charsets=['ISO-8859-3', 'ISO-8859-9', - 'WINDOWS-1254'], - alphabet=(u'abcçdefgğhıijklmnoöprsştuüvyzâîû' - u'ABCÇDEFGĞHIİJKLMNOÖPRSŞTUÜVYZÂÎÛ'), - wiki_start_pages=[u'Ana_Sayfa']), - 'Vietnamese': Language(name='Vietnamese', - iso_code='vi', - use_ascii=False, - # Windows-1258 is the only common 8-bit - # Vietnamese encoding supported by Python. - # From Wikipedia: - # For systems that lack support for Unicode, - # dozens of 8-bit Vietnamese code pages are - # available.[1] The most common are VISCII - # (TCVN 5712:1993), VPS, and Windows-1258.[3] - # Where ASCII is required, such as when - # ensuring readability in plain text e-mail, - # Vietnamese letters are often encoded - # according to Vietnamese Quoted-Readable - # (VIQR) or VSCII Mnemonic (VSCII-MNEM),[4] - # though usage of either variable-width - # scheme has declined dramatically following - # the adoption of Unicode on the World Wide - # Web. - charsets=['WINDOWS-1258'], - alphabet=(u'aăâbcdđeêghiklmnoôơpqrstuưvxy' - u'AĂÂBCDĐEÊGHIKLMNOÔƠPQRSTUƯVXY'), - wiki_start_pages=[u'Chữ_Quốc_ngữ']), - } +LANGUAGES = { + "Arabic": Language( + name="Arabic", + iso_code="ar", + use_ascii=False, + # We only support encodings that use isolated + # forms, because the current recommendation is + # that the rendering system handles presentation + # forms. This means we purposefully skip IBM864. + charsets=["ISO-8859-6", "WINDOWS-1256", "CP720", "CP864"], + alphabet="ءآأؤإئابةتثجحخدذرزسشصضطظعغػؼؽؾؿـفقكلمنهوىيًٌٍَُِّ", + wiki_start_pages=["الصفحة_الرئيسية"], + ), + "Belarusian": Language( + name="Belarusian", + iso_code="be", + use_ascii=False, + charsets=["ISO-8859-5", "WINDOWS-1251", "IBM866", "MacCyrillic"], + alphabet="АБВГДЕЁЖЗІЙКЛМНОПРСТУЎФХЦЧШЫЬЭЮЯабвгдеёжзійклмнопрстуўфхцчшыьэюяʼ", + wiki_start_pages=["Галоўная_старонка"], + ), + "Bulgarian": Language( + name="Bulgarian", + iso_code="bg", + use_ascii=False, + charsets=["ISO-8859-5", "WINDOWS-1251", "IBM855"], + alphabet="АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя", + wiki_start_pages=["Начална_страница"], + ), + "Czech": Language( + name="Czech", + iso_code="cz", + use_ascii=True, + charsets=["ISO-8859-2", "WINDOWS-1250"], + alphabet="áčďéěíňóřšťúůýžÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ", + wiki_start_pages=["Hlavní_strana"], + ), + "Danish": Language( + name="Danish", + iso_code="da", + use_ascii=True, + charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], + alphabet="æøåÆØÅ", + wiki_start_pages=["Forside"], + ), + "German": Language( + name="German", + iso_code="de", + use_ascii=True, + charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], + alphabet="äöüßẞÄÖÜ", + wiki_start_pages=["Wikipedia:Hauptseite"], + ), + "Greek": Language( + name="Greek", + iso_code="el", + use_ascii=False, + charsets=["ISO-8859-7", "WINDOWS-1253"], + alphabet="αβγδεζηθικλμνξοπρσςτυφχψωάέήίόύώΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΣΤΥΦΧΨΩΆΈΉΊΌΎΏ", + wiki_start_pages=["Πύλη:Κύρια"], + ), + "English": Language( + name="English", + iso_code="en", + use_ascii=True, + charsets=["ISO-8859-1", "WINDOWS-1252", "MacRoman"], + wiki_start_pages=["Main_Page"], + ), + "Esperanto": Language( + name="Esperanto", + iso_code="eo", + # Q, W, X, and Y not used at all + use_ascii=False, + charsets=["ISO-8859-3"], + alphabet="abcĉdefgĝhĥijĵklmnoprsŝtuŭvzABCĈDEFGĜHĤIJĴKLMNOPRSŜTUŬVZ", + wiki_start_pages=["Vikipedio:Ĉefpaĝo"], + ), + "Spanish": Language( + name="Spanish", + iso_code="es", + use_ascii=True, + charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], + alphabet="ñáéíóúüÑÁÉÍÓÚÜ", + wiki_start_pages=["Wikipedia:Portada"], + ), + "Estonian": Language( + name="Estonian", + iso_code="et", + use_ascii=False, + charsets=["ISO-8859-4", "ISO-8859-13", "WINDOWS-1257"], + # C, F, Š, Q, W, X, Y, Z, Ž are only for + # loanwords + alphabet="ABDEGHIJKLMNOPRSTUVÕÄÖÜabdeghijklmnoprstuvõäöü", + wiki_start_pages=["Esileht"], + ), + "Finnish": Language( + name="Finnish", + iso_code="fi", + use_ascii=True, + charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], + alphabet="ÅÄÖŠŽåäöšž", + wiki_start_pages=["Wikipedia:Etusivu"], + ), + "French": Language( + name="French", + iso_code="fr", + use_ascii=True, + charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], + alphabet="œàâçèéîïùûêŒÀÂÇÈÉÎÏÙÛÊ", + wiki_start_pages=["Wikipédia:Accueil_principal", "Bœuf (animal)"], + ), + "Hebrew": Language( + name="Hebrew", + iso_code="he", + use_ascii=False, + charsets=["ISO-8859-8", "WINDOWS-1255"], + alphabet="אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ", + wiki_start_pages=["עמוד_ראשי"], + ), + "Croatian": Language( + name="Croatian", + iso_code="hr", + # Q, W, X, Y are only used for foreign words. + use_ascii=False, + charsets=["ISO-8859-2", "WINDOWS-1250"], + alphabet="abcčćdđefghijklmnoprsštuvzžABCČĆDĐEFGHIJKLMNOPRSŠTUVZŽ", + wiki_start_pages=["Glavna_stranica"], + ), + "Hungarian": Language( + name="Hungarian", + iso_code="hu", + # Q, W, X, Y are only used for foreign words. + use_ascii=False, + charsets=["ISO-8859-2", "WINDOWS-1250"], + alphabet="abcdefghijklmnoprstuvzáéíóöőúüűABCDEFGHIJKLMNOPRSTUVZÁÉÍÓÖŐÚÜŰ", + wiki_start_pages=["Kezdőlap"], + ), + "Italian": Language( + name="Italian", + iso_code="it", + use_ascii=True, + charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], + alphabet="ÀÈÉÌÒÓÙàèéìòóù", + wiki_start_pages=["Pagina_principale"], + ), + "Lithuanian": Language( + name="Lithuanian", + iso_code="lt", + use_ascii=False, + charsets=["ISO-8859-13", "WINDOWS-1257", "ISO-8859-4"], + # Q, W, and X not used at all + alphabet="AĄBCČDEĘĖFGHIĮYJKLMNOPRSŠTUŲŪVZŽaąbcčdeęėfghiįyjklmnoprsštuųūvzž", + wiki_start_pages=["Pagrindinis_puslapis"], + ), + "Latvian": Language( + name="Latvian", + iso_code="lv", + use_ascii=False, + charsets=["ISO-8859-13", "WINDOWS-1257", "ISO-8859-4"], + # Q, W, X, Y are only for loanwords + alphabet="AĀBCČDEĒFGĢHIĪJKĶLĻMNŅOPRSŠTUŪVZŽaābcčdeēfgģhiījkķlļmnņoprsštuūvzž", + wiki_start_pages=["Sākumlapa"], + ), + "Macedonian": Language( + name="Macedonian", + iso_code="mk", + use_ascii=False, + charsets=["ISO-8859-5", "WINDOWS-1251", "MacCyrillic", "IBM855"], + alphabet="АБВГДЃЕЖЗЅИЈКЛЉМНЊОПРСТЌУФХЦЧЏШабвгдѓежзѕијклљмнњопрстќуфхцчџш", + wiki_start_pages=["Главна_страница"], + ), + "Dutch": Language( + name="Dutch", + iso_code="nl", + use_ascii=True, + charsets=["ISO-8859-1", "WINDOWS-1252", "MacRoman"], + wiki_start_pages=["Hoofdpagina"], + ), + "Polish": Language( + name="Polish", + iso_code="pl", + # Q and X are only used for foreign words. + use_ascii=False, + charsets=["ISO-8859-2", "WINDOWS-1250"], + alphabet="AĄBCĆDEĘFGHIJKLŁMNŃOÓPRSŚTUWYZŹŻaąbcćdeęfghijklłmnńoóprsśtuwyzźż", + wiki_start_pages=["Wikipedia:Strona_główna"], + ), + "Portuguese": Language( + name="Portuguese", + iso_code="pt", + use_ascii=True, + charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"], + alphabet="ÁÂÃÀÇÉÊÍÓÔÕÚáâãàçéêíóôõú", + wiki_start_pages=["Wikipédia:Página_principal"], + ), + "Romanian": Language( + name="Romanian", + iso_code="ro", + use_ascii=True, + charsets=["ISO-8859-2", "WINDOWS-1250"], + alphabet="ăâîșțĂÂÎȘȚ", + wiki_start_pages=["Pagina_principală"], + ), + "Russian": Language( + name="Russian", + iso_code="ru", + use_ascii=False, + charsets=[ + "ISO-8859-5", + "WINDOWS-1251", + "KOI8-R", + "MacCyrillic", + "IBM866", + "IBM855", + ], + alphabet="абвгдеёжзийклмнопрстуфхцчшщъыьэюяАБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ", + wiki_start_pages=["Заглавная_страница"], + ), + "Slovak": Language( + name="Slovak", + iso_code="sk", + use_ascii=True, + charsets=["ISO-8859-2", "WINDOWS-1250"], + alphabet="áäčďéíĺľňóôŕšťúýžÁÄČĎÉÍĹĽŇÓÔŔŠŤÚÝŽ", + wiki_start_pages=["Hlavná_stránka"], + ), + "Slovene": Language( + name="Slovene", + iso_code="sl", + # Q, W, X, Y are only used for foreign words. + use_ascii=False, + charsets=["ISO-8859-2", "WINDOWS-1250"], + alphabet="abcčdefghijklmnoprsštuvzžABCČDEFGHIJKLMNOPRSŠTUVZŽ", + wiki_start_pages=["Glavna_stran"], + ), + # Serbian can be written in both Latin and Cyrillic, but there's no + # simple way to get the Latin alphabet pages from Wikipedia through + # the API, so for now we just support Cyrillic. + "Serbian": Language( + name="Serbian", + iso_code="sr", + alphabet="АБВГДЂЕЖЗИЈКЛЉМНЊОПРСТЋУФХЦЧЏШабвгдђежзијклљмнњопрстћуфхцчџш", + charsets=["ISO-8859-5", "WINDOWS-1251", "MacCyrillic", "IBM855"], + wiki_start_pages=["Главна_страна"], + ), + "Thai": Language( + name="Thai", + iso_code="th", + use_ascii=False, + charsets=["ISO-8859-11", "TIS-620", "CP874"], + alphabet="กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛", + wiki_start_pages=["หน้าหลัก"], + ), + "Turkish": Language( + name="Turkish", + iso_code="tr", + # Q, W, and X are not used by Turkish + use_ascii=False, + charsets=["ISO-8859-3", "ISO-8859-9", "WINDOWS-1254"], + alphabet="abcçdefgğhıijklmnoöprsştuüvyzâîûABCÇDEFGĞHIİJKLMNOÖPRSŞTUÜVYZÂÎÛ", + wiki_start_pages=["Ana_Sayfa"], + ), + "Vietnamese": Language( + name="Vietnamese", + iso_code="vi", + use_ascii=False, + # Windows-1258 is the only common 8-bit + # Vietnamese encoding supported by Python. + # From Wikipedia: + # For systems that lack support for Unicode, + # dozens of 8-bit Vietnamese code pages are + # available.[1] The most common are VISCII + # (TCVN 5712:1993), VPS, and Windows-1258.[3] + # Where ASCII is required, such as when + # ensuring readability in plain text e-mail, + # Vietnamese letters are often encoded + # according to Vietnamese Quoted-Readable + # (VIQR) or VSCII Mnemonic (VSCII-MNEM),[4] + # though usage of either variable-width + # scheme has declined dramatically following + # the adoption of Unicode on the World Wide + # Web. + charsets=["WINDOWS-1258"], + alphabet="aăâbcdđeêghiklmnoôơpqrstuưvxyAĂÂBCDĐEÊGHIKLMNOÔƠPQRSTUƯVXY", + wiki_start_pages=["Chữ_Quốc_ngữ"], + ), +} diff --git a/env/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py b/env/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py index 46ba835c..0ffbcdd2 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py @@ -26,70 +26,77 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### -from collections import namedtuple +from typing import Dict, List, NamedTuple, Optional, Union from .charsetprober import CharSetProber from .enums import CharacterCategory, ProbingState, SequenceLikelihood -SingleByteCharSetModel = namedtuple('SingleByteCharSetModel', - ['charset_name', - 'language', - 'char_to_order_map', - 'language_model', - 'typical_positive_ratio', - 'keep_ascii_letters', - 'alphabet']) +class SingleByteCharSetModel(NamedTuple): + charset_name: str + language: str + char_to_order_map: Dict[int, int] + language_model: Dict[int, Dict[int, int]] + typical_positive_ratio: float + keep_ascii_letters: bool + alphabet: str class SingleByteCharSetProber(CharSetProber): SAMPLE_SIZE = 64 - SB_ENOUGH_REL_THRESHOLD = 1024 # 0.25 * SAMPLE_SIZE^2 + SB_ENOUGH_REL_THRESHOLD = 1024 # 0.25 * SAMPLE_SIZE^2 POSITIVE_SHORTCUT_THRESHOLD = 0.95 NEGATIVE_SHORTCUT_THRESHOLD = 0.05 - def __init__(self, model, reversed=False, name_prober=None): - super(SingleByteCharSetProber, self).__init__() + def __init__( + self, + model: SingleByteCharSetModel, + is_reversed: bool = False, + name_prober: Optional[CharSetProber] = None, + ) -> None: + super().__init__() self._model = model # TRUE if we need to reverse every pair in the model lookup - self._reversed = reversed + self._reversed = is_reversed # Optional auxiliary prober for name decision self._name_prober = name_prober - self._last_order = None - self._seq_counters = None - self._total_seqs = None - self._total_char = None - self._freq_char = None + self._last_order = 255 + self._seq_counters: List[int] = [] + self._total_seqs = 0 + self._total_char = 0 + self._control_char = 0 + self._freq_char = 0 self.reset() - def reset(self): - super(SingleByteCharSetProber, self).reset() + def reset(self) -> None: + super().reset() # char order of last character self._last_order = 255 self._seq_counters = [0] * SequenceLikelihood.get_num_categories() self._total_seqs = 0 self._total_char = 0 + self._control_char = 0 # characters that fall in our sampling range self._freq_char = 0 @property - def charset_name(self): + def charset_name(self) -> Optional[str]: if self._name_prober: return self._name_prober.charset_name - else: - return self._model.charset_name + return self._model.charset_name @property - def language(self): + def language(self) -> Optional[str]: if self._name_prober: return self._name_prober.language - else: - return self._model.language + return self._model.language - def feed(self, byte_str): + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: # TODO: Make filter_international_words keep things in self.alphabet if not self._model.keep_ascii_letters: byte_str = self.filter_international_words(byte_str) + else: + byte_str = self.remove_xml_tags(byte_str) if not byte_str: return self.state char_to_order_map = self._model.char_to_order_map @@ -103,9 +110,6 @@ class SingleByteCharSetProber(CharSetProber): # _total_char purposes. if order < CharacterCategory.CONTROL: self._total_char += 1 - # TODO: Follow uchardet's lead and discount confidence for frequent - # control characters. - # See https://github.com/BYVoid/uchardet/commit/55b4f23971db61 if order < self.SAMPLE_SIZE: self._freq_char += 1 if self._last_order < self.SAMPLE_SIZE: @@ -122,23 +126,36 @@ class SingleByteCharSetProber(CharSetProber): if self._total_seqs > self.SB_ENOUGH_REL_THRESHOLD: confidence = self.get_confidence() if confidence > self.POSITIVE_SHORTCUT_THRESHOLD: - self.logger.debug('%s confidence = %s, we have a winner', - charset_name, confidence) + self.logger.debug( + "%s confidence = %s, we have a winner", charset_name, confidence + ) self._state = ProbingState.FOUND_IT elif confidence < self.NEGATIVE_SHORTCUT_THRESHOLD: - self.logger.debug('%s confidence = %s, below negative ' - 'shortcut threshhold %s', charset_name, - confidence, - self.NEGATIVE_SHORTCUT_THRESHOLD) + self.logger.debug( + "%s confidence = %s, below negative shortcut threshold %s", + charset_name, + confidence, + self.NEGATIVE_SHORTCUT_THRESHOLD, + ) self._state = ProbingState.NOT_ME return self.state - def get_confidence(self): + def get_confidence(self) -> float: r = 0.01 if self._total_seqs > 0: - r = ((1.0 * self._seq_counters[SequenceLikelihood.POSITIVE]) / - self._total_seqs / self._model.typical_positive_ratio) + r = ( + ( + self._seq_counters[SequenceLikelihood.POSITIVE] + + 0.25 * self._seq_counters[SequenceLikelihood.LIKELY] + ) + / self._total_seqs + / self._model.typical_positive_ratio + ) + # The more control characters (proportionnaly to the size + # of the text), the less confident we become in the current + # charset. + r = r * (self._total_char - self._control_char) / self._total_char r = r * self._freq_char / self._total_char if r >= 1.0: r = 0.99 diff --git a/env/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py b/env/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py index bdeef4e1..890ae846 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py @@ -28,33 +28,38 @@ from .charsetgroupprober import CharSetGroupProber from .hebrewprober import HebrewProber -from .langbulgarianmodel import (ISO_8859_5_BULGARIAN_MODEL, - WINDOWS_1251_BULGARIAN_MODEL) +from .langbulgarianmodel import ISO_8859_5_BULGARIAN_MODEL, WINDOWS_1251_BULGARIAN_MODEL from .langgreekmodel import ISO_8859_7_GREEK_MODEL, WINDOWS_1253_GREEK_MODEL from .langhebrewmodel import WINDOWS_1255_HEBREW_MODEL + # from .langhungarianmodel import (ISO_8859_2_HUNGARIAN_MODEL, # WINDOWS_1250_HUNGARIAN_MODEL) -from .langrussianmodel import (IBM855_RUSSIAN_MODEL, IBM866_RUSSIAN_MODEL, - ISO_8859_5_RUSSIAN_MODEL, KOI8_R_RUSSIAN_MODEL, - MACCYRILLIC_RUSSIAN_MODEL, - WINDOWS_1251_RUSSIAN_MODEL) +from .langrussianmodel import ( + IBM855_RUSSIAN_MODEL, + IBM866_RUSSIAN_MODEL, + ISO_8859_5_RUSSIAN_MODEL, + KOI8_R_RUSSIAN_MODEL, + MACCYRILLIC_RUSSIAN_MODEL, + WINDOWS_1251_RUSSIAN_MODEL, +) from .langthaimodel import TIS_620_THAI_MODEL from .langturkishmodel import ISO_8859_9_TURKISH_MODEL from .sbcharsetprober import SingleByteCharSetProber class SBCSGroupProber(CharSetGroupProber): - def __init__(self): - super(SBCSGroupProber, self).__init__() + def __init__(self) -> None: + super().__init__() hebrew_prober = HebrewProber() - logical_hebrew_prober = SingleByteCharSetProber(WINDOWS_1255_HEBREW_MODEL, - False, hebrew_prober) + logical_hebrew_prober = SingleByteCharSetProber( + WINDOWS_1255_HEBREW_MODEL, is_reversed=False, name_prober=hebrew_prober + ) # TODO: See if using ISO-8859-8 Hebrew model works better here, since # it's actually the visual one - visual_hebrew_prober = SingleByteCharSetProber(WINDOWS_1255_HEBREW_MODEL, - True, hebrew_prober) - hebrew_prober.set_model_probers(logical_hebrew_prober, - visual_hebrew_prober) + visual_hebrew_prober = SingleByteCharSetProber( + WINDOWS_1255_HEBREW_MODEL, is_reversed=True, name_prober=hebrew_prober + ) + hebrew_prober.set_model_probers(logical_hebrew_prober, visual_hebrew_prober) # TODO: ORDER MATTERS HERE. I changed the order vs what was in master # and several tests failed that did not before. Some thought # should be put into the ordering, and we should consider making diff --git a/env/Lib/site-packages/pip/_vendor/chardet/sjisprober.py b/env/Lib/site-packages/pip/_vendor/chardet/sjisprober.py index 9e29623b..91df0779 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/sjisprober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/sjisprober.py @@ -25,68 +25,81 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### -from .mbcharsetprober import MultiByteCharSetProber -from .codingstatemachine import CodingStateMachine +from typing import Union + from .chardistribution import SJISDistributionAnalysis +from .codingstatemachine import CodingStateMachine +from .enums import MachineState, ProbingState from .jpcntx import SJISContextAnalysis +from .mbcharsetprober import MultiByteCharSetProber from .mbcssm import SJIS_SM_MODEL -from .enums import ProbingState, MachineState class SJISProber(MultiByteCharSetProber): - def __init__(self): - super(SJISProber, self).__init__() + def __init__(self) -> None: + super().__init__() self.coding_sm = CodingStateMachine(SJIS_SM_MODEL) self.distribution_analyzer = SJISDistributionAnalysis() self.context_analyzer = SJISContextAnalysis() self.reset() - def reset(self): - super(SJISProber, self).reset() + def reset(self) -> None: + super().reset() self.context_analyzer.reset() @property - def charset_name(self): + def charset_name(self) -> str: return self.context_analyzer.charset_name @property - def language(self): + def language(self) -> str: return "Japanese" - def feed(self, byte_str): - for i in range(len(byte_str)): - coding_state = self.coding_sm.next_state(byte_str[i]) + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: + assert self.coding_sm is not None + assert self.distribution_analyzer is not None + + for i, byte in enumerate(byte_str): + coding_state = self.coding_sm.next_state(byte) if coding_state == MachineState.ERROR: - self.logger.debug('%s %s prober hit error at byte %s', - self.charset_name, self.language, i) + self.logger.debug( + "%s %s prober hit error at byte %s", + self.charset_name, + self.language, + i, + ) self._state = ProbingState.NOT_ME break - elif coding_state == MachineState.ITS_ME: + if coding_state == MachineState.ITS_ME: self._state = ProbingState.FOUND_IT break - elif coding_state == MachineState.START: + if coding_state == MachineState.START: char_len = self.coding_sm.get_current_charlen() if i == 0: - self._last_char[1] = byte_str[0] - self.context_analyzer.feed(self._last_char[2 - char_len:], - char_len) + self._last_char[1] = byte + self.context_analyzer.feed( + self._last_char[2 - char_len :], char_len + ) self.distribution_analyzer.feed(self._last_char, char_len) else: - self.context_analyzer.feed(byte_str[i + 1 - char_len:i + 3 - - char_len], char_len) - self.distribution_analyzer.feed(byte_str[i - 1:i + 1], - char_len) + self.context_analyzer.feed( + byte_str[i + 1 - char_len : i + 3 - char_len], char_len + ) + self.distribution_analyzer.feed(byte_str[i - 1 : i + 1], char_len) self._last_char[0] = byte_str[-1] if self.state == ProbingState.DETECTING: - if (self.context_analyzer.got_enough_data() and - (self.get_confidence() > self.SHORTCUT_THRESHOLD)): + if self.context_analyzer.got_enough_data() and ( + self.get_confidence() > self.SHORTCUT_THRESHOLD + ): self._state = ProbingState.FOUND_IT return self.state - def get_confidence(self): + def get_confidence(self) -> float: + assert self.distribution_analyzer is not None + context_conf = self.context_analyzer.get_confidence() distrib_conf = self.distribution_analyzer.get_confidence() return max(context_conf, distrib_conf) diff --git a/env/Lib/site-packages/pip/_vendor/chardet/universaldetector.py b/env/Lib/site-packages/pip/_vendor/chardet/universaldetector.py index 055a8ac1..30c441dc 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/universaldetector.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/universaldetector.py @@ -39,16 +39,21 @@ class a user of ``chardet`` should use. import codecs import logging import re +from typing import List, Optional, Union from .charsetgroupprober import CharSetGroupProber +from .charsetprober import CharSetProber from .enums import InputState, LanguageFilter, ProbingState from .escprober import EscCharSetProber from .latin1prober import Latin1Prober +from .macromanprober import MacRomanProber from .mbcsgroupprober import MBCSGroupProber +from .resultdict import ResultDict from .sbcsgroupprober import SBCSGroupProber +from .utf1632prober import UTF1632Prober -class UniversalDetector(object): +class UniversalDetector: """ The ``UniversalDetector`` class underlies the ``chardet.detect`` function and coordinates all of the different charset probers. @@ -66,49 +71,87 @@ class UniversalDetector(object): """ MINIMUM_THRESHOLD = 0.20 - HIGH_BYTE_DETECTOR = re.compile(b'[\x80-\xFF]') - ESC_DETECTOR = re.compile(b'(\033|~{)') - WIN_BYTE_DETECTOR = re.compile(b'[\x80-\x9F]') - ISO_WIN_MAP = {'iso-8859-1': 'Windows-1252', - 'iso-8859-2': 'Windows-1250', - 'iso-8859-5': 'Windows-1251', - 'iso-8859-6': 'Windows-1256', - 'iso-8859-7': 'Windows-1253', - 'iso-8859-8': 'Windows-1255', - 'iso-8859-9': 'Windows-1254', - 'iso-8859-13': 'Windows-1257'} - - def __init__(self, lang_filter=LanguageFilter.ALL): - self._esc_charset_prober = None - self._charset_probers = [] - self.result = None - self.done = None - self._got_data = None - self._input_state = None - self._last_char = None + HIGH_BYTE_DETECTOR = re.compile(b"[\x80-\xFF]") + ESC_DETECTOR = re.compile(b"(\033|~{)") + WIN_BYTE_DETECTOR = re.compile(b"[\x80-\x9F]") + ISO_WIN_MAP = { + "iso-8859-1": "Windows-1252", + "iso-8859-2": "Windows-1250", + "iso-8859-5": "Windows-1251", + "iso-8859-6": "Windows-1256", + "iso-8859-7": "Windows-1253", + "iso-8859-8": "Windows-1255", + "iso-8859-9": "Windows-1254", + "iso-8859-13": "Windows-1257", + } + # Based on https://encoding.spec.whatwg.org/#names-and-labels + # but altered to match Python names for encodings and remove mappings + # that break tests. + LEGACY_MAP = { + "ascii": "Windows-1252", + "iso-8859-1": "Windows-1252", + "tis-620": "ISO-8859-11", + "iso-8859-9": "Windows-1254", + "gb2312": "GB18030", + "euc-kr": "CP949", + "utf-16le": "UTF-16", + } + + def __init__( + self, + lang_filter: LanguageFilter = LanguageFilter.ALL, + should_rename_legacy: bool = False, + ) -> None: + self._esc_charset_prober: Optional[EscCharSetProber] = None + self._utf1632_prober: Optional[UTF1632Prober] = None + self._charset_probers: List[CharSetProber] = [] + self.result: ResultDict = { + "encoding": None, + "confidence": 0.0, + "language": None, + } + self.done = False + self._got_data = False + self._input_state = InputState.PURE_ASCII + self._last_char = b"" self.lang_filter = lang_filter self.logger = logging.getLogger(__name__) - self._has_win_bytes = None + self._has_win_bytes = False + self.should_rename_legacy = should_rename_legacy self.reset() - def reset(self): + @property + def input_state(self) -> int: + return self._input_state + + @property + def has_win_bytes(self) -> bool: + return self._has_win_bytes + + @property + def charset_probers(self) -> List[CharSetProber]: + return self._charset_probers + + def reset(self) -> None: """ Reset the UniversalDetector and all of its probers back to their initial states. This is called by ``__init__``, so you only need to call this directly in between analyses of different documents. """ - self.result = {'encoding': None, 'confidence': 0.0, 'language': None} + self.result = {"encoding": None, "confidence": 0.0, "language": None} self.done = False self._got_data = False self._has_win_bytes = False self._input_state = InputState.PURE_ASCII - self._last_char = b'' + self._last_char = b"" if self._esc_charset_prober: self._esc_charset_prober.reset() + if self._utf1632_prober: + self._utf1632_prober.reset() for prober in self._charset_probers: prober.reset() - def feed(self, byte_str): + def feed(self, byte_str: Union[bytes, bytearray]) -> None: """ Takes a chunk of a document and feeds it through all of the relevant charset probers. @@ -125,7 +168,7 @@ class UniversalDetector(object): if self.done: return - if not len(byte_str): + if not byte_str: return if not isinstance(byte_str, bytearray): @@ -136,35 +179,38 @@ class UniversalDetector(object): # If the data starts with BOM, we know it is UTF if byte_str.startswith(codecs.BOM_UTF8): # EF BB BF UTF-8 with BOM - self.result = {'encoding': "UTF-8-SIG", - 'confidence': 1.0, - 'language': ''} - elif byte_str.startswith((codecs.BOM_UTF32_LE, - codecs.BOM_UTF32_BE)): + self.result = { + "encoding": "UTF-8-SIG", + "confidence": 1.0, + "language": "", + } + elif byte_str.startswith((codecs.BOM_UTF32_LE, codecs.BOM_UTF32_BE)): # FF FE 00 00 UTF-32, little-endian BOM # 00 00 FE FF UTF-32, big-endian BOM - self.result = {'encoding': "UTF-32", - 'confidence': 1.0, - 'language': ''} - elif byte_str.startswith(b'\xFE\xFF\x00\x00'): + self.result = {"encoding": "UTF-32", "confidence": 1.0, "language": ""} + elif byte_str.startswith(b"\xFE\xFF\x00\x00"): # FE FF 00 00 UCS-4, unusual octet order BOM (3412) - self.result = {'encoding': "X-ISO-10646-UCS-4-3412", - 'confidence': 1.0, - 'language': ''} - elif byte_str.startswith(b'\x00\x00\xFF\xFE'): + self.result = { + # TODO: This encoding is not supported by Python. Should remove? + "encoding": "X-ISO-10646-UCS-4-3412", + "confidence": 1.0, + "language": "", + } + elif byte_str.startswith(b"\x00\x00\xFF\xFE"): # 00 00 FF FE UCS-4, unusual octet order BOM (2143) - self.result = {'encoding': "X-ISO-10646-UCS-4-2143", - 'confidence': 1.0, - 'language': ''} + self.result = { + # TODO: This encoding is not supported by Python. Should remove? + "encoding": "X-ISO-10646-UCS-4-2143", + "confidence": 1.0, + "language": "", + } elif byte_str.startswith((codecs.BOM_LE, codecs.BOM_BE)): # FF FE UTF-16, little endian BOM # FE FF UTF-16, big endian BOM - self.result = {'encoding': "UTF-16", - 'confidence': 1.0, - 'language': ''} + self.result = {"encoding": "UTF-16", "confidence": 1.0, "language": ""} self._got_data = True - if self.result['encoding'] is not None: + if self.result["encoding"] is not None: self.done = True return @@ -173,12 +219,29 @@ class UniversalDetector(object): if self._input_state == InputState.PURE_ASCII: if self.HIGH_BYTE_DETECTOR.search(byte_str): self._input_state = InputState.HIGH_BYTE - elif self._input_state == InputState.PURE_ASCII and \ - self.ESC_DETECTOR.search(self._last_char + byte_str): + elif ( + self._input_state == InputState.PURE_ASCII + and self.ESC_DETECTOR.search(self._last_char + byte_str) + ): self._input_state = InputState.ESC_ASCII self._last_char = byte_str[-1:] + # next we will look to see if it is appears to be either a UTF-16 or + # UTF-32 encoding + if not self._utf1632_prober: + self._utf1632_prober = UTF1632Prober() + + if self._utf1632_prober.state == ProbingState.DETECTING: + if self._utf1632_prober.feed(byte_str) == ProbingState.FOUND_IT: + self.result = { + "encoding": self._utf1632_prober.charset_name, + "confidence": self._utf1632_prober.get_confidence(), + "language": "", + } + self.done = True + return + # If we've seen escape sequences, use the EscCharSetProber, which # uses a simple state machine to check for known escape sequences in # HZ and ISO-2022 encodings, since those are the only encodings that @@ -187,12 +250,11 @@ class UniversalDetector(object): if not self._esc_charset_prober: self._esc_charset_prober = EscCharSetProber(self.lang_filter) if self._esc_charset_prober.feed(byte_str) == ProbingState.FOUND_IT: - self.result = {'encoding': - self._esc_charset_prober.charset_name, - 'confidence': - self._esc_charset_prober.get_confidence(), - 'language': - self._esc_charset_prober.language} + self.result = { + "encoding": self._esc_charset_prober.charset_name, + "confidence": self._esc_charset_prober.get_confidence(), + "language": self._esc_charset_prober.language, + } self.done = True # If we've seen high bytes (i.e., those with values greater than 127), # we need to do more complicated checks using all our multi-byte and @@ -207,17 +269,20 @@ class UniversalDetector(object): if self.lang_filter & LanguageFilter.NON_CJK: self._charset_probers.append(SBCSGroupProber()) self._charset_probers.append(Latin1Prober()) + self._charset_probers.append(MacRomanProber()) for prober in self._charset_probers: if prober.feed(byte_str) == ProbingState.FOUND_IT: - self.result = {'encoding': prober.charset_name, - 'confidence': prober.get_confidence(), - 'language': prober.language} + self.result = { + "encoding": prober.charset_name, + "confidence": prober.get_confidence(), + "language": prober.language, + } self.done = True break if self.WIN_BYTE_DETECTOR.search(byte_str): self._has_win_bytes = True - def close(self): + def close(self) -> ResultDict: """ Stop analyzing the current document and come up with a final prediction. @@ -231,13 +296,11 @@ class UniversalDetector(object): self.done = True if not self._got_data: - self.logger.debug('no data received!') + self.logger.debug("no data received!") # Default to ASCII if it is all we've seen so far elif self._input_state == InputState.PURE_ASCII: - self.result = {'encoding': 'ascii', - 'confidence': 1.0, - 'language': ''} + self.result = {"encoding": "ascii", "confidence": 1.0, "language": ""} # If we have seen non-ASCII, return the best that met MINIMUM_THRESHOLD elif self._input_state == InputState.HIGH_BYTE: @@ -253,34 +316,47 @@ class UniversalDetector(object): max_prober = prober if max_prober and (max_prober_confidence > self.MINIMUM_THRESHOLD): charset_name = max_prober.charset_name - lower_charset_name = max_prober.charset_name.lower() + assert charset_name is not None + lower_charset_name = charset_name.lower() confidence = max_prober.get_confidence() # Use Windows encoding name instead of ISO-8859 if we saw any # extra Windows-specific bytes - if lower_charset_name.startswith('iso-8859'): + if lower_charset_name.startswith("iso-8859"): if self._has_win_bytes: - charset_name = self.ISO_WIN_MAP.get(lower_charset_name, - charset_name) - self.result = {'encoding': charset_name, - 'confidence': confidence, - 'language': max_prober.language} + charset_name = self.ISO_WIN_MAP.get( + lower_charset_name, charset_name + ) + # Rename legacy encodings with superset encodings if asked + if self.should_rename_legacy: + charset_name = self.LEGACY_MAP.get( + (charset_name or "").lower(), charset_name + ) + self.result = { + "encoding": charset_name, + "confidence": confidence, + "language": max_prober.language, + } # Log all prober confidences if none met MINIMUM_THRESHOLD if self.logger.getEffectiveLevel() <= logging.DEBUG: - if self.result['encoding'] is None: - self.logger.debug('no probers hit minimum threshold') + if self.result["encoding"] is None: + self.logger.debug("no probers hit minimum threshold") for group_prober in self._charset_probers: if not group_prober: continue if isinstance(group_prober, CharSetGroupProber): for prober in group_prober.probers: - self.logger.debug('%s %s confidence = %s', - prober.charset_name, - prober.language, - prober.get_confidence()) + self.logger.debug( + "%s %s confidence = %s", + prober.charset_name, + prober.language, + prober.get_confidence(), + ) else: - self.logger.debug('%s %s confidence = %s', - group_prober.charset_name, - group_prober.language, - group_prober.get_confidence()) + self.logger.debug( + "%s %s confidence = %s", + group_prober.charset_name, + group_prober.language, + group_prober.get_confidence(), + ) return self.result diff --git a/env/Lib/site-packages/pip/_vendor/chardet/utf8prober.py b/env/Lib/site-packages/pip/_vendor/chardet/utf8prober.py index 6c3196cc..d96354d9 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/utf8prober.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/utf8prober.py @@ -25,45 +25,46 @@ # 02110-1301 USA ######################### END LICENSE BLOCK ######################### +from typing import Union + from .charsetprober import CharSetProber -from .enums import ProbingState, MachineState from .codingstatemachine import CodingStateMachine +from .enums import MachineState, ProbingState from .mbcssm import UTF8_SM_MODEL - class UTF8Prober(CharSetProber): ONE_CHAR_PROB = 0.5 - def __init__(self): - super(UTF8Prober, self).__init__() + def __init__(self) -> None: + super().__init__() self.coding_sm = CodingStateMachine(UTF8_SM_MODEL) - self._num_mb_chars = None + self._num_mb_chars = 0 self.reset() - def reset(self): - super(UTF8Prober, self).reset() + def reset(self) -> None: + super().reset() self.coding_sm.reset() self._num_mb_chars = 0 @property - def charset_name(self): + def charset_name(self) -> str: return "utf-8" @property - def language(self): + def language(self) -> str: return "" - def feed(self, byte_str): + def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState: for c in byte_str: coding_state = self.coding_sm.next_state(c) if coding_state == MachineState.ERROR: self._state = ProbingState.NOT_ME break - elif coding_state == MachineState.ITS_ME: + if coding_state == MachineState.ITS_ME: self._state = ProbingState.FOUND_IT break - elif coding_state == MachineState.START: + if coding_state == MachineState.START: if self.coding_sm.get_current_charlen() >= 2: self._num_mb_chars += 1 @@ -73,10 +74,9 @@ class UTF8Prober(CharSetProber): return self.state - def get_confidence(self): + def get_confidence(self) -> float: unlike = 0.99 if self._num_mb_chars < 6: - unlike *= self.ONE_CHAR_PROB ** self._num_mb_chars + unlike *= self.ONE_CHAR_PROB**self._num_mb_chars return 1.0 - unlike - else: - return unlike + return unlike diff --git a/env/Lib/site-packages/pip/_vendor/chardet/version.py b/env/Lib/site-packages/pip/_vendor/chardet/version.py index 70369b9d..c5e9d85c 100644 --- a/env/Lib/site-packages/pip/_vendor/chardet/version.py +++ b/env/Lib/site-packages/pip/_vendor/chardet/version.py @@ -1,9 +1,9 @@ """ This module exists only to simplify retrieving the version number of chardet -from within setup.py and from chardet subpackages. +from within setuptools and from chardet subpackages. :author: Dan Blanchard (dan.blanchard@gmail.com) """ -__version__ = "4.0.0" -VERSION = __version__.split('.') +__version__ = "5.1.0" +VERSION = __version__.split(".") diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__init__.py b/env/Lib/site-packages/pip/_vendor/colorama/__init__.py index b149ed79..383101cd 100644 --- a/env/Lib/site-packages/pip/_vendor/colorama/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/colorama/__init__.py @@ -1,6 +1,7 @@ # Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. -from .initialise import init, deinit, reinit, colorama_text +from .initialise import init, deinit, reinit, colorama_text, just_fix_windows_console from .ansi import Fore, Back, Style, Cursor from .ansitowin32 import AnsiToWin32 -__version__ = '0.4.4' +__version__ = '0.4.6' + diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index bd8cbdaf1421633e7f2105a59c4780d29403dc3b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 471 zcmYe~<>g{vU|^UdaWM5g0|Ucj5C<7EF)%PVFfcF_yD%^?q%fo~<}l<kMlt3xMKR?v zM=|HJM6ob}#F=tfbJ?QUa@nKUb2*|oayg?o!Q#w0T)Es)+>8t<EKxiuticSLY%duZ z7#K8JZn0$MWtQAxOG$;$MG%@dIX@@AC^0uNz9hAx1f<L@zbN$<i&J89_AS=nlFFRa zTWrpyMaB6=nvA!&9rKDaL-NBj^NfwESPk?{^i2FTd2exnjLb~T$t+GS0{NhbnSp_! zhy_HjGB7aQVoA&^&MaaB@!3HH2Z-PV$#8>YO7hD=1{Q&W<`#E+d|7Hyab|vAeEdp= zB7Trk5b>+g*(xTqIJKxaCN(D|vna+tFV&?evn*9XS0U8TGt4z8*fYd2Si#fJ#oy00 z*wZm4*wxoHIK(wb!7L^qz$YfrL^mftJ+rtZGdm_VuPnwVGbyGxvm{lwATc>RF+H_7 zrXaIGKfWwAFD1W79~Lb7@$n$f#mDOvRNmsS$<0qG%}KQbd9oPf9|=YYMjj>rEZ=~H diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-39.pyc deleted file mode 100644 index 289921d1e1e4cdb0a890634e8f0fc739658ba064..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3256 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 PfLB0FKumy*jS&O^ne2R8 diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-39.pyc deleted file mode 100644 index 5a1d0f29b5e7600235db474f382655bfbeeea474..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7722 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 ZK|TN_Z4M?GMiE8<W)?;cMmA;v0|4|y2;2Yw diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-39.pyc deleted file mode 100644 index afa6b47b1ecd18f626bde53106251302c2f2b69d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1738 zcmYe~<>g{vU|^UdaWJ)-oq^#oh=Yt-7#J8F7#J9eOBfg!QW#Pga~Pr^G-DJan9mf& zl){w4oWq>U62-#EkiwYAn!=dKmcp3Gp2C>Ok;0P5nZlaF*1{0Ql_HeFk;2)+7{#5! zmBQV^5XF<qn8lmIlfv7=(99Ucm%^9A-@*{ZpCXVV*uoGckir<upeg(k<Q~75j0_A6 znvA!&9rKDaL-NBj^Nfw$l0j0)n2CXb!5QRS2?hp+5{49pQpO^Y5{44SX2u0f3mF(0 zQW%06Rx<i&G8Zv3FfiQW&M(SLk1sAs$uBLr#aWbEoLUl}n3J=Tp@^M<0Ydz0cD9NM zElw>ej!Df)$t;TT&r5YF$}CG&&{YWa^9*wh3ib?f3|8>;bMg0c4fb@533l~$4GwV) zQZS1N2=IwXG||n;PtPna$;^&P%`1!X$xMnV&MZmQEl5nxPE1cNjw#42(2p-m%}dEI z(ofFM$uCOGP1MiK%Ph%E%*iZH)hnnhVq;)n5CVA&6d??Z9E@O*kYq3y8Ui3TNF6u; zIv5xjYM6_qN*HPwY8Y#n(wUnXi=;{zQy7~Wn;1)&vX~QDN|>@(6WKuQ6oyiUBC`~R zMD{$f5{?oUkd7LL8s=tJ7KRe0c;-ZQkXo>+m=uOYPOvIAG*zsLoF!bvEhXFwcuIH| zGBPrxFeP$<0$h{XuS%!9D6zoSEitD!RUtV)FD)lCxujU3JhLQ2Au+E~A-^OewMZec zDBU)ss5CW1lkXODVqWDfuCT<M(p1-?qWq#;%*B<(x7Z+YRm2L4JrF0gs0a~@APyhM zqJq>ESgdk``0>RhMX8Cow~!@4in$X@QY$h`;#2bTQg5+AIJY>8QbEy`S_BSbO_p1n ziKQj^;KXr@Jvl$GEVZcQ7He@yQD(s{7Le(P#8Sioau*9I?!-Z{B?pQcCLu-+RyIa9 zCN4%cX1@O%Fq(yhk&CfNl7WE%cRE%;q+>o%I*w;5VFssanG)s_#&{M`@D_n0UXv9Z zCPmz!bjt%G_&@|Nh=8YMh(p0{WJ^f}xzZTqN{|33O|gN}l@z*rKzRyeLOw{T4%j_4 z44Diyj7u2%7#SI=1X38n7#JDCLAi{9ks*(xgt3`{k--3**C1|V0{gNEWV9yJEtbTh z^x|7=+2tS_;v|sykg(&0Wq|mS)QS=-key)XG4U}nF>){!$)Y<C9Kx_{PfBp{gMtPT zT!J7j?%*l{2NyVNf!)K%!3Yj6Pz)!7QX|M6APmZZAPiQj2FisjMM|(-Si_vc*vnGO zTEn`4aUnyIQVnYsQ!PUcLokCT6R1!U133bea*9Mj#T~4aD$d9+%}I#|r8Q6v03~Hj zwjz*ci%@kGfy%vG>>z~&sYPgETO`21z~BW6QBcxgU}RxrVPyNy#su;SSWc70&Cf4H zQ?N)Fl#02M^YcJ)kdv7NPF1(K6Z48QOY+M>MK8Gcgrqo-VMXA;1P39glmcfQM4aE^ zgBq2an3tHIS_F>7B2dVItwnMsA{}tp<mRW8=A_zzl3y`MEe9h9BL@=?GYcaN6Bsjd QuyV<8u(L37ad5B$09HP0)&Kwi diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-39.pyc deleted file mode 100644 index 0c8709f0ac9c87dfdfa044124483cfb128d9b41e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3970 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 b<u@BUR1GR0VhS4v3lBR73zrZF7Y7#r{xppU diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-39.pyc deleted file mode 100644 index 958e35ccec9b08bd312a543e7c196a74e518634f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4692 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 diff --git a/env/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py b/env/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py index 6039a054..abf209e6 100644 --- a/env/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py +++ b/env/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py @@ -4,7 +4,7 @@ import sys import os from .ansi import AnsiFore, AnsiBack, AnsiStyle, Style, BEL -from .winterm import WinTerm, WinColor, WinStyle +from .winterm import enable_vt_processing, WinTerm, WinColor, WinStyle from .win32 import windll, winapi_test @@ -37,6 +37,12 @@ class StreamWrapper(object): def __exit__(self, *args, **kwargs): return self.__wrapped.__exit__(*args, **kwargs) + def __setstate__(self, state): + self.__dict__ = state + + def __getstate__(self): + return self.__dict__ + def write(self, text): self.__convertor.write(text) @@ -57,7 +63,9 @@ class StreamWrapper(object): stream = self.__wrapped try: return stream.closed - except AttributeError: + # AttributeError in the case that the stream doesn't support being closed + # ValueError for the case that the stream has already been detached when atexit runs + except (AttributeError, ValueError): return True @@ -86,15 +94,22 @@ class AnsiToWin32(object): # (e.g. Cygwin Terminal). In this case it's up to the terminal # to support the ANSI codes. conversion_supported = on_windows and winapi_test() + try: + fd = wrapped.fileno() + except Exception: + fd = -1 + system_has_native_ansi = not on_windows or enable_vt_processing(fd) + have_tty = not self.stream.closed and self.stream.isatty() + need_conversion = conversion_supported and not system_has_native_ansi # should we strip ANSI sequences from our output? if strip is None: - strip = conversion_supported or (not self.stream.closed and not self.stream.isatty()) + strip = need_conversion or not have_tty self.strip = strip # should we should convert ANSI sequences into win32 calls? if convert is None: - convert = conversion_supported and not self.stream.closed and self.stream.isatty() + convert = need_conversion and have_tty self.convert = convert # dict of ansi codes to win32 functions and parameters @@ -256,3 +271,7 @@ class AnsiToWin32(object): if params[0] in '02': winterm.set_title(params[1]) return text + + + def flush(self): + self.wrapped.flush() diff --git a/env/Lib/site-packages/pip/_vendor/colorama/initialise.py b/env/Lib/site-packages/pip/_vendor/colorama/initialise.py index 430d0668..d5fd4b71 100644 --- a/env/Lib/site-packages/pip/_vendor/colorama/initialise.py +++ b/env/Lib/site-packages/pip/_vendor/colorama/initialise.py @@ -6,13 +6,27 @@ import sys from .ansitowin32 import AnsiToWin32 -orig_stdout = None -orig_stderr = None +def _wipe_internal_state_for_tests(): + global orig_stdout, orig_stderr + orig_stdout = None + orig_stderr = None + + global wrapped_stdout, wrapped_stderr + wrapped_stdout = None + wrapped_stderr = None -wrapped_stdout = None -wrapped_stderr = None + global atexit_done + atexit_done = False + + global fixed_windows_console + fixed_windows_console = False -atexit_done = False + try: + # no-op if it wasn't registered + atexit.unregister(reset_all) + except AttributeError: + # python 2: no atexit.unregister. Oh well, we did our best. + pass def reset_all(): @@ -55,6 +69,29 @@ def deinit(): sys.stderr = orig_stderr +def just_fix_windows_console(): + global fixed_windows_console + + if sys.platform != "win32": + return + if fixed_windows_console: + return + if wrapped_stdout is not None or wrapped_stderr is not None: + # Someone already ran init() and it did stuff, so we won't second-guess them + return + + # On newer versions of Windows, AnsiToWin32.__init__ will implicitly enable the + # native ANSI support in the console as a side-effect. We only need to actually + # replace sys.stdout/stderr if we're in the old-style conversion mode. + new_stdout = AnsiToWin32(sys.stdout, convert=None, strip=None, autoreset=False) + if new_stdout.convert: + sys.stdout = new_stdout + new_stderr = AnsiToWin32(sys.stderr, convert=None, strip=None, autoreset=False) + if new_stderr.convert: + sys.stderr = new_stderr + + fixed_windows_console = True + @contextlib.contextmanager def colorama_text(*args, **kwargs): init(*args, **kwargs) @@ -78,3 +115,7 @@ def wrap_stream(stream, convert, strip, autoreset, wrap): if wrapper.should_wrap(): stream = wrapper.stream return stream + + +# Use this for initial setup as well, to reduce code duplication +_wipe_internal_state_for_tests() diff --git a/env/Lib/site-packages/pip/_vendor/colorama/win32.py b/env/Lib/site-packages/pip/_vendor/colorama/win32.py index c2d83603..841b0e27 100644 --- a/env/Lib/site-packages/pip/_vendor/colorama/win32.py +++ b/env/Lib/site-packages/pip/_vendor/colorama/win32.py @@ -4,6 +4,8 @@ STDOUT = -11 STDERR = -12 +ENABLE_VIRTUAL_TERMINAL_PROCESSING = 0x0004 + try: import ctypes from ctypes import LibraryLoader @@ -89,6 +91,20 @@ else: ] _SetConsoleTitleW.restype = wintypes.BOOL + _GetConsoleMode = windll.kernel32.GetConsoleMode + _GetConsoleMode.argtypes = [ + wintypes.HANDLE, + POINTER(wintypes.DWORD) + ] + _GetConsoleMode.restype = wintypes.BOOL + + _SetConsoleMode = windll.kernel32.SetConsoleMode + _SetConsoleMode.argtypes = [ + wintypes.HANDLE, + wintypes.DWORD + ] + _SetConsoleMode.restype = wintypes.BOOL + def _winapi_test(handle): csbi = CONSOLE_SCREEN_BUFFER_INFO() success = _GetConsoleScreenBufferInfo( @@ -150,3 +166,15 @@ else: def SetConsoleTitle(title): return _SetConsoleTitleW(title) + + def GetConsoleMode(handle): + mode = wintypes.DWORD() + success = _GetConsoleMode(handle, byref(mode)) + if not success: + raise ctypes.WinError() + return mode.value + + def SetConsoleMode(handle, mode): + success = _SetConsoleMode(handle, mode) + if not success: + raise ctypes.WinError() diff --git a/env/Lib/site-packages/pip/_vendor/colorama/winterm.py b/env/Lib/site-packages/pip/_vendor/colorama/winterm.py index 0fdb4ec4..aad867e8 100644 --- a/env/Lib/site-packages/pip/_vendor/colorama/winterm.py +++ b/env/Lib/site-packages/pip/_vendor/colorama/winterm.py @@ -1,6 +1,12 @@ # Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. -from . import win32 +try: + from msvcrt import get_osfhandle +except ImportError: + def get_osfhandle(_): + raise OSError("This isn't windows!") + +from . import win32 # from wincon.h class WinColor(object): @@ -167,3 +173,23 @@ class WinTerm(object): def set_title(self, title): win32.SetConsoleTitle(title) + + +def enable_vt_processing(fd): + if win32.windll is None or not win32.winapi_test(): + return False + + try: + handle = get_osfhandle(fd) + mode = win32.GetConsoleMode(handle) + win32.SetConsoleMode( + handle, + mode | win32.ENABLE_VIRTUAL_TERMINAL_PROCESSING, + ) + + mode = win32.GetConsoleMode(handle) + if mode & win32.ENABLE_VIRTUAL_TERMINAL_PROCESSING: + return True + # Can get TypeError in testsuite where 'fd' is a Mock() + except (OSError, TypeError): + return False diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__init__.py b/env/Lib/site-packages/pip/_vendor/distlib/__init__.py index 63d916e3..962173c8 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/__init__.py @@ -1,12 +1,12 @@ # -*- coding: utf-8 -*- # -# Copyright (C) 2012-2019 Vinay Sajip. +# Copyright (C) 2012-2022 Vinay Sajip. # Licensed to the Python Software Foundation under a contributor agreement. # See LICENSE.txt and CONTRIBUTORS.txt. # import logging -__version__ = '0.3.1' +__version__ = '0.3.6' class DistlibException(Exception): pass diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 26fe7876846643be9ad59f28927ee4e43dc81a5d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1084 zcmYe~<>g{vU|^UdaWK`DiGkrUh=Ytd7#J8F7#J9ea~K#HQW#Pga~Pr+QkbF`-5FAt zQ&?IUQdm-%nwg`Rs{~RQQdn~sa#^BS7#YGD@>EzDQduhl7#Tp&ogsxSg}sF#g*}xa zi>;YCiY1aEkI8@`m0<yUD#t>`D9%*Q1zf2t%?t|}85vR-gBdhAUV_}=SH)_eXRK$K z4B{YTMwr8R7#J8*8KM|d7^0ZK8kuehxMUWW<YXqfRwSnulw{`T`DrrW;)svWOUzA; zkH5tgAD^3_Qknx|^Tfv&mL}#vWL7d1u`w_}h+hrPRxzQ)sYS&xsW~Z`MKS()sV+sC zWvL3f3ZZ_UVXi^Jo*|CG3Z8y0{(i2(o{llWuD-6pA+A9RW-$Q)J~4?Vx;gpjnZ+fU z*)gekWidXPNioHlC8@dviOJcC>8Zsr1(^l<@nxxbDfvbEDG(Ry$H!;pWtPOp>lIWM zF)=VOaD&1g#Nc2A^EDZ7ar>3#<ai|JrR1a*VFU|EDLB4VP=Y0esf8hm84_brEGeuh zY%L5?tSRiEa4rJHaWY6FEPO$1Q2087EN1~nd@#dGMn7=qtYo^yQk<HTc8jejH95a1 z1uO_5*cliYZn0&6ohHP<!0;JlV3iP(d-Wiagl#M0ghfOVD1k!E2S*Or5|-55%o1Uc z5<Uh7hAIJMD?n1oAm@W@2VoE!<R!3oK&GWI)G)*|q%Z_CfUVJFyv34}pPa49SOf}g zbi25ci&7IyQhoB1vqj)GiXq#GP~fM@R>TZa1PZkxRuGF9MDT+MK@b7<1A+kg1{?t( z$zqT=2O|iA#WcBZvFGHcr)TD+-{OvsFH0>d&dkq?kH5tUPubu^0akpA+cUQyzo^8u zs3^ba7CSV7+~Q16E%C`uPfslZJM0!4$iUR1TU?1LDNr>?9tJs}2;`<)95#?VVh7?C Z3otM+a4@kj2{1D;3NZ38O0aS<0sveu<>3GT diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-39.pyc deleted file mode 100644 index 41b0909f21b95625ab9c3a5a93e9b92145f3754d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 32186 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 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-39.pyc deleted file mode 100644 index 912b3ee2d9dd1e4bc7da4e21c551ce45c0546ec1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 42508 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 YcnQ=q#Ii85FbmW(2y&TmNO4F404`X_aR2}S diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-39.pyc deleted file mode 100644 index 9665374b7abc14d7f9b2570423b6a7eb9e68ba16..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17529 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 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-39.pyc deleted file mode 100644 index 0becc23bf9eef5df250973155261d3ffbe49934a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 38517 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 S-c0{ln3(>sv9U36F#`a{ktFE= diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-39.pyc deleted file mode 100644 index 2aa069a2d60f9d2bac22989becf8ef4642702fab..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10220 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 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-39.pyc deleted file mode 100644 index 97123f12612c5c75856379337b9c09c8e05957a0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4511 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 F0RUtF5S9P{ diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-39.pyc deleted file mode 100644 index 14140c9e7b7cdb11ccdd68e4dea3a443d048f5e3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26437 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 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-39.pyc deleted file mode 100644 index 8d057ac273a36f696a6677b930d9ed15a3e5d43a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11050 zcmYe~<>g{vU|^UdaWIuni-F-Wh=Ytd85kHG7#J9eTNoJ_QW#Pga~N_NqZk=MY^EHh zD5eyK6s8>JC}uFt62$_hS)*9NG+PuKm}ZY+2h$u;9AKI=iW5w8MRBDtr?BL3=ki4H zFfybtr?BSm=JG}H<?=`I=L$p#<O)U!GBTvHED%Z+UdR|FlERcI>duhDmcrh`kiwoS z*vuRy=FX79k;2)+kiwZN-pm{&;m(l4mBQV^kiwlR(aanr>CTYClfv7=kirY*OSv<o z@TKs#Fr@H<)l0iGqzI%4wlJg!rb;(6N6DnhrZ6=#rb?%BWyz(=WHLp`SGiR2fZeMQ zr5MhTC&R*!sx*PIQi+iP1i>=OQHqfac}xZjsnV(Psft-DHZYc|4MQ|Ymjp;xs#+S; z1jfn`kUmBRh>jGY6yX+zDD_N+D2)`66wwxjD9u#P1zM@vDPqlx3mKzyQp8gvS{R~q zQ<#DoG$mhx;zyJ5mOyD<W^#T?YJ5&+NorAIPO;xhMg|53kc>-aaY;^Ql50hBYC%b6 zex4@FE&k-h<c!pm_=2MRg4Cjt%3FNtsU`7X!T6-a;?!G$1&JjY@g@0Cv6RfBTdd9? zJ;@;ZkTDCCQ>@3pz>vxi#hAhn#gxL)&XC5K!j!_?!WqS!!ji(;!Vtv*iK!^ob_N!P zD7Ih*P0m}qL8-<0rA5i9V8i{AnV_bDC=i>Kfq{V;l;R8+7#M08Qy5AaieyR{vKSXI zl`uCml(3{QHZv|{s%0!;En%x+Xl7c#Uc<N$oFao6G@1OW_==zw=z@Kx$#IJ*zxWml z$a}X~vhp+Yir5$!7;Z5amlWM%EiNrcEh++~@>?A7@tJv<CGqi^Ot)ByQ*+X8v48?* zCF3p5`1s_U#Ny)k_>~O58lA0TLW@(2iepl9QZkET{PR*>iZaVm6?7Fs{XD~5gMvLn z9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u5>0e-^3yYmOER-#QuE4Ud@_?_iZe@6 zbqf-cvlG)(i(?8h3-sg5Qu9*si}X_<F{uypQ?Xt_Wf4CE1A{Cmh(I1;VB}yDVXP8E z306IrUy?yV2?|;e2C+dKU)6pJa0pdhPy%%uPYp2Z3!8L0~3fKw<gNz6%ANXst* zi=}6lrRFKX++oiJ*JD+XSd^Fxm$6a^$w*bO0tc8?0?btj3Q4J%dFc?7Q}oa^gCYl_ z5yVo+PXk*CvrHi~56lNU3rTNLYDsBPo|QsKQE93|CPWWdjY4KI#PtZpAw?n#3=Auo ziv&QC&jB;Kh?{|d0W1X}M8UF|#qnUzD}w?GlqeZE(E}K!1SS1)FfcHHFgSp>fYWal z!vaQ7`ix<!WvXSaVM<{vWhj!XVXkG#n^eM-#k_!}h9Qf!hG79)4bwu#8s>$}wJcz9 z_8OLjjJ2#_Hb)KXLdN2V5~c;5AQmG7Sd<H-qBtvssg^B|r-oqxcMV8CQ!QH!ThWFR zo*I@E=4PgTnOgQ5_658(j9Gl3ToTTZ!pOqF!qCjj$dD&s$WXk@09=ZJN+U*w8kS%N zO_r)9@c400Em25>$E`wUUP(S8Ds=E90!J)KATzJHBrz{J6%i{|@F>hkRRBeOUSe)4 zk<srLa*L@vNt6E;TUusbN@@{uiI$m{mR|&_*&y-D1BzrpP}K4k6s4wRR)ESmPzlGL zl34_@@)m1mF^JERo0y%Nl37%Ii!HSxv$&+VNCKpbCBGmw?-px$QD#Z%E!L#UlGI{N z4sc2;5(mk%K}-c(c8jejwYW5=qzIHlZ?S^Y(JjU_Nb&-u!6I-PV@^*k0hOP{GN7Ev zF2Kma$i^hW$iv9P$i>LR$i~FO$il?KsKr<%2+Kp@0#h$NwM3KAPm>)~UV)q*AAgH0 zK0Y@;r8FlsKK>R@e0*VPVh%(GTvC9&P^1BJCoi-hOHR$niH}Eek`O3>K<)w;g&-#t zgUS{TMm{zUZm<|eEda_E;FbZ%Pw-lRF@>pxA&NPL8I+E0@xYw!lvtdKQ51np0Ou4? zmaJi{VTfm_VX9$>XG~!TW?0GSr^!?#1#&eD$TOOdoC_8y(g!&gWG}=EV26VWMNd$E z1r=-zjBJcmqR6(xOGH0SmLg4%ek~B84I)5VAts@jsms8?-~lod<WvsEA`l-VAV8%m zI3Pd-A|RreQ<$PyK+T&LhA7rlwiMPBwibqF#whkwwiNah4ltV|l`Vxcg$vB)OyLe@ z(B!$r0dscMad0+tQ~;Ny3Pq^}MXAN9c_pB7G%-&hGY?i}!1Je$LUCzwhC*VoLZU)S zVo9PxT4qkFo<c}QX0bwMG1#=c{1Sz{{G!~%oSaGpNQNxQOe{%FQAny(C@oGcQUJ9n zbQF?GOB9L{OEOZ6KoW^yz37Fy8#v!3D3oVpCTA$*Cgy>vFL3byD_$Wv-7OhZ>wwZZ z2!q(5Fat+DC}-9%fD1{6g`nDqv1$_7E>ML8DttiI5zI7*$BIjeQWJCa5M>Y4dkP@0 zB`UxgI0_~C3ZUGqkXfRTpH!BaUka+*5=%gQNT~w~rM%Q~1&D!gTT>I0GZacPbCHTE zSW4sqwV5EwS29BKKWd7(#hD1IIzSE#gQXh=_9`J*l<L8yaR&*g#3^9_w|n?X7@HXq z8A=!yFx7yArwCMJXfoeo1y^(6j0w)!MMj`>jP4dt?8k#j)p(FwKpC2WnFEwF5bl91 z!R;ROD1x{Fnm0K?Ap$NCu{og#RDq^}EC*#E2Bs=LctC*lkZCCg$kO7>s#I)t-eLjC zWFc7!Z*l5@Wc)O_(DMH+_W1ae{A5t!nOPj4oS#>cn3<PaRAdYaQ&4lX$P~l^`K8DL z#6pBKm<29=K&@3jkforal!K9lm4%6elZlawjfs(qnTfFoB#*o30F}7NMMo+NxFroL zE?84Qbu#NML^S|&U<jGP#|sKRSe`1z8it$*X^@|wu_q0SJ!hB`^x*3JG}+LCwa5w- zR^afn1+l<kg&@G8X3fCBkPor}lsGvUS(um@i$G$yLuwLopMx=qIh7@gbpcxn(?Z4~ zxfJFo_B@spmMC^eVH?E(DQKfOA%$!dR|<CuPYXj7cM5L`UkgJNPYQpEKnp_@Z;D`w zPzys8Uy5*wNDD(0e~M^|SPMgx0JP^Nm?D`X)xr=Zlq#Gmk|mlY*31|so+6zh)4~uX zks=$+pec6?p0pvQVwDNFK!Jsr0;G)sZcT&ooI-JBaY-to)m#iIDQ~f4C6*;>GXG-H zE2vBcllfI_df*B`lc@+)!xT9(FfgFBIzh1m3O{gx3MwEVb!iD>4Py#p3PUq<4MRLr z33C?90#>jXQwno4^FmO4%Lb}xHCg;XEr^`_#FW&c_;^se0_4K@_*)E`?6=q;EsI<1 z>8T}&B_&0-*dPj#T34WkP7$berO5;-6J1fG8ywT1I<^rO)1c~^kFiP|7CMk1gICcQ zzC)=lAbmkln>v^QQWh~I9CM4KC^az$ROYROItE(<pC>*sC9AZ!1Y9__fm{U&Lk7kw zcnXKP2uU4^t3b&b)X)Hjxf25eLkU9-V+mt3Q;|RlV=Yr2OA1phQw`$+CQz%smbr#` z0dop-4MP^oLMBFr64orXEcP1aK89MB8ioZNpmsc{z2x^9R5$AXV$?4JF*G@Eab*@m z>geQDa9MhbwYVTBv*Z?AW?pe>Q3*KI5uPss71c#vpg{mua7^6dh2_t9P#fwNb8%|H zE!Kj>qLShwRm@1b#T5^#F~OnI2?`ZHP<_qJ#mL6Q!pOzQ$H>E2C5awqa2+V&0}4;# zW35O5<QP!v4XGIhN;bDx<3Sl`D#$S)BN-U0M9>`oQh;GMNHI8WK%IaTh8o5!hBPKv zdSL`N)L{t()PhH|wn&<Rfnf%crLt(2f=W<u6&w%hX`t8+N)>RQyMX$D3=0@QskN4= z2Gkd1TF6)|mBLWVoTpX;s@Fj!mq7`04MPoMGgB>d9#;tqj9tT2!yM0A!whpbTTw75 zoI*g2V&3@7;`o%zqSWM){Gv*5p$V>Iz+Tg20Y`sP07yAF17M477Es8|2Kf@y0B2z2 zVg$uB7b6c77pRdSjOJ&MY80P>!WiyTP|^eCfh@)p#%88qhLucyx0s5OG?|JN;f@Fe zvCwJ&Lk0$h<sdhJOk==IU!ahNw75|02H6YmX@e?dgx&oTwM;ck3z!x%gflQPq%gpG zyTJ^G48>Z=y<Jf0R}=xtF3bp5-eM_AO-zAxH^7NQ9gDlo7#J8<f!qy>Zw5v_#wrQ4 z@B+CU(#ipQ4V0A_7#KiokmJFL6O_MT#aR|3sQrsspn(eBVo+NLTj-fHFfgnGxdLP? z17?W|asx;+O4xzag32$DGm1gIpmxSIP))(q!qLf4!T=t}V@_dd;V1!>UyNDI3mIJ) zni-ox&2v^itc?y~kQ>Cni9Llen>k;khG79i2Ls4YJPe>QCcj(U@$m(fkURq#VdF^6 zODQhTEXlYfRGghzP>`AupIT9pnpd2epI5BOSOgApM5`8D7_cYi<m8v9rfdS)2CDHG z7&#cZ{#WT@33*t-SFC4~lb@WJQ*5UP)s5l-CI$uuPz-`S0BU)sGt@A|3e+-ofbt__ z5lao@M5aQPV5Bi3O{QB+dIn$zYBCmqn%0og1MEaDo1DzzlH~l{0=umY3=E$^v0i0B zocj=3HCaGKbqTm+zr_wRF(tDIoU@DIsX&tnVmB!7f`=4}Y#10AHiCi%<RJz|9_A_; zd=_J*2~c_fCreOX21Q^EBPar4r4LgPs7r(93WV3e&Asg)>p@|Pr7lHoTcg+w%EzGe z2x{~dw}2B7yu@TmVJKxRYN%mKX9U%vMGZB~3m8)v7czqKco+jCLk&|FQ;|dsQx<bA zOAS*Niwi@nT`g-3OR-N4Yb{$IUkcL#)*6-?)^w(YjJ0fFU$HG@1dWMhF%^~7FfU-M zVF!(i724IXgUl<mE0h403!2P+;7Yj22UI?=7lnfgUFL%P0<b?JBM{(bEhw;Vu_YE1 zq~@i-28F=oE~x0Z#Zr==l7EX8Jjevrbc-V|wH#6#vnFR`=A=ME5L_yPQxFGuG`}Rj zXb&hXK@}sYWCnHHKy@%1BM5RavM{nS@qx-~Mjj@Nb`;D6KTS#WHn}C(8^x8yw>S!N z5=+wZi*j#q6_<co1fa}V6bCBmKy5W}GXhcHfNMl>AQXX0>>^O{R|G13z^M)#CbxKs zOA<>mlXFu`GV)WvX%~`M<UnSE(@r*s1@<a}0C~E|j)8%p9OPdm&<H9c3kzrjjD?AV zm4lgshl3ePvT!hSuyHW+FoD&Bk_#w%!7(WPf;hzqXnh25i3XaP;D};@&P=dEXC~Mn zb4O9^Dd0JyC=SS6Q4}X+jwp%?GB*^(4V|Uo0ncRc1~X`i+!Bn+EI`d*Rc1IF{qXV# zG?=Ydm018Dn}Ig_QL+Qb8!%iP1#ViFFxG%3I+#Gs2u6k)hAieRmRhD1#uC;Vre;QQ zh8l)=wi0%bcnVW9Q;{8rmBmrR5YLgvQ^J|WRl_6+Qo~WgUBi&Y(F|((^S}~0$f{dx z@t`Juu_kX3s7fj-0L2qH6}W@a3wvTwaz<uZ>MiD+)Vy0<kipJ)5Su+Cu^7}VC@KW0 z<E+Xo$jmLsFDkhu5?_^BfM}mUCY5fn73UX~q^8_r1q~ck!0K3VccBPmC8+NV$q(RE z0dm1rP^thqih&U{M#{&;!^p$L!&oJS5%{>f51__0xL^Ynj5UnV0u5pjmPRKy=|2G3 z3oXgyu-JvGV*s)ORG@+FTLdc17(wG(DGaSlk_@$spsraKV;Mt{9JrehR>N3iRl}IV zBnckU&t?YkK!f|@47H3UEYQgT&~z7bl?ZsEfLRhWRRAsk!x{3#SQtv!D~ll0i7Cvr zOpqzX8m8i&5{?C&DJ)?7xU#qxf`<Erz+$Y(Vl|*CMK-^Xm;e9&|L;~M3~p{Kq$OtN zq^4LYs1_-x7QqC|^NX_Kf|@)<C7>7s#XBUc2ZB-nTT*6mYH~?YB}gt0B*NvHmy%lH zT2zz|?mDKYrxx8}O-W5EO)mnats)gr@d|CO!dt4h7&9TU11=`OX#v#eeGG~d&`=4e zy#;Ek3W0kiOpGGnQF9hX5hfwVDse2ah0%5eMH2{vqe%@EO$=EKS)f{lF$<Kjm?0Sp z8g0y=mN=;YpvmM{1j;a)ED+a&Q!Uup#Yp}DmHc3jLCQa{C%^>QC!oH?SCCI&Ef_Jz zDg{h8gPLxT<`PC11C%U5t^hk8ls7;r3^dJ@#f0331cmP{@K_mWEEwVzc=G`gzF-G| z%JN?z2Z785RovJegS{;as<^@K0JTF(Kph-Vr-pGMa%=V$Q)d1xb|=uZiKjoL>cHj> zP{r~W$sID--GQSw01psQbpz_})i7i+LgSCAh9QdyR0yUpN<x~WFG0#RnIVCKNXeik zEF@$Q@dc{o7#JBCib3fGR0?4$dqA;;(a>gRU|;}6GB|t|fD##F7O3<_IE$%B2Q(!J z&;2?zOrYFv&QQx#!U9Tywag`~%?!0HC2R}WY8bNEYnT=?)w0&Gf;x#=?9GhX3`KLm z;;fROfdo+JGNTYKQo{@l0Ja*I1)Mc(3%E*{vY1nt7BZzUOEQ3(JvFQ;Oy&%=tc4zs zsXxD>Dp1x1g$}s+qsfgFM4-NO5h$M*fl_-Br~)pk1}R5mcjm;Dlp@eLs3tq43kuE) zpd50Gr64CY4>Igf4=NcLi_t?G)PQ9Hg*0f|2Ncqv{0(aP@G<f+3NSJ;3NcDBaxqrP zV^0|HDi)<W1;rY?K+XV10w}vc1BS7Nu}BLvPA17v!kERB%?#p!SmvMtn0Wzs%%%oZ z05gFLU=~m+TEGgbh-;al1u$D>60`tjs%3^2z@YgrW=LSVX|hAgN<{FX23k=KQrQ6t zsv=PMKtc+f48a6AtAbil!k`cW)s&!85EMdujIa_ATgae{6KL{bYY;-F2|?pVMWA99 z($)i&3XrxQC<8#6c_8bHbU-l<b`qEXxdhVx0JRz}g7Pm&oP&{tnTMN$nL`NNh-2np z;ot|iD^MZ_RN{al2%JMeB}ffp2?Myb!)U_*YN0^-!%VjXz!g(!QG8J<XzfH%<t>(y z%7Ro)CU7}?iw9J|rxt;SuZqx;)h&LAp41|!83v#L1li2MSkwg?Oa-+MKn+I_2IW_{ zi+VuGg`tF@jG;)VgrSB3RD<W0)qs;q8Do(OXxOHikrB)X%Yt)l3S$aWGc%~WlEPHV zP~=s@n!?=7*u)6R(J3roIZ%FPFX5<R0WI(W<!7+UiW1fo)*1#e29W9+aN7>lVgT7} z!vJcxXtGt!hqf?5D<6<&<{<$99$!vWfG#D0j44CcXF$aut1LjHfv{<Is036oWNOSx z0dxKyG9;P+oit2FtPDXh05p6I8h(wB_p7pq%r8|)PRs*M%%y`D5}>#eGP10rke`=R ziR$no(1>c4TxecmQcfypA`jGsFG)onL{}{WttEoSD5QB=lmjYO*dfLigT}NWjnVk{ zA~#T)1x0I7JBS6E3@_>c<vO-o>`>=J@*B7<3eJO|+Or5W3W}DTz%$Thpd<vUXc*Wy z7`d3ZK;saMJd7NS985fne2g3rHX~RqX!%e|X>M+1d_2m~11ogs0i5=O7#J8*7;70J zH7KZL29?yH_8+LLTf(}4rGyPsA1s7)gZ)a_YgtM-vN#uT)i8j{^BR_T?i!{VmUx~T zW>BgErJG;|P3EdK#HE*#3?1k+ZgEC_X-*1awpk%j0X`)Lopgn#sFDmwasov-CF!Rm z1ESln2sB`-$$N{vAUnOZBs1q052#{=L}O|ZB!Y!Ow#CE5pivKwQE=RXqV*PUJS4;+ zX#vte1;;9=w_XGaac~mTWQEjj;L%ZVgoA3HB5)!A6=IO62bH|H_#sI*J}tipJU$)- zN&z4>4D2jSpcNZ@j4X^Si~@{oj2w(bpaE-5Jx~%%D=jH4N{x>%0u?xr+7dJka*I7D zKRrD&FCF5xiJ+9rR-6IyGsKsypyI8#s0@@`L4i^PO1-yOzzRSq2fT=_2-LzT0@ZG} zKohY(`Jm=Cq=c^pX*2;5oM5x_ld?b!bI=L~$T%@*nho5K2A9g<+;EE<-hoRk0_T)l zQt@d;`BkZT(D2U5Oac$n73C%7L@~#wW!~cU1b6r#4SYci)wcwK!HfOeGILUWz%xv@ zxIk=3VRDPlv81FZGpV#B6>I>wI4%N}x{#d1<qKZc5>i=^TEq+T%M=g+3S3CcfWjZb z0>=@D4J5wpK*3TBs?T_sI6#>a88h)PN-%LTvoH(j2(Sq#3UCNS3HWg^vi)OWWnyAt Z1Z7{)zzS#xT!@j4nS+^ynM0C~830ZknCSoj diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-39.pyc deleted file mode 100644 index d2bafdbba247cdcd44b5b5c68612d281ca1d7436..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10958 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 MT#PJS90Dv%04oJ9r2qf` diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-39.pyc deleted file mode 100644 index 22a066ee2fa540b79e7054b5e3c8c25d3e684f7f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 48230 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 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-39.pyc deleted file mode 100644 index c97c1bf37a7349062ebe174707b8fa0b26df4e40..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20335 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 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-39.pyc deleted file mode 100644 index 7f8f24b6fb063e31e3d632d990e4a98405483d5c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26419 zcmYe~<>g{vU|^UdaWHkq0tSZ1APzESWnf@%U|?V<p2Wn!kiw9{n8T3E7{$m4Vl(A1 zMKPr?q%h?$M=^tGmM9i5%^Jm)!jQt8!=B3##Q{~z8N~^f<BH+})7(+qV45e22Tb!u z@q%f-C_XUFAH@%*1)>DNv|yAVm==l>0@K1#!YM2%tT`gNqEVu`Vo_p@3@I!rY&qh& z5>XPll2MYmQc+U5(oxd6GEp*MIrbdcT)8MYFq<PsK35@1Ay+X<F;^){DOWj487$73 zqmru{rJAc2rIxE6rJk!1rID){rJ1W0rIo84rJbu2rIV{0r3+Tem7|xdAElpb5M{u~ zkjk^bFx6-wW0Y|UQ=&<#X{ulfcQexj#v+>(o+z_CtyIA*^92?uybBp8Fct-*@I{&B ziGjpY__IN(l2Qbs%<@=L1f$GSB^Fqw2rXocvP!j@z*yXoBAhCiWu3y5BGSqv$sooM zWtAeDY9-DPWs_<KrfpN%vQ!q>Eo4|=pCXnbzL05weToE#j&cB-CAp9>$}!b(0%Osg zRL2DtDN<lJfY|maQYnH9nW7x?1X83^WLg-aoKl^d8KNAcol^N1IH$;_@@KiE@@Kg^ zF)U<?as!LWp@_MI#pD+<MtOi)3JV#dJW~{-yi$~+yi<9zd{UINnI<q5xuvM2sJ1Xf z`Q~w?s6kln3@Pd<8Z8Vd8mWHG%u)WS{>=<g0qzVbnkiZ>3@KV*(ZCe#6rC1^sG!uK zW`?NX=%5t+6x|fP7RIQM6sBMXO@o)9)T+sNOQ19_GdVvcH9jY^B(*3pr`S)E@s?n2 zYH@L5dTM-HQGRZGT4qk_OGX9;22G}0-0|^csYS(^`FZj2w**`=i%W7clUys3QwvHm z^Yb)WZ*dk^7ANQDrDdkyVvou!aLdd|y~UAMoRSK%<Q8X1YDGzWNo7ImEw;4GoRZWc zO~zZIo_WP3i8(o`DIoKTGLuTdX0hDj@J%gAOi3(Byd~)C8sg~U7~&Z3=IP_==jiKt zOFZ1e)zv2+Q$oVW)!orK5>rN#^A-=tJ^lr$MTsT(MYnj8^YhA5i%Q}P5=$~}aXJTw z1*ImYq!xjh;YFYTxy9<7n4FP%i$57erNkE$<rkzDl~ms1OHVC{2Mfk0B^IaN;wef^ zOo>meD9A4=DZa&ClA2qPl3Aq5bW6}LzbH2`C$lOwB@7aBx5Pv9ic1SXD&b<TMMe2V zw*(6+3o79OoSB!Fe~YQ0;1)|(Vp-xXrmV_a%*i>Kx0o^uZZRbn+!8=io0p%GUsA=Q zTC7_9l8J$V;TBUt<u69vTa59y81-(k2KzfYc~)^G7gUyH<mc%ogCZY>K{3nBz`)=P zDz1VU7#LC*OBm9bY8grx7ciwTEo3Z`sbN^aoWi`2kr5)svXHUJ04&A|7h_w<n8KdT zROA5`=KzVPa4uk}VOYo*%%I8TSEK}T6-Pj2yo;+-sQWF(lv}*vo*^Fb0g=9rK0f}= zw-|G8@ds4Khx&Os`@6Wt2YW`jzGMMuVl2JIpviiRE6g=0J~-6P%`>8i9V8Bk0&rT3 zFH0=C#g<r5keZirizO>RGf$K87HdIbQAzPih9YwY28Lg?&Q>v@#i>QbF{wEznME=F zd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW!LGip!6B|e3T80@0X{K_Cb~KK z>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g`tfC{c`5lt`YDi{p<kYnnwq0m zP<e|xJ|z`oU3_9vrVS{h1wi4?$ic`3g?x-$j763V3=CCOTpIQPHhH;r(Q&%5+L~Ot zAZ}TnT}+BLNJLAMO9L#Fge0VC4^dW7X%|zj9h0K15u*oTXlg-CNXi6BK{<&<APz(k zNJWfZc}9*3SCu(gcB^m|^D;0n#1v~OD@Mn~6vgDlY8A^eFfhbvfW<VFqT`fewUugO zg0(d@V~Vvk^t3cpia8h<7?c$uX|k9TiBtZIQ9l`!E<s@g!XP#XgVQJ|QPeO5GpuCv z14r#j##@Z}U>1b103{9%o1Dblq?AOvI0goW&mc33>=+mrFiZs*1~!$Cfq|ihVF5!4 zV-`~i<3dm&$>djL1uFKKZ?PAp7UU!*r`}@9FTTZGoLW!>ibIHXpwv|avJ-4U0s{j> zkv+&Jke$dFl*hnL0y72%hE#?q#uSDqrWD2$rWS@M<`m`>mKKI6mK4?$wibpc))bx; zjug%o#wfNFt`zPThA8$F_Fx80-dpUx`K5U!sYMtb0p)tIM?eWHlc9zoo&iiUrZ5CE z6j_7(!E}o^Gq<3$C^a6OEQ@ck<YXoluVlQ%Qk<HThUS}F9P#m)d6^~g@hPC>3JNC% zMmEMO0jLA?VA9DTkHI_&VuLW)B~qXuWvXGwVyI!XVW?rqVqCyf!vroG;BI0rash>y zD=5y`N()jFOHwtNi`+q64p6b2mzbM+iz~IFBsC9I>lCBAk~uLYB?I9=F2*Wum;)12 zQj$TT0&^RvO$K+H0my9(SquvpYZw<Y)-u&FxiG{^#W2+}*Rs?w*Dz!;l`#|vfan@# zTZTdbL?}XBe2cjtzn}=@Y)w|MbBnw{{_qAloH6?rV;Q<b*@{wg^UG3mKyC#kd<I4y zMjl2k#wtFTdm#$^P{I=w>>xjY!&3s}W=2qWLflr%oX3*FP|IAy42xk#h>KXjF1p2$ zR+^Io4nP)AP~KuIN-ZwUDM5D`cUop%N_=j9N@-4N5yE*~jBHFSj8(!g=OL*=309C3 zK|u?4ViwqmB@9`NWei1PAi9Q8lA)F<FQ5kGaHcZGBApWE6vi4xF@|QwCdLw$1*{Mm zkh+CTwM;b(HB9krHH-_`Q<zei7c$i{mvGcDH#4R%XR{Qg)i9^9NP<*w)_`&-t6!CT zX<lMdPO3slz5>XF3h<<&kd|Mhpjup{0g4xpBa1*Kh$h!9=HklYTkH`37J~!q7Pn_E zs5*w!!pxbu1yMXX`H3m<DV2GNxtYngxZ>kM{M4fO_*-m6#RWN;CAXM!Qu9FVA!zv@ zAFl}s_M$+Lg~1>Kl+!Un8)OhPv@1cOEdolPj9iR7Ok9jSj6#fTu!I2*c_ba0jDDIN zpsWds*7$gk!yq1skH5teA75CS2#)ah_#zLG1AIV40Eh?y5wRcwTwWmvaLEOVJ5Zyb z7}TrbVB}!oVBuinVlRS;gPaJ*pgaUF$ljq8WKqm1Oi?T;%u%c<CMj$w?4ZIcl^tA+ zF*Gwqaip?Cin3<LD9%*&6rL2`7LYhsDt8KB3O|_5lOm8J*uoISo64Oclp+ik<4X}q z5p7|J;!iOJwbEM{qXbeUQY2d#q6AZ<QlwiLqJ&apQe;~gqJ&e-Qsh$PTNtB6QWR1Y zTNt85Q<PGaTNt9mpsi@}6txuf7KSK^6pa+k7KSLv6s;8P7KSLP6!R3F6x|laDCrcv z6#W*4D47(46vGyVDA^Q?6r&X57RD&K6qaBHP0L%X;h-wL%7IHkK|#SeC$YE~l=PBH zGjmcD67y0NG9isw1yIvj0jyR5)POEl&<Jo1P%tqv*VF@R)nqCHCrS`;i>){#(a6-y z&n+3mg@rVzl>_2~VxicAk%6Ix2~@0uil=zS6vi5cc%~BObP&yw!UU#SQy_e{67~fg z3qh3tXANTtODRK9Pzq}eLp)asTMa`zcMU@pPYpvnZ{DL4z6Jc?0+6MKrD#?S%L0KE zP;tmw!<xb_3DVD1!<xb&$*@2$g)@a~A;^C28rBqUupFpphnO>~ggr}WfiTFV7^Ygb zTE-F)gt^5>N<>q5U^%{qt>_w9wO9??LXg`zLHR$P7q{JD7bEOsP2rVfSRkCj2iDC} z!<xd6#0R-t0Ey2AjyAz6Cvc#H;><HIvm`SyC$l(JAu$gUU3tl=3Z=!FdFcv?3L0gJ zIhiS%;79{yGDvKJG!_|x3U`*g{Jhj#%!zrGez#atN^^57tC$V+3~w>z<wh};<rS$j zFfbIUF)%PhF(u_y$#~|0%~JpwrI23)H`Yo)wWvrHq!v^@MKL91-eO8D(iFeNQk<Ed z7sXqgkzbmV0_qE7rd8hJ0H?3A)S_Fg0g+*@LAO{7DnUHv#H7qyEQv+Q8AXmD$FZfS zmL!*_++t73ECShhiv>)wL;GyEI6z4eEW`=!)`6M)p#D@mxCQL*7a!z$i#0c~Bst?2 zXL?b7X+cV6a!C;=yBC4_2Dextg&#Mp9~K|vTEqsjnmsY87*xw>vV$w1B2Z0I1ge>D zv6ZD3Wu{dY>4KE8fO<7W`5=#@l|i5aYa*yX1T_d4SlAdrkb@BfxfnUXJT4|KMix+e znMnvt3NV8BER0P5K~)tWBO6E*j0G447_0ce*$>fB0hRx-yajSID1U+T7O0H~s#c4H zK)EW5L7btMF^?sMsg^N?c>%cI0yPn!Z03cGwaid9%R<IlmKugE)&*=Sj43P&nQB=< z`7DdQ22`st)iBqvq_K%H1T$!|Re8ZvpcA~XC`v6UEy`0!geMC~u~Cwds!*0#l$l>z ztdN|aTacfZnpaYcloCPd3!EGwwHqkSRf(t;>w@}!x?oyYwHVZ-*W@V51ckLJh{y&J zpaw`$E{IhKBET_Q0BRkwLE;Up9GgnC=mN#>E>LuV>n~O|Mjj>>aLvWT1nSDL{f7lV zEXkp?SV3(Xc+n=uz`y`%Dl7mMD4@0%C?FZZBCMby1=hM@11EBDIxGTv2%L;S4!Oma zSq!pAlL_JpP*O#&c-c}bGK))!PlMbHvYLTOh_Q+Xl0+a<C@usk0VNV}wP*rr)-Yr- zxG=<O)PfQOqYFc<45+b^1!^}6)H2sF)-csDr!j{yFftTM6$%uxA-5P&!xPp}Kov!I zFH1>cdhrF2Yr)M$CP+uIiVNamkR*zG`571(K(#kGL7OmQ3sG?5X02h!VoPHZW2j|H zVX6Vq%q8p#I6&R|T9y)Ub<xb!|Dcw&hG79$4eLV2TDBUt6jn)w1>B%oeIZjVdkLg- z!cfER!qCjv%vj4&!dt?Z&Q!~p!cfaq!|B2hTUE<ll~lsN0F(u|7c$lI)UYlPsNq@2 z*l$tGTf<Vr+ss(YS0Y%$m%`P{Sj$zzRdgtvA%%g3frX)&nUNtJ6pBBPMe+m;8H%qN zFff8)Bm+oIVGRpIiBRPim{?(r0YhO;4c7$5Vu2Fj6z&wB1xz)Z3mG9zO%&6F3>hXc z7ONqfSHlJBVEO%G1?Qh%JgUWdpkBN#sKENgT3V8(YjKOQ=oc?I{B@yYIgtDZN-HRl z0ZZPXR$wtGgQPRmFvRlIGL|sZFg7zzWGZ9{hKx(BWW2?knOCxs=@yfo!7av2^i;rQ zlapCo0xAUT9)R*IsB2lJ1a^a7E_8TI&n727IWec$P7k42lkpZiC`aTcWmQ?gDj{&U zPe&msH94`gI8_0rUm>$tAvd!aQ~_Ek<mBgPr-GU>3aZ6bOgajhA~<th5vbfK0u>{- z*g(U3$;G!g(^E@8BVnmUMW9rBO9(Vf2DUaHW?NA?s2*S~DJ{rJEdr(5B2bU@7H2_z zab^Xm2D!zOUyzzt1R7De#o?V=32Bvcg(c>crh?g;{E%D@>T%uT0M%ijdh!+rD5m05 zGK+4pmluJ?f{Jc2Ri)kHL$&@EQ+e4f9#GJLG=ch*x0uuNii<!|b&Dx24>b4*8FfU| zkW5Kwx0uQ?d&n>^T?ge-BT&`CB*Z8H9@GJK?F1Nw*f<zj7&#c3z$GJSu!n`wgpmha zov|=-{8wXwm69-{P`Xy2AOvA>o(2`%;2aF@Nu%XprUlG3pdmV@T9z8d1uQiz3mN;> zYFSG_6%)%s#v0aU##*)#_8PWk##(lioB+yKQONnAgrkPN88m3e>Q__`N^%Y0_yP~N z7Bzxu3Qk1C7xjZwfD7XZAXYbs=m8O+UcxOFQ0qaH0}@@+K*Ezj#1s%Q2Sm&T5%WM6 zutUe3(K0|$F9QR^cTo6(251<-p$qCb^D(M1R!Kne0cILQ$&8@f2@ge3ngQ1=sC5l% z4Py#pGgH45s7znL1{$TPWyT068{}{T^}02g{EC`DLBftZlYp!S`vO+%gPc$V4h&G5 zL-%hrC>b#_Fn~wLKy?%kqXr|a)CZ+-loZ0vz`y|VA2@|v0oS955sjjn8m0wI3qd0U zj42E?%%FLY8payt6b2BBiJ_LImNkX3hGhZsLWVMiBBv6TTDClv64qL_61D}5pfm&; z7b!{u)e{TY7c!(UOM;q4?0GCHEVb-4Y&GoS47DsZEH$j)22)54;{uKpP>sO>X0a_~ ztmUlXNMX-rC|*#*QNx+dQnW0Et(GfKu7<IOqlP1eLmcdq6wYj>q5~<MwOn~DDXg_z zC9E}E;tVy6AX95VDUr*s7}QpSj1-oC2DRf9UjG08|37%74b0~SlU(3Fevt|&y@1MK zUM@|}TU@~&u1=1A?x3b>DJZEigGPy2bMnhmi*E75Bm*KtJpBE_Z}FiD+!BQGU0g#P zJ$*p!V>WQZxcC+eXuv^}8=Sgtv4AEjz-`>36(CF4i!)M_67$ldgg_GUiD@ONMe#5( zJ}4s|;w4ZMKD{`KDY@ttQ%+hGOG#=`E?T;{#a~dApPX7;3^Rirlty&Gi3QXM=3ta! z;sKA?fOtYopi&3aT;^gFU}R$w0n6|(R*6D#44PReLr$Qv98j7CC#f`0!-pw_p_HMB z57a`gWvb#UVJu;)VQOXqWsp2M7KRe$N-IbeT*8vV2x?M*Ms^|@@|X-5YM4Rw-2&Ey z47DsJYzx>yiE04{XjWkXC#1<y!&JkP1{%v@@vD+Unix^YNG#4!NX$vkFUl;*$OZM6 zz)@^_i#4%0IWtp}>lP<SNqlx@Udk=@^wg5Xl9HlZ>>#n6%%od<jwL1Fxg<!P0qLZ$ zrDUe37MI*&1I^i(ncNaAEy^iQOiPVVGBZid1Jz-m;hmDA%z|5NkSQzJ=-zrzLA4DO zv1}k4Qj5S926`lMfQllJyecSmgut-_>bfv7@`1;8co@at-4d8mj4nSs@IixVkOo67 zBPh_bm=~~sTA2%(nnB$T#s#c3EGdjBjA_iEG1U^b8m4B(ewA9*8c^$$ua>Qbbpbo5 zlg-FbXn|3d#UPhuptdTgECcm$H90`z!o?-GI7;&4!Id(iYy%C1=YZ<yB2bIC2-LE< z#ZeBPDa$X1_WVF<lJkpFif?fjrGglc=`|Kmkl$h~xWxuhe~Y;&zZ^aMc))V;5Pb%q zFyw)TA*fyjbpxw}ASoDGAxa2>stHcmbk-pT28MJ{8O0dGR0}HC7)n5`cTnPGuVHp! zh)s!Ms^zHVEMczU1egC3ptk4&mW2$p+!!I|gA!s)H4F<_Yq&wJ%UYfiwk-Aq9H6!) zsCB!5vxcLFr-m02FNHE-S<pZVXgHIzhG7AB4NDDY4bwtqMurlIUalH8&|oL1EnUM5 z*3X#+A1T*l@w>%TlvKs4T5PLYe2Xo})!9GDMU%H^J19}^01=>+Sp=$qZ?S-yUquH% zf}kM*aBm5mJ&H4{QX$a>uC77-pdwKCX!3yzup&^!bBiq}GYQm!;suQ<WR|6Z<F2^q zC@A4`fSSXg8mI_dfA0s0F(nohod7Wy(~7`Z1k@!2jbT)!qQ@;Sa+HCGvx-3z1PtH? z5~xb&VN`=;6DB@JK1LzNDq+m1E=DP;K>ag#ZixcdexQ0BG=<a5+;36K3?9{2ieUoP zbS2CSSW=j3SZi27;a<bMfECPUVq_>3ArRM~4m`8pEynUH@$jPjl2ip%@SvY+u|j5^ z0=Rjp$p&ffvR7pmfZCR~c%nQ5;$2+bd>lhuU2d`E<fo^DMsHG5lS<QXv4Vp_lMNE^ z;P${pP=tXS1(!iAP?(|zASZYbD84GQzyp*sKpqFRhj<wI7_0apK?PTVk|jV>ub_qk zs7Y3QjTtnKn8H}fP{fnTP|H-pP{P>Gkj4laZExX7VQFS+W(0NjKoxrmTQ+D30(&iM z2~#?#0m+=sSj%3*lFnGmktdeI0cv1^#8Wsy;wfAp@fxNDY$@C|Y~Zm%b})~ph8@h~ z0P}cjIKVv44u%>QNrqa^6j05=Rl|_Q4Q|wOrSR8qi80i2rwD*)o^*y<-V{L>h6#+Z zT(x{Pd>ssBj77%^w{<Yo@JTY%@|W;r@h;%2;a|vDw5^0^0Y8Z4!Vr5WhPhUtR<Ks6 zM#zOB_DrpCi2zuoV2wbHFt`X60rQ1wL~8gKGS!Nf2!r{8HQY6PHKGfdn;C1xYIqlj z)QHuHKr&+uUy4vRQ_-gykp-eD!V4LTKb45ph@^-#GxbZ<ir0uQ5MRhpD-q6+!U*fg z=0Q4|CCEib4Z{M78i|FBwGv?6qTpsHNVg<N6x6Xr=r8;P?x=1-)?fIk@JZpe8qQk& z6vkRfBp+{q`&gg`v^<8X$f`uDMz9%F9azLL)k@V$mk88IH#62s*GMlAO%VexX!!*7 zwLp#ZLZ({D8o?SVTLwmk2~34L6Br9W)kscYDz@@sND&9s>fo^S0EK0Za5Liq(G-b= zj1!oO!X_{k+QH2cUdU7{0u4=Q=r%Lfih{#Z6c&~s9TOM}ua)pDkgkzj$Ow%mr&{3} z;S|X-kg2oaF(wI*F<2b&Kt<4EXaZB=tQ4sl<_Sy%uWA^wWW*R!q)TMQ7*b?vSj8C9 znQLWg7_#JC7-AJ-m}_Ng<!a??WEO~|$kxc#$koWFF^e&Ps?rI}g-lT2NT$eveFKVT z`DUhm1#mn|rYI~BtdUvB2vUs^-^|4+$ngaY3Bej3kXe|iDn&6xsfD3dp+vrhw?-jF zxtFPyw}xSXLXBh%Pa0DVXALi?z=FDmAxp7_Axmi?Q>|hR!vf_R#Twp)OpFXQiopz; zDpj56V~mi}2{Nh(Dwn_|R&haUa%Ng)YKj7=DlgUn&s%^71QPQq6%dl3Attza<r%4Y z3Mr|emT6`lXrvr8MhWVAE99psfY{(-5HUpQhtdTDwb()JabZxy98_@CFmy1K!6tzr z1s!NceI<C+Mo9*Anio7b1)8=GV}#DCSIHt3bjaf#kjZ{crd#Zw32smWki8%$5wto9 z(j|BZs-#%c5_5`EZ?TjVm8KSf2KI_TbK6B|<8Yu(?=N=H@K0h%ViBnKtH}(m+-|XF zfY%2V-(oLLF3Kz@DK2^jT3W)Qms*ipbOvMtQ+d)aF2uM|l?H;Xkdj%Hnp~1!RH=|! zQIMKklA5BUke6Sgkd|MXm!ip3#iCbGnG7cLHCc+zf{f$z^a~Dg^zm^Gied})a13&F zDOvzpA|e6~1=t{zm4a%Do@z>!sC#N2WNDL?0;sOe$xH$b;s^)j=a=Yu7V8F-7NzE7 zCRu?5c|#J@K@7-fG1$~1&@jd=MlO_?1JxNI4C<;DYk_(L3@M-)UB(*51q`5ed@WN7 za}8*=SE+_6g~gl!)Mcz;1h?o}{UBj)1**|N3(hhH)EO8+D|3=Tix@PSZ!wk>fvUS( zjCqhW03Kro#riF_;{2kL)S^wGnhrFq$p9Wz0Zj%}NrOGF2d?W7NdTf=lkpaFc50=j zO3^`(rJ!2x7MrJU0BFvH+0n`K7K>w$vqurAWqpeoG**Qc_wW%dq&6>WW-+Kq#8RG^ zlU)RAT0#b&4}&ZKHK4$as#_eXc`3!^nI#$EW?0cVknCm<aR(fcsd=TjptwoB#SR+K z0~yE*&N8r3s3K6mtEdj77~=PoqH7@S`5*!`#$9w5G|->~X*1jhiGmat{Q^xjftqdE zsg<|bGmGOv=|74$B{eOvG^ZpUJWmwG4dW&zWk&J9IiPtX&<Jx8XjJAF2e_k}l34_4 z-+@~sA3*kiM$>Px6y@iafChAmif^%ki;|+*AW2Y5<rY&>0XQOyKtmAVyi#-tB-sJ- z4pT~A(R2_GEv(;z#K4UoaJ1h8alvuV3XWPoP}I)?HUC*T7+IL47(qj6;5i{C7VvBk z8@Qdw$Hc(|8gk=cVqpe#5SSP_7<m{)7&#b)82K1Qz%5D85DI8=-GGIKk%du&k&79m z1JrN=%@{#UU;(QX1DnCcC<KDcpcy5$zbvc*j1u6MsR77LHV!r(79l1fMjpm0Zlt7$ zGA;uu>_FKD+=&LIUvPF|1TThTs>*>Et1i$IH5F7)mt>?Cf#xKkZEuCtypp0yg<|kb zph8lrLUDFxK|yK?NNJt|WKu0NFCA`Hei39gGbblAFC9@5YchdXF;#KvL;4MRS>?r= zj76X^HRyE7E%wBsWKda-o(Z`?HpYXUaR?L}OrY4{s}g|t8X<|&C<l2N<YUlMnBp)F zP-`;_)CFT+zzCgN2C*P(JJ@PKY!*=0r<T2h3EaVD$O2DMEM%(XfX<~cWO0C7hMXyE zHJoA$wOlFeV4AxGw8D_PgbOsm0AZ(aEM%(Xg|aypGS%{xa4+CV;abR8%U{A<!vS7g z%-+AIR-i^;0bdR8LdJfDTEQBAP%EicsD!^psF|@=IGiDc2i}4M4Uir~uFq?P!86bT zpk)i-wt*mI*+Pv7bUH+|Mzn?@ODLOp0%MUt4J(8MiPVTTgX(JG6d_556k+fJW{n!g z6cI^=TCqHi8pae+5G#|RRvhd)zJ-ka5w#K}!Zi{pV!e$0I<=BDk}eFfVzp8=QYqq+ z47JiVQZ?c=(l!he7z+bXTn%Y=)*-tai~Kxfd2pz4rARDfs+9q=xxs8%Fq<nyGDTt` zbFEy7NDWJhR4-$#e2R39e7tChSe7^sL#;wOL#<+o!~)5M47Ex%N;ORJQYkz&O!3ka z*s4?}uvWdQ5m+Fzkimsv0&^@^t#XZW7F(@KiENEZiCi;ip|ehnO08-hSB=U7d2np0 zf?GhU;MS$v1g1j18u1!cNd~abWh5CUFcnplDAp)vDK#_JNTtX~GGsG@#gtQIYg8c< zJ~dLHl>rl&iatPC3j|W+Qur4##W2;X)vAL-SY;t&zeKG>jl=?#g$%VC7$L+|d;mFw zY8V!%)@anIfz8mY)vD2|Q3u=mp+q@FzD5OVFWUs>BC#6P1!^_2H8P-{1BhRuzCa^I zp+*(dS_AtBBrms+aRPI`PL1jU%@oCjj64jr+F*S$An~G<8r1~?DM~3a3z=e=Yc*?i zYIUJ`gt10PlA%PaMz@)9Aychho=S~s4Q~x!8dDj=1m>bLkoi!RVkKHNst{E*+7noc z`{4eTsg<aaU!YwhQKJWP6NcZJi}#@TU2%a<jUK4ITf;JerPvA*rW06-tV;N5^iq_Y znfmPzA&C}J`ZfABTG`AKSc;@dlv7k{^dKRHVJAzm0g9ap6IhERYV;OprhrlcYmr2i zOpSb&ZjD|Idx}~wQ>{S_$W;a)SA{d=DX}n==uKd$?1GL)s%Pn^sHaG$X!J5MGC;;7 z^SZ#{Vo;)0qtXmo>0$`xv(zZn7%pV0HNp})Mp#3KrT7-IOTnfHfWjw+sn)pGu*Mja z_G_3H7}gjrWUMu*kzZg`V*+w#jp71h2n!TTHEa`Di%h_2LlY#M!c%KHfhliJ3Qw(B z4MUa*sHCYCtr1Pp%4V9tR-^~ci`*&N3z=%otG0k$YYtAsf+eQlG7L1(hbX&1r2uPj z3$jZy8EVZ^bX*u>i)t-XbZacd7;3F*tZFRE7$&e5P0M6pVW=@n(F2LwFw|PtSkzca zGAu9y<=j}CTALL88k;Qh8k;N&aEWYNW0Pe$fwkyIjV)-w)B+X|A2cLp&QNPxV_Rcg zW0S>h!!Uuh@Wcex!fD|Q;PGO;32c>GusB+vpJD{^IW&GMsv^L?f=m@7N@lAC)-^&4 z85c077%yb3HLEe3z*dw}W43@X#RSC1NJ(tPRmi?ZvUv%T&87&OYs@CF7Zrd_G|OaI z$W&_wW}AcA_BD1B*orUI*n`!8TmdQ#nQ9%t@orP&u#j;ATk)q7+Y}3MFWCVc`*xts zB`yrHS}{zuR<$-MmNiy2HsEk`1g8u~)RZxSy^sN7LyA?3bS7i1Q;j{;1RY!^)Hp3< zLQY*1*bAM&Zepnss{u{COPAP#d;F#)4xo|vT1HTPW6J=lYit>6#A+B*tZf)-OcyxT zfF^vHKqCVa*o*do^OZCxbZSf&IMpcDFs9f@GC+sUOv4$%8A_ZNxYQ_tRD?4yA=Q_` z4B%YIQ7HxwXV(;4kh&WA1#Sx&7#W(Nc@f!+JRXF31`HUn$x-Zq9GfXT!3>&qiFM2j z4Di+ubQ6g}BB*(kngd#t2kMq0y0hTEuAYKtnnHGYVo|z6LPB|BQC@0MLV`kOG29rq zdL4z#5~Q|QqC#?FP7Y|Lsg6Q<MrLw`LV0FR4yaWI5(hQPGD|WPO3L%$CV?loLH+HN z%;dxpSeF^x<_9(2Kr_#fzH?@=LUDdtNqJ%sXhm8IqBjjU3c7p?G};LA6R7pAqmT*i zcNe9CX73Y0{k`O()Plsk<Vu(_s4k>+Lm?TN#R|!Zc_3$(7N@3w0x7e&xD;e>r2;58 zGV{{GLz_j3ko9q(zAAKc50W`ZVVIMd6rZ1$Qwa`5g^;4sR2>BnAM6WIS0pDhNgvu1 z2d{D}R!A&Lh5HP;S`yS11}&Zh`3~C0)=_}=v2_$c{SxpP1*lUCUXOuTx`1pLs51>3 zSuIJ;Ly704$`bJQqxg)(;*8Xk_)N%}yhPA8BV>0&^}-zo(+7!aP+PntUjZ~u0*U}# zkYNg-Ne$3q3GgC6uz}!pp1P){Mw$xwd2plP`+XELL96!*ia_mtSTZP9&~Od_@61s! z(lgiA)Z>Ed3&}`TD1s~!D+8^6fJC-cGHBhYRRT24qi&o^fb;^uYZ~)%Qi~C3J0T$- zyiKcE4_mB(hq6HlJ2|m96&!u&7AGY5<>#d)Bp~`0x7a|5Cbj4m2h2pbC>dC=VGC}^ zih?Jgt{!M$1v2gc8tMSAECA1?`xP~Vq(RFf!7F4@h9f{d5YT)#csK$y{gjStVNFpB z$don^0q$Oc2~hX4sFQ(#;Rk#`NfFYSfhI)6cmiT6O%*@d07?;PyJr!2ISy!8X(i(= zwqnq#mt4qj2WS!vJTL@WgOgHJ8DCVI7g7Y8ll~<FnuGzZwE?fNgsxEk#c2CW3^Fl^ zE>$H83s);h?+;Xrs1_GJ2YCxTtO6Q!s**?7ou8)wO3bNH8>*P~3Mw@jZwZ6aELsMr z5_hUBN!10dFv`q<q~Nr~%$(E|O~zXssTIlbpc$Vk34}W!sRHB>P->`RHq<ky5&-uR z;|uaLLF*JtDoQ{Damo34#rZj@x0usQGpo2%i{qggx(d8JCtkG}G@)e$q7<T4i(`K= z>Qp&~!WZ*{rm+-qQqvQYE1@L;Jk#qa6z7AAF;IR_hYWe8Le&%(fx4Yl{E&Hdz2yAd z+{C<;;wlR?gS~?N{fIIziU+ioC?4vUC=M_W<RSSm&^lqLwcvqN@L(Ri{-|PCEmp7v zZ9ouYWMH_(3>uPTD=11$%dDspfu=U(;MUW0FX95F$}ga}g-_i<#+vd$V&Fj_!~hj| z<qc@*R1sp)4QOZ;GX4Y_d;qVsD(VC21&tCFfkt181VKYGY>*k&qEHY=I3+)?Bp#ez z;$eCB76)htBdDCa#h#m;0^;1_D$Xx0N=^l@u;MC7ECNkngT}GI>#jh9TDQ0|i@`q2 zOHM5U4FMGG1KG_A_J46n(JfApf$^X`0G^JA43dGSDsOQWmw-0wm4n95Zh<u21`(h! ziXzY~`YrC{{DR7OXf6ZIJ>TL1IW-=VY*TM>!uO!wVh0sTnR)5AI6#FnXjtPGOKxIz z>Mh~o)ROqriqz!N5>P!3+JljLiw(SAB&7&6`&k6qU~`KNT+kL5iGZBVR$Q8vmRWI& zH7zGGz4#VOR&jpbEf&y*jH0g~7fu2NAZunxYHo26XsWtsA!s;G3=){d8Hq)yDe<7i zd7!GMI7$>E4h|#Gepm1cvtrQd|I(7ooLg)~xg|xZskb;&VH;|1aTMj}<Rm2~XKOkm z2L3<`w6jx-Zn1$IGR2T&!v;z_phY23VoAwZi(c?h+hmZd|AGk6B<?L<*t)ZLa6k!z zn<w$8g0N|Pkcy(IAg!Qz%3I7y<!MErrCUXdKw>jM#7qzY9#I6%7#D$7cY$^tfi~3^ zodU^$Mhl}L1C0e~6;a@%6Axl>K?(;D8@x3*HNPN=DJeOMBfqo+lxm7^v6tr;WrNZi zYZa(SDq;b}4`*pSbnNOD3wR+2D>(KbLy(|l(M6yM=_t-jSm|?%wLBxWD7A<Yq?;XT zcob(|YB{6~jbbjSOa_l^Msa{F1bdnZq!^rdLEPe7ETD$SEe=@ea*HXoAc`#&w0SMD z2s~oy2lA^ni0}s`5XRzL{Lm5vRtVnWPA|=baiU<p2YHVT5)!xAp_MiIpd33i`CI~x z$VGr=Rs=z#m^_R;(8Y%wOyJpcCN3t>q7x2AHAVr@XeJ|gVKx&76J(h-XeiwWtdfrf zwABkVe#!w}b<e>F8utV(CIXF_f)*0VF+$eZb1{lAg2qxI>+YHUvoVV?@-TwT<ND9U z4BEUT!OX|V0^P)<!^p)X0AB0}R?o!rPmNiKk%^HFyk4J=k&hX~;$s#7kFDx32|(BH z^D%+^!@&+&>CXdRJgEU*B>-AL30m0?8od=^6a$UevVfLWa)1^&G3qh$F$yq2woidV zfRB-biH#BD0xm|7nIKhQaV9=S4rb7@95(P+F&iTnGY=!ve-<V-Hm+YF*MP>6xtOXT zOMUgA;f>J_0Ts5O!Omh(tD=M<1++-Y1hn>G0domUGeZe$3S%>43KMAc2k2A>(3(3j zhK0<vj3pePu2>>N320pbi(eIYN@Y%Fk}h~RIjBz5Q!NHJ7c@C<v4RB=lM#^WKpd2^ zWI-7oT!8aHTl(Otx=0i>O#od7e;lL`-0}evAcx)(hzA$kAS)po*mp27FcgCdF9z^X zy1;)HCJx3bF-W@zT`@{1fUE*dh=4<33aM+(nP4kcOE?yArhv9mu%<KAvXyYvFs87A z&VcCGt7V_SSjASu4q7p@kg@++Ek_M&4M#I$EoTYO0$%WX8?G9L1$?0OIyKzTEk`^h zke#O7S)di?py6N;Ul26dTfC-(VSx~c#mG>@wLlm=tkD$1RLfV(57ot6B2vQ-9xxLC zi-^_;EMzQxkiu3gm}gePus{sN&l0Z{Dv`*NSRe@+l&BS|VP7BxT6Rz?3=*vo&XVq9 zs1>OZsS(O%sTHgdoWNM5QNzAKriLFnUCXvWwuY}p05mwr$WXWiW&H_g(1x+t54pn| z&X6a<!cZbNfw3|V(yfLJmtfJ?hODoKEto-*9cdkJ6qjp6h^t?)r@vn?qRAbiDUY7S zaJD$GH8!+CNl^zx_<~AGUPv=1z9b*iRwx1|LQrjaivv^-r(_lt7wLi&gKGAoT2KMW zQe2W)a*Lz5BtEw!GdC4H6_pBR@q+fzfmp>QiMa*fg-oE*{}yLTVo7Q|Na7ZIYDGy= zVsZ(19<B(qg-BBrQduHuJWyo^t}!4L7^wRIS%M3yq9C;xsNq=T4RRN#=8xh6=REM? z4v^)}p!vRAEGenQB}Jg==qPY~0CoYm@esuYsXIYVLNBuU!MO<B(g1b)iw}Zw9B5vf zff2N>4K!f|TD1u(Izem0!Nm`>-~tuhprRO5aDj?rP_f0sXu=3y{|sHtiDo)V76sK0 zpiUDwi-Jn55{4RvX3(Nq#wuTUH`4{w9nH<mO9hQ8z(!C&V+HxS1&Jk@p#8O=rWvGH zSegf308m_6T#}lL=nHBx-r~(H2Diu{T8i8-OP``hMh1q*An$`5#lQkv<AtIT!vi2s zfIR@}`lWyz&r}sa(D8}I#i>OlsVNGH#R|FkrFr01pF&clLS{)ZyzP&0e+VSjusHe_ zPiApE+yv118pTl8Ll+|=OQTE!vNA9*fEKBN9lr&<Kn=7B9$c`1H#&j#jxA&Y?Jlcf zSirWBq1Xtrg0_~qgdMc&xrwoc0ko5|*bB4>TZ{oooT-E}3pDSZRKm4@JB7K12{cZf z=U2m6R05J&zyn&u&d89*2j=mnus~Emi%XUomZA+M{3V=O0%eRvOF;Ajo)Ui0I9&<< z0zuHKT#$L-g`uo|Rhr=10JQE6)ae4Xx*>6_08JK|#R`xS481B9xKhxzlEfm=Zj!`e zaOVgfhI&;(s>KS4IiOA+c)SWUI0x=MYYHKiM3tZfWC|h>#Sth0L3$5Spu7sI0E-Yk z25{GaEi(@k^F^S>(Jj{ajQsrUTb!UaEqFC!5ol91Y*{ZzJ$UE-E#}<fba3Ypk_-^_ zB`es~??Gu6w2+R05i}DGYCS<PsBOW*$OmduFoIevh*@E<K9sZ!N;UB00P4<x69N;M zL`@EiHH;-}S&U_jMMmJ=S)fx2m>3!IY(Sz5I6=GO7#V69OSrPQ%NUA+O1NNRAd%v{ z60Q=qES@rkqC612fU|@P6tUpQWb&)xQ-wrFW*)fTs>w?r$kD<Wyq`P<6!@T>nnkgU zpp$`+3S4l|feCPXgS|8l91<+d3=GAfA|Dijpil#Ck>LWj`Cu(As7jPDlVL#G*H*+t z%Dy&GrVs-yJZE3PRKrpNni^&;0kgqdH9?!CnQB;4SiyVRI2UlGfOaf!lyKKDrm%zC zA0KKtYd9D1fYwm=E7Wq;aMW-$GuCpK@YZlQGuHB;)V`o;VwCCB8XoY*X+Frt=~~_r ze$bAz7KR#L=rl23CPOVh*nIYdjQwG?0wn@90x7(`jQv`mHiHX8tO#gPTncEBqi~H- z4S$WW4MX886k8!}1u^70AB(&hvV0Ba0zpu_X98m^6R3@n#ZoI;B2*(<A`J3#QCf{? ztymscjpzaqaCnH-h%Mkt;a|vDE1V)wBV5KXfw5>piD-&ojTmGSuLjg6f-EImFoChq zqlUjmOp*cYav@2O>Psc!H6mFO&5SidpowqrwD_eG(G+302|_7cV3i&<VAcY@6cNy7 z^BAUD@mdLR2#JCxxj>Wlpb2J43_mgzOQHCYVS!YQWQ{m@qE-qtsZk>Vw%4OXG)1&V z6ykD_Yq6M=f@~5v&xk==P<Y2J=`n1n$P8Nt2RT|m53&jb+o)v`2PlVvYEJO-k6%oB zdcUNgBj3=KCEyX?)YKf%-U@Jsqlg=%hX+LPf^xMqQo(>$43jwy1s;Nu23a5jA`pW_ zpklEIG*VOq?$^kHWWj5wK*K|tGDyV>>Ig;=Xsc_HDM+~)h=7kz6q$p#*v2Q0f+`en zyAO1x0%BaE$Qq;rG^|i$17g{N2s;n~UfB*GO+c$4imDhG7z99tTMTG<475duwG++^ z>MDa;cpQvgOz=)N3utFAxP#3M>P&Mm;_7b0b}K_79c9rCXeB+UCkAT77PEoQ9ApF? zEL6(^IasKc6<o(4?|EYbFRlSEwE<5_vZt`su!}L&a)3)njuiHVOtqXP9L)?982cC1 za+Pq_u%&P`GxfLCa%VEs^3-rI-~yE*u^F|zHN06YpoKOyd?h^1OhrvKe6{>}Ts3?P zcvCn*3vX)pYd|}^rWIzSaMkdaF%+#T;Y;DJ;fLhH8c@HDw}uPU+<>~0t3&|S2dfdN z;i=)bVJOT%nG^(-w$G6BX$?yaPYp*iXmN*NtxyeP4Nn?lCPNML62?A8(30W_j75)- z)QHpy)QEsi8LSbh5d<&9v8iFL5vdUXFVJC1;VA``TxlhOSwbniDSS0tDg3?6F-*0h zwPGa<3xsP#LG@{#7TCQapoZ22#^Qz&z7zr2_9w6m6X?K>EYNOtu@cc5o&{nH8JZbu z#i4RspoQ?DB@;CqX`qGI3=70-Bx|^8#6in_!HdMjKqVL>Lk-M5k4hvLNY#K2&R_yB z6GxrsXDt4K5+cIE44Q(86OkuLLqTIykjb6o{Jav-sRE!mNO+4MbQA%2L_ITEp**ot zPXRRll$)OdS}j}zoehPzyOUBC5VNAtNzqjB%GP29(1c_%XwWmUs8S)ZD7`c{HLt`9 z-15#&twfyzgf4f}1<xUXTO`mW$)I*RcsLKNULi55I6tSfBo#7^2=0AARKr~a9@+zU zQsBM=%_t`47Zs%z7v$%qfMzYA)`82w%vAV%D0mev*u!w+;2zH`R!A#K1)njLoROH9 zjv0a=Yrw;l3g9^q@YJe~LSjk^+_1dVa=4YCsZPjgPcR|SrtGx*qEzT)A7}xe0(iDI zH?<@qKLtDk2{#Jb-vxU#HLoPIC{+ROU*y%;py}O21<=@iei0}hU<1)Q;JIwLaUi$D zyb4(hUIJR|4Vvf#Nfm(lQ7H-<AV(ME7Z+zH<y0y_PU=e0gd38Q36JiQeCXs;q5{a% z;BGN^J~kl%)O!Yv2|#9D;d3QAV6Wt*mcxw$Yf{K82Afopng>!)l&YYstB?;`C0U+X zoC?vDUzC}inU|OYo%PQwR>&_)Edq_RgJywICsJXageGKYSc506LH*v$5}3C@wm}Tk zQAo`xPE~LNts6(`DuU+Gp)pego}DcQYbj351s&XxQwm8SaQmQY5C&j$5<$~7ph1aZ z&?zXOa}a8oYQe{3l`w!yXV5NN(6$$q6eiF?I-t!tHK0Aa4mFTXG|VNSeZ9=Rj9H)~ zw3up`!3(fi{6NEr`l`iM+^WU;0p9Mqo_=orD;dF?!Zew|8}GsU?2AB~_%&H?fsb5^ z&rK|VECB|Ig4IGswZUzAFad7ZbA!eap+k?6p!yFq83kIW4XNQk-6I~xD(L(wB*7pW zDoA=!0s}Ne0m9(G04)hlVW?%Qs)3AJ)H2sFKv$8n)Uc#5Wiu3Mr7+hpfDW_B3rS%~ zVQpam1xN~;I0Iyp^8%(6_Jxd~26rv!WFQV!21$k#Hgg7M1{;PH&Kiakh8h;oz-$Wp z0%pkZR5h$1)e9NH!OjF-H^fpo4>Ifq-cZj|!vLzRAVY99Ohva!*lQR;4fk5M8m1by zc+mD|aF+|TNji(WhOve{g%7j_4Xm3Vbix^^hzB<<1^mE=1%dm%pz}Mm4N-bOpdKS= z&;uMCgy*|8nTpy$ts7TRs|6fWU;-3f;A!t{c>B=;+)LL(j}{0Ywk91BU5MFm@SHs4 z*o!5gtq82D#oDUH7>))d=wi@r4>9nbfmlA+*%x7;qdk~Feuo@N$OvihVVS7E#c2bo ziz*6=?DF95HYd^DFcYc_oD=gvV;2w~D&&EVLCw!C$jMC1D}k)pFflREge}Pcoz4XE zlO_{5{oi8C0nbEN$wJTlfR_}Y;YkJ6B2ZDQTBONS1Zs#CtpmjY=$H%0aJ@8$ix{H- z9c%&4aNsrAkW2{LB%sLw5d|-|XNR~mr3f^ER0LW_Uj#Z$E{Z8Pr6?UUc5m@P)Wc#9 z)Hp2G1Gh(67(q+o!DEU{3gA&iq5oW<z2b~a|GAhzLl&Uv7Cz7^75|}wHw2OeWDy5= z{RVjH2IvF?$Y63J$Yn{43=Do%ETH3usvvtDbRmw@)nqQx1gQWGu-;-$$t<c8_RB8; zHx{5<V?bRIP2#&9lAw?U6&FP~`xKzDTJRilkvM2<nmsogG;CRLi#0hXzc>{#iwoW> z0v?hEZ@IV&GF1<xngcZL464^PrNBLqTO6=5{T2tTE-Nwyc_|e{WP%8^L1%EU#0n$< znl&v-0kP0J8lVV|5`fiYuqXtdBnG!I<raT(X;D#XUI|S87E@ZvE%v<Ba`4z0c((?4 z&jolU8=URI1UT<|GB7ZBfQo2v7e$bRi$feS@C@p7@PNl**qA`c1e9FB-4Q0xjGhKF zA82Nd2{g9`I#7U(k%^J%9~U!dHjxLMoIptjG}Fk%r~^Mx2@>I&%zkcepd$;J{QNW- z!7TYA&|zCe@t`0Eot1ivJw84qKRG@gypg2{ypI`F2j1d<9kmQONenbi0Nx!_1S(L9 z=7aQujs^jby%&Ku+JJhBMc{4Ch*)F>1vj``=>=kerYFF|g5YuJBJc=eJV+t|M1VSS zMWCQU>fs^6Fp+_Q0km|e*nxq8frF6+w3md5OOuI_OMr=yi-n1ii;anqOP+%h#Nv?S z;^yGs5a3|rD&Y{|sAov$;N(!^VB=up66N6GuqXnV2HJrJ%A#NlT9*Op!GVX0E5PGi z>5R1uCD83wkp2HDOp**KOcD$!%qh&xp#AIMGpH7@q=1jngq#47&IH+(Sg4W?9xetA zAA=X6GJ|$O*Rs~IEZ_v4(oy7B13FKD1vKsj>g|Ed2K8zRLE_w?g_@vqp0b&XrqwVn z;7wsH;Q>{8AU!GI<DJ2Cb$p<Wza>mr{Gc;DCNLKDl?W^lOyMfw18v`^;Q)!$a4Zm7 z$PmL)%UR1<%T&u%A`CjGpq8lyv|X6HhARa$g88F{djU%d56J!+t`uJIC=;lU$pSj& z4>VVo!VeZx0IL&#suKi@nSjNFpkj~_Di5%j2w03Mg)tkn38Sxu8x#(;JSn0zphE|l zYIxFE#27&R*AhPP=ulV<`vMlo?BE2(!mt{q6ebIXS|-pq5%{zKgIc~Cb{B?Nm0GSE zHb|(Kh}3{%2sD#d!&k!v+4Dbvv2fM|#==P@qM*qZ7lv4$7^YhOS^*?o;JLpPjubJ7 zjvD?HMsPp$46+)~Ry&Z%2z3(}3(w#(HANgUqli!qHI=DI31%ut4Hi?G3YAL4K&Jx* zGiXXwxr5u`LEx6Hf(CdCnT|qYQl^dqsPm+$0A1ROZyEq>0=QKJX)u7=3g8p#s#x?A zlQJO<2+*21@IK62Y$=IF<(YX^5*jh(+M4kiF)2u7xwfW?CetmJOk)ePTg(Lo$+wu( z5=%6hi^@T{wgOa8vsGA_#haN#v7{xI7;7@!Vl600HZv)z0?DzaC6<_(Xfi>RLxe!9 zFmp6n5kf_^FtduPL7F&A^D;qg+r%7D+c{pf7=j=hMpZ#m?BYeB6Q6Fe7J)j1;FVNG zJ|Hu|QwreGGVn-N1ZY7J52(2dSxS^zTqF-t25KJMVgc=1Ecyg0%%VYppo6M!ae$V~ zrsWsq-eM|BEdrfbQ?wSOq7^h#%H`=B5FZfa3OWV-2S|XqIJHDm@D>Niv6=aK#h}GO zS@}h`SaUP;@{4Y<Bqn7RLuy^{02Zhrd5aAcjj6?u(`vvYd7uLUZ?S_{C8icb>;$(V zL5EI3S|8xP0Jt;+6QF7Zw5SC(KNt_%ExZ;~#ehn6(D98Nj8cqJOrXUeT#ORnV;n&P z{w&Z18lZ(4pt(%Yk`B=L7b*rV)!+gx3t<NJBGi}#7^N7w7?of&V^KFF0|QFG0W^LH zYAAz?Pf#rf>M@isHZv6qfsXuWW~^mM0Uh(q2wtY4RKf&W3Gc!XYY@W>I`X-e6?Cd< z7IPUxky;JtL`N1d3p6~&3Sy-&)q)O+h$vJ8pF7O#=N6*LRs<fy1eN5s_?`WI0~|v< zoqSy5Lmb_Mi%|DEYO;aX9i`?#sxWXQFqfqk6@kMS6!=J04k&2B_0tDXaDp2B42+<9 z8MG3Ig^>?DJjlifRspJ8LqUfCr<Im~&h?H5O^`4Y?FJ<m@I-wOC@u4WmMfK(Wabp> zfyi5&aQ-dU)ZE0(oFY(by$F1e2q?K0f#&mXv4hU6$jnQJi~)mJ8#aN`D5zlsN$#Kq zRnZNQUEn3Jpvg|~%pB-6I8eF(AJY#$7Xz|w7ChPu+L8-d0R~#02U#=+uFb*CV$kU= zNQc6)fZPjSvIuFyfrpPlAp&0I0%;0>7sG&7?iGPsgWz-uZiR!I-M2so()r|r4&Q(@ zJiyIx&@4arq#)3dK}F3VUp0aVaK<zSc?guXA=w$URk-LQD5rrlF)VLFjzk6JS4j4? z1gT&Lm57-+skgX1-TnN7T%8?*U2n06xdu7;2fG$kfDA4H5z9fu8W6D>M63c4P9Orb zo%j}8eo|IyatZkG<s$Gr8z_l^lYCJR$eG|NP;f3p5THbJi^C=te2TXn=(McjE(Qh$ z9wtx*0%1g_9K?fTCILnnMjl29CLJaLCN3rxaK`{PG|j>Unx7K_WnLyJCeW@}J|+%M uHby2UHV&>IEL?0XTz^>DKv|cC5u}rgiGx`{nT=VXo&f>1IPBP%n3w_Ga&NZ) diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__init__.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__init__.py deleted file mode 100644 index f7dbf4c9..00000000 --- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__init__.py +++ /dev/null @@ -1,6 +0,0 @@ -"""Modules copied from Python 3 standard libraries, for internal use only. - -Individual classes and functions are found in d2._backport.misc. Intended -usage is to always import things missing from 3.1 from that module: the -built-in/stdlib objects will be used if found. -""" diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 2d3302e2a94dfc0aeb36363d66d4ae1a5bc139ad..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 511 zcmYe~<>g{vU|^UdaWGYgk%8ech=Yt785kHG7#J9eIT#oiQW&BbQW%37G?@~)85tOS z^HWN5Qi~Om^9wRlQxwvQ@^cjeDoZl*^AwB~ic1pnQWA?&6ml|?iV}-5Q;T&J((;QG zGV@AOi}Dh46iSOz74q|PD)qRyJo8dA%Q90+6LS=ja}tY-Q;QW6^HLPjO7oISGV}9_ z6%vb571Huc^HLNt^Au8y^x~5eld}u*i%RrzGmDe;6cjx3N>cMuQd77}ixbmR6*7wz zO7ayFbIKDdixo0+K`IqWGBWehixqM+i;FY!(jl%j)-!}KN-`2l6mr4-u~I0>Naac@ z&CDs$&CJs;E=kGBOj5{C%1TWxDOM=Y%*jzmN(H$-MIkc{;wn8ZKTXD4?D6p_`N{F| zD;bKI7#JYLuP$e+n9$<XqT-m;oRrL>82`Lfm!izFR0UmyP(RNw*Pvj}5XWEzPd^ub zKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!klnAE(o7@y3fnBvTmRNaEa<m|-s z)Z&<e%mV%Rvedkk{3897%;J)q%p`qy_~^&SXXa&=#K-FuRNmsSf%wo46sey<u?zqL Cr=rmS diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-39.pyc deleted file mode 100644 index 8dd32bbd50bc42f64a21559f56a58dd142c39776..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1131 zcmYe~<>g{vU|^UdaWM5XGXuk85C<7^FfcGUFfcF_FJWL{NMVR#NMTH2%3+LR1k+4W zOz8|M%!?SKn5zU*7*kksSaMmTSQ#0@8S-RU7*g3PJs254FoidTErq>>F^V;kA&<#` zp^77wJ&HY?Ay18kA(f-D0;Gl!WHv_*XD(M17b8OoX9`yfLliqyJy$AY7IzePI76Nk z3qvYT<vgek?i8LDhA3``suZSR22H*yeW%3a?1KEFl46Cl{33<Syp+tc%#_l^9EIeZ z#Ny)AVui%K6os_XyyTM1{Jdhlmmm-OX)@muOioPBNR3Y`%Fm52&Mz%WPQAsEoS2i7 zn3R)xizBT#H7_|oB~_ELh>3xLAtV_@g0zA#GXnzyi0=#vD-i|;h8o5qjugfMt`w$P zrW%GCCUJ&f22EzaTa3xK81q*$Xfj8!7gWZlW#**bVoga+Doww|oLW&*#LmFL049F5 zIa|eq7N-^!$E4<@WEREv=cT$7WtOEX=qiNzd4{<L1$%}#1}k{_x%m6J275Zj1iSjW z28Xx?DVW6s1o*@xn&{@_r)L(IWM;>t=9R_xWG2NFXO^Vu79=KTC#I(s#}s51=*O3( z=B4Bp>8E5Cm*iw7>BlEQ!%japvp89=pc3p?L6EOlK>lRpf%smN@fL?OG-#3;K{8Mb zVuJz$91x(iRl-oiP{P;@iW){gO{QC1nZ=oT#U+V($*D!$3=9mKjJKHcld`~`h7cfK zMIbYzLDqsom4Ok=$FK<GB(Oy`3=9k~i;DPa7=j@@re>xhwHk&6%q1)fSQj!ZWDI5~ zVM}2wVXt9mX3XLcV`ye<VoU+W43l4#bZSLGYI2D}Qe{bMu|j^4LUBovjzV63iGpge zCT9^30|Ub?R<PtP=Hil~TWpZzaErOPviO#0dTI$MGK(vVOHy;eGMRblw>U#83sPN+ zit>wYv6NI6q~79)kIzfYO^uHS1t3TRhzIdDIO@TE2YE{g<aa($pfYkXvM_Qn@-eY6 za{Mm>$!Ri%X!71-kB?8uPmYhj#gt!M1d1V$NMcS-eEcou%-jNS#NFcd%mw8HuoJ*x zc#G37F&FA2?&SQOoK#3I0LKN`^jmz6B_&0fNu?zaWk{}rJMk8WO>TZlX-=vg8_1ms n3=9k`OdO0HOdQNii~@{2i~_7oj2w(Sj66(yEKH1Cj6940kn0Y4 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-39.pyc deleted file mode 100644 index 6276239783ad31ee70781dd0ba8b38c5ae70d506..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21705 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 Qx?`TdY;2(UYOrc{0BP7n2LJ#7 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-39.pyc deleted file mode 100644 index 605f0df3d550f1f368c94f5d5ce6f660fc318f3f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15995 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 VGq7-Qa?~>@bFgr*b8vGp0st_My^;U` diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-39.pyc deleted file mode 100644 index 81af67a91a823524ed75c3f3cc508531e7e39f6c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 62759 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%0AIjZ!&t+#kSUl! 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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 Z1?n021nL=JPz;F;5(^Q~;^1as1ONu;lz0FD diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/misc.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/misc.py deleted file mode 100644 index cfb318d3..00000000 --- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/misc.py +++ /dev/null @@ -1,41 +0,0 @@ -# -*- coding: utf-8 -*- -# -# Copyright (C) 2012 The Python Software Foundation. -# See LICENSE.txt and CONTRIBUTORS.txt. -# -"""Backports for individual classes and functions.""" - -import os -import sys - -__all__ = ['cache_from_source', 'callable', 'fsencode'] - - -try: - from imp import cache_from_source -except ImportError: - def cache_from_source(py_file, debug=__debug__): - ext = debug and 'c' or 'o' - return py_file + ext - - -try: - callable = callable -except NameError: - from collections import Callable - - def callable(obj): - return isinstance(obj, Callable) - - -try: - fsencode = os.fsencode -except AttributeError: - def fsencode(filename): - if isinstance(filename, bytes): - return filename - elif isinstance(filename, str): - return filename.encode(sys.getfilesystemencoding()) - else: - raise TypeError("expect bytes or str, not %s" % - type(filename).__name__) diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/shutil.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/shutil.py deleted file mode 100644 index 10ed3625..00000000 --- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/shutil.py +++ /dev/null @@ -1,764 +0,0 @@ -# -*- coding: utf-8 -*- -# -# Copyright (C) 2012 The Python Software Foundation. -# See LICENSE.txt and CONTRIBUTORS.txt. -# -"""Utility functions for copying and archiving files and directory trees. - -XXX The functions here don't copy the resource fork or other metadata on Mac. - -""" - -import os -import sys -import stat -from os.path import abspath -import fnmatch -try: - from collections.abc import Callable -except ImportError: - from collections import Callable -import errno -from . import tarfile - -try: - import bz2 - _BZ2_SUPPORTED = True -except ImportError: - _BZ2_SUPPORTED = False - -try: - from pwd import getpwnam -except ImportError: - getpwnam = None - -try: - from grp import getgrnam -except ImportError: - getgrnam = None - -__all__ = ["copyfileobj", "copyfile", "copymode", "copystat", "copy", "copy2", - "copytree", "move", "rmtree", "Error", "SpecialFileError", - "ExecError", "make_archive", "get_archive_formats", - "register_archive_format", "unregister_archive_format", - "get_unpack_formats", "register_unpack_format", - "unregister_unpack_format", "unpack_archive", "ignore_patterns"] - -class Error(EnvironmentError): - pass - -class SpecialFileError(EnvironmentError): - """Raised when trying to do a kind of operation (e.g. copying) which is - not supported on a special file (e.g. a named pipe)""" - -class ExecError(EnvironmentError): - """Raised when a command could not be executed""" - -class ReadError(EnvironmentError): - """Raised when an archive cannot be read""" - -class RegistryError(Exception): - """Raised when a registry operation with the archiving - and unpacking registries fails""" - - -try: - WindowsError -except NameError: - WindowsError = None - -def copyfileobj(fsrc, fdst, length=16*1024): - """copy data from file-like object fsrc to file-like object fdst""" - while 1: - buf = fsrc.read(length) - if not buf: - break - fdst.write(buf) - -def _samefile(src, dst): - # Macintosh, Unix. - if hasattr(os.path, 'samefile'): - try: - return os.path.samefile(src, dst) - except OSError: - return False - - # All other platforms: check for same pathname. - return (os.path.normcase(os.path.abspath(src)) == - os.path.normcase(os.path.abspath(dst))) - -def copyfile(src, dst): - """Copy data from src to dst""" - if _samefile(src, dst): - raise Error("`%s` and `%s` are the same file" % (src, dst)) - - for fn in [src, dst]: - try: - st = os.stat(fn) - except OSError: - # File most likely does not exist - pass - else: - # XXX What about other special files? (sockets, devices...) - if stat.S_ISFIFO(st.st_mode): - raise SpecialFileError("`%s` is a named pipe" % fn) - - with open(src, 'rb') as fsrc: - with open(dst, 'wb') as fdst: - copyfileobj(fsrc, fdst) - -def copymode(src, dst): - """Copy mode bits from src to dst""" - if hasattr(os, 'chmod'): - st = os.stat(src) - mode = stat.S_IMODE(st.st_mode) - os.chmod(dst, mode) - -def copystat(src, dst): - """Copy all stat info (mode bits, atime, mtime, flags) from src to dst""" - st = os.stat(src) - mode = stat.S_IMODE(st.st_mode) - if hasattr(os, 'utime'): - os.utime(dst, (st.st_atime, st.st_mtime)) - if hasattr(os, 'chmod'): - os.chmod(dst, mode) - if hasattr(os, 'chflags') and hasattr(st, 'st_flags'): - try: - os.chflags(dst, st.st_flags) - except OSError as why: - if (not hasattr(errno, 'EOPNOTSUPP') or - why.errno != errno.EOPNOTSUPP): - raise - -def copy(src, dst): - """Copy data and mode bits ("cp src dst"). - - The destination may be a directory. - - """ - if os.path.isdir(dst): - dst = os.path.join(dst, os.path.basename(src)) - copyfile(src, dst) - copymode(src, dst) - -def copy2(src, dst): - """Copy data and all stat info ("cp -p src dst"). - - The destination may be a directory. - - """ - if os.path.isdir(dst): - dst = os.path.join(dst, os.path.basename(src)) - copyfile(src, dst) - copystat(src, dst) - -def ignore_patterns(*patterns): - """Function that can be used as copytree() ignore parameter. - - Patterns is a sequence of glob-style patterns - that are used to exclude files""" - def _ignore_patterns(path, names): - ignored_names = [] - for pattern in patterns: - ignored_names.extend(fnmatch.filter(names, pattern)) - return set(ignored_names) - return _ignore_patterns - -def copytree(src, dst, symlinks=False, ignore=None, copy_function=copy2, - ignore_dangling_symlinks=False): - """Recursively copy a directory tree. - - The destination directory must not already exist. - If exception(s) occur, an Error is raised with a list of reasons. - - If the optional symlinks flag is true, symbolic links in the - source tree result in symbolic links in the destination tree; if - it is false, the contents of the files pointed to by symbolic - links are copied. If the file pointed by the symlink doesn't - exist, an exception will be added in the list of errors raised in - an Error exception at the end of the copy process. - - You can set the optional ignore_dangling_symlinks flag to true if you - want to silence this exception. Notice that this has no effect on - platforms that don't support os.symlink. - - The optional ignore argument is a callable. If given, it - is called with the `src` parameter, which is the directory - being visited by copytree(), and `names` which is the list of - `src` contents, as returned by os.listdir(): - - callable(src, names) -> ignored_names - - Since copytree() is called recursively, the callable will be - called once for each directory that is copied. It returns a - list of names relative to the `src` directory that should - not be copied. - - The optional copy_function argument is a callable that will be used - to copy each file. It will be called with the source path and the - destination path as arguments. By default, copy2() is used, but any - function that supports the same signature (like copy()) can be used. - - """ - names = os.listdir(src) - if ignore is not None: - ignored_names = ignore(src, names) - else: - ignored_names = set() - - os.makedirs(dst) - errors = [] - for name in names: - if name in ignored_names: - continue - srcname = os.path.join(src, name) - dstname = os.path.join(dst, name) - try: - if os.path.islink(srcname): - linkto = os.readlink(srcname) - if symlinks: - os.symlink(linkto, dstname) - else: - # ignore dangling symlink if the flag is on - if not os.path.exists(linkto) and ignore_dangling_symlinks: - continue - # otherwise let the copy occurs. copy2 will raise an error - copy_function(srcname, dstname) - elif os.path.isdir(srcname): - copytree(srcname, dstname, symlinks, ignore, copy_function) - else: - # Will raise a SpecialFileError for unsupported file types - copy_function(srcname, dstname) - # catch the Error from the recursive copytree so that we can - # continue with other files - except Error as err: - errors.extend(err.args[0]) - except EnvironmentError as why: - errors.append((srcname, dstname, str(why))) - try: - copystat(src, dst) - except OSError as why: - if WindowsError is not None and isinstance(why, WindowsError): - # Copying file access times may fail on Windows - pass - else: - errors.extend((src, dst, str(why))) - if errors: - raise Error(errors) - -def rmtree(path, ignore_errors=False, onerror=None): - """Recursively delete a directory tree. - - If ignore_errors is set, errors are ignored; otherwise, if onerror - is set, it is called to handle the error with arguments (func, - path, exc_info) where func is os.listdir, os.remove, or os.rmdir; - path is the argument to that function that caused it to fail; and - exc_info is a tuple returned by sys.exc_info(). If ignore_errors - is false and onerror is None, an exception is raised. - - """ - if ignore_errors: - def onerror(*args): - pass - elif onerror is None: - def onerror(*args): - raise - try: - if os.path.islink(path): - # symlinks to directories are forbidden, see bug #1669 - raise OSError("Cannot call rmtree on a symbolic link") - except OSError: - onerror(os.path.islink, path, sys.exc_info()) - # can't continue even if onerror hook returns - return - names = [] - try: - names = os.listdir(path) - except os.error: - onerror(os.listdir, path, sys.exc_info()) - for name in names: - fullname = os.path.join(path, name) - try: - mode = os.lstat(fullname).st_mode - except os.error: - mode = 0 - if stat.S_ISDIR(mode): - rmtree(fullname, ignore_errors, onerror) - else: - try: - os.remove(fullname) - except os.error: - onerror(os.remove, fullname, sys.exc_info()) - try: - os.rmdir(path) - except os.error: - onerror(os.rmdir, path, sys.exc_info()) - - -def _basename(path): - # A basename() variant which first strips the trailing slash, if present. - # Thus we always get the last component of the path, even for directories. - return os.path.basename(path.rstrip(os.path.sep)) - -def move(src, dst): - """Recursively move a file or directory to another location. This is - similar to the Unix "mv" command. - - If the destination is a directory or a symlink to a directory, the source - is moved inside the directory. The destination path must not already - exist. - - If the destination already exists but is not a directory, it may be - overwritten depending on os.rename() semantics. - - If the destination is on our current filesystem, then rename() is used. - Otherwise, src is copied to the destination and then removed. - A lot more could be done here... A look at a mv.c shows a lot of - the issues this implementation glosses over. - - """ - real_dst = dst - if os.path.isdir(dst): - if _samefile(src, dst): - # We might be on a case insensitive filesystem, - # perform the rename anyway. - os.rename(src, dst) - return - - real_dst = os.path.join(dst, _basename(src)) - if os.path.exists(real_dst): - raise Error("Destination path '%s' already exists" % real_dst) - try: - os.rename(src, real_dst) - except OSError: - if os.path.isdir(src): - if _destinsrc(src, dst): - raise Error("Cannot move a directory '%s' into itself '%s'." % (src, dst)) - copytree(src, real_dst, symlinks=True) - rmtree(src) - else: - copy2(src, real_dst) - os.unlink(src) - -def _destinsrc(src, dst): - src = abspath(src) - dst = abspath(dst) - if not src.endswith(os.path.sep): - src += os.path.sep - if not dst.endswith(os.path.sep): - dst += os.path.sep - return dst.startswith(src) - -def _get_gid(name): - """Returns a gid, given a group name.""" - if getgrnam is None or name is None: - return None - try: - result = getgrnam(name) - except KeyError: - result = None - if result is not None: - return result[2] - return None - -def _get_uid(name): - """Returns an uid, given a user name.""" - if getpwnam is None or name is None: - return None - try: - result = getpwnam(name) - except KeyError: - result = None - if result is not None: - return result[2] - return None - -def _make_tarball(base_name, base_dir, compress="gzip", verbose=0, dry_run=0, - owner=None, group=None, logger=None): - """Create a (possibly compressed) tar file from all the files under - 'base_dir'. - - 'compress' must be "gzip" (the default), "bzip2", or None. - - 'owner' and 'group' can be used to define an owner and a group for the - archive that is being built. If not provided, the current owner and group - will be used. - - The output tar file will be named 'base_name' + ".tar", possibly plus - the appropriate compression extension (".gz", or ".bz2"). - - Returns the output filename. - """ - tar_compression = {'gzip': 'gz', None: ''} - compress_ext = {'gzip': '.gz'} - - if _BZ2_SUPPORTED: - tar_compression['bzip2'] = 'bz2' - compress_ext['bzip2'] = '.bz2' - - # flags for compression program, each element of list will be an argument - if compress is not None and compress not in compress_ext: - raise ValueError("bad value for 'compress', or compression format not " - "supported : {0}".format(compress)) - - archive_name = base_name + '.tar' + compress_ext.get(compress, '') - archive_dir = os.path.dirname(archive_name) - - if not os.path.exists(archive_dir): - if logger is not None: - logger.info("creating %s", archive_dir) - if not dry_run: - os.makedirs(archive_dir) - - # creating the tarball - if logger is not None: - logger.info('Creating tar archive') - - uid = _get_uid(owner) - gid = _get_gid(group) - - def _set_uid_gid(tarinfo): - if gid is not None: - tarinfo.gid = gid - tarinfo.gname = group - if uid is not None: - tarinfo.uid = uid - tarinfo.uname = owner - return tarinfo - - if not dry_run: - tar = tarfile.open(archive_name, 'w|%s' % tar_compression[compress]) - try: - tar.add(base_dir, filter=_set_uid_gid) - finally: - tar.close() - - return archive_name - -def _call_external_zip(base_dir, zip_filename, verbose=False, dry_run=False): - # XXX see if we want to keep an external call here - if verbose: - zipoptions = "-r" - else: - zipoptions = "-rq" - from distutils.errors import DistutilsExecError - from distutils.spawn import spawn - try: - spawn(["zip", zipoptions, zip_filename, base_dir], dry_run=dry_run) - except DistutilsExecError: - # XXX really should distinguish between "couldn't find - # external 'zip' command" and "zip failed". - raise ExecError("unable to create zip file '%s': " - "could neither import the 'zipfile' module nor " - "find a standalone zip utility") % zip_filename - -def _make_zipfile(base_name, base_dir, verbose=0, dry_run=0, logger=None): - """Create a zip file from all the files under 'base_dir'. - - The output zip file will be named 'base_name' + ".zip". Uses either the - "zipfile" Python module (if available) or the InfoZIP "zip" utility - (if installed and found on the default search path). If neither tool is - available, raises ExecError. Returns the name of the output zip - file. - """ - zip_filename = base_name + ".zip" - archive_dir = os.path.dirname(base_name) - - if not os.path.exists(archive_dir): - if logger is not None: - logger.info("creating %s", archive_dir) - if not dry_run: - os.makedirs(archive_dir) - - # If zipfile module is not available, try spawning an external 'zip' - # command. - try: - import zipfile - except ImportError: - zipfile = None - - if zipfile is None: - _call_external_zip(base_dir, zip_filename, verbose, dry_run) - else: - if logger is not None: - logger.info("creating '%s' and adding '%s' to it", - zip_filename, base_dir) - - if not dry_run: - zip = zipfile.ZipFile(zip_filename, "w", - compression=zipfile.ZIP_DEFLATED) - - for dirpath, dirnames, filenames in os.walk(base_dir): - for name in filenames: - path = os.path.normpath(os.path.join(dirpath, name)) - if os.path.isfile(path): - zip.write(path, path) - if logger is not None: - logger.info("adding '%s'", path) - zip.close() - - return zip_filename - -_ARCHIVE_FORMATS = { - 'gztar': (_make_tarball, [('compress', 'gzip')], "gzip'ed tar-file"), - 'bztar': (_make_tarball, [('compress', 'bzip2')], "bzip2'ed tar-file"), - 'tar': (_make_tarball, [('compress', None)], "uncompressed tar file"), - 'zip': (_make_zipfile, [], "ZIP file"), - } - -if _BZ2_SUPPORTED: - _ARCHIVE_FORMATS['bztar'] = (_make_tarball, [('compress', 'bzip2')], - "bzip2'ed tar-file") - -def get_archive_formats(): - """Returns a list of supported formats for archiving and unarchiving. - - Each element of the returned sequence is a tuple (name, description) - """ - formats = [(name, registry[2]) for name, registry in - _ARCHIVE_FORMATS.items()] - formats.sort() - return formats - -def register_archive_format(name, function, extra_args=None, description=''): - """Registers an archive format. - - name is the name of the format. function is the callable that will be - used to create archives. If provided, extra_args is a sequence of - (name, value) tuples that will be passed as arguments to the callable. - description can be provided to describe the format, and will be returned - by the get_archive_formats() function. - """ - if extra_args is None: - extra_args = [] - if not isinstance(function, Callable): - raise TypeError('The %s object is not callable' % function) - if not isinstance(extra_args, (tuple, list)): - raise TypeError('extra_args needs to be a sequence') - for element in extra_args: - if not isinstance(element, (tuple, list)) or len(element) !=2: - raise TypeError('extra_args elements are : (arg_name, value)') - - _ARCHIVE_FORMATS[name] = (function, extra_args, description) - -def unregister_archive_format(name): - del _ARCHIVE_FORMATS[name] - -def make_archive(base_name, format, root_dir=None, base_dir=None, verbose=0, - dry_run=0, owner=None, group=None, logger=None): - """Create an archive file (eg. zip or tar). - - 'base_name' is the name of the file to create, minus any format-specific - extension; 'format' is the archive format: one of "zip", "tar", "bztar" - or "gztar". - - 'root_dir' is a directory that will be the root directory of the - archive; ie. we typically chdir into 'root_dir' before creating the - archive. 'base_dir' is the directory where we start archiving from; - ie. 'base_dir' will be the common prefix of all files and - directories in the archive. 'root_dir' and 'base_dir' both default - to the current directory. Returns the name of the archive file. - - 'owner' and 'group' are used when creating a tar archive. By default, - uses the current owner and group. - """ - save_cwd = os.getcwd() - if root_dir is not None: - if logger is not None: - logger.debug("changing into '%s'", root_dir) - base_name = os.path.abspath(base_name) - if not dry_run: - os.chdir(root_dir) - - if base_dir is None: - base_dir = os.curdir - - kwargs = {'dry_run': dry_run, 'logger': logger} - - try: - format_info = _ARCHIVE_FORMATS[format] - except KeyError: - raise ValueError("unknown archive format '%s'" % format) - - func = format_info[0] - for arg, val in format_info[1]: - kwargs[arg] = val - - if format != 'zip': - kwargs['owner'] = owner - kwargs['group'] = group - - try: - filename = func(base_name, base_dir, **kwargs) - finally: - if root_dir is not None: - if logger is not None: - logger.debug("changing back to '%s'", save_cwd) - os.chdir(save_cwd) - - return filename - - -def get_unpack_formats(): - """Returns a list of supported formats for unpacking. - - Each element of the returned sequence is a tuple - (name, extensions, description) - """ - formats = [(name, info[0], info[3]) for name, info in - _UNPACK_FORMATS.items()] - formats.sort() - return formats - -def _check_unpack_options(extensions, function, extra_args): - """Checks what gets registered as an unpacker.""" - # first make sure no other unpacker is registered for this extension - existing_extensions = {} - for name, info in _UNPACK_FORMATS.items(): - for ext in info[0]: - existing_extensions[ext] = name - - for extension in extensions: - if extension in existing_extensions: - msg = '%s is already registered for "%s"' - raise RegistryError(msg % (extension, - existing_extensions[extension])) - - if not isinstance(function, Callable): - raise TypeError('The registered function must be a callable') - - -def register_unpack_format(name, extensions, function, extra_args=None, - description=''): - """Registers an unpack format. - - `name` is the name of the format. `extensions` is a list of extensions - corresponding to the format. - - `function` is the callable that will be - used to unpack archives. The callable will receive archives to unpack. - If it's unable to handle an archive, it needs to raise a ReadError - exception. - - If provided, `extra_args` is a sequence of - (name, value) tuples that will be passed as arguments to the callable. - description can be provided to describe the format, and will be returned - by the get_unpack_formats() function. - """ - if extra_args is None: - extra_args = [] - _check_unpack_options(extensions, function, extra_args) - _UNPACK_FORMATS[name] = extensions, function, extra_args, description - -def unregister_unpack_format(name): - """Removes the pack format from the registry.""" - del _UNPACK_FORMATS[name] - -def _ensure_directory(path): - """Ensure that the parent directory of `path` exists""" - dirname = os.path.dirname(path) - if not os.path.isdir(dirname): - os.makedirs(dirname) - -def _unpack_zipfile(filename, extract_dir): - """Unpack zip `filename` to `extract_dir` - """ - try: - import zipfile - except ImportError: - raise ReadError('zlib not supported, cannot unpack this archive.') - - if not zipfile.is_zipfile(filename): - raise ReadError("%s is not a zip file" % filename) - - zip = zipfile.ZipFile(filename) - try: - for info in zip.infolist(): - name = info.filename - - # don't extract absolute paths or ones with .. in them - if name.startswith('/') or '..' in name: - continue - - target = os.path.join(extract_dir, *name.split('/')) - if not target: - continue - - _ensure_directory(target) - if not name.endswith('/'): - # file - data = zip.read(info.filename) - f = open(target, 'wb') - try: - f.write(data) - finally: - f.close() - del data - finally: - zip.close() - -def _unpack_tarfile(filename, extract_dir): - """Unpack tar/tar.gz/tar.bz2 `filename` to `extract_dir` - """ - try: - tarobj = tarfile.open(filename) - except tarfile.TarError: - raise ReadError( - "%s is not a compressed or uncompressed tar file" % filename) - try: - tarobj.extractall(extract_dir) - finally: - tarobj.close() - -_UNPACK_FORMATS = { - 'gztar': (['.tar.gz', '.tgz'], _unpack_tarfile, [], "gzip'ed tar-file"), - 'tar': (['.tar'], _unpack_tarfile, [], "uncompressed tar file"), - 'zip': (['.zip'], _unpack_zipfile, [], "ZIP file") - } - -if _BZ2_SUPPORTED: - _UNPACK_FORMATS['bztar'] = (['.bz2'], _unpack_tarfile, [], - "bzip2'ed tar-file") - -def _find_unpack_format(filename): - for name, info in _UNPACK_FORMATS.items(): - for extension in info[0]: - if filename.endswith(extension): - return name - return None - -def unpack_archive(filename, extract_dir=None, format=None): - """Unpack an archive. - - `filename` is the name of the archive. - - `extract_dir` is the name of the target directory, where the archive - is unpacked. If not provided, the current working directory is used. - - `format` is the archive format: one of "zip", "tar", or "gztar". Or any - other registered format. If not provided, unpack_archive will use the - filename extension and see if an unpacker was registered for that - extension. - - In case none is found, a ValueError is raised. - """ - if extract_dir is None: - extract_dir = os.getcwd() - - if format is not None: - try: - format_info = _UNPACK_FORMATS[format] - except KeyError: - raise ValueError("Unknown unpack format '{0}'".format(format)) - - func = format_info[1] - func(filename, extract_dir, **dict(format_info[2])) - else: - # we need to look at the registered unpackers supported extensions - format = _find_unpack_format(filename) - if format is None: - raise ReadError("Unknown archive format '{0}'".format(filename)) - - func = _UNPACK_FORMATS[format][1] - kwargs = dict(_UNPACK_FORMATS[format][2]) - func(filename, extract_dir, **kwargs) diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg b/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg deleted file mode 100644 index 1746bd01..00000000 --- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg +++ /dev/null @@ -1,84 +0,0 @@ -[posix_prefix] -# Configuration directories. Some of these come straight out of the -# configure script. They are for implementing the other variables, not to -# be used directly in [resource_locations]. -confdir = /etc -datadir = /usr/share -libdir = /usr/lib -statedir = /var -# User resource directory -local = ~/.local/{distribution.name} - -stdlib = {base}/lib/python{py_version_short} -platstdlib = {platbase}/lib/python{py_version_short} -purelib = {base}/lib/python{py_version_short}/site-packages -platlib = {platbase}/lib/python{py_version_short}/site-packages -include = {base}/include/python{py_version_short}{abiflags} -platinclude = {platbase}/include/python{py_version_short}{abiflags} -data = {base} - -[posix_home] -stdlib = {base}/lib/python -platstdlib = {base}/lib/python -purelib = {base}/lib/python -platlib = {base}/lib/python -include = {base}/include/python -platinclude = {base}/include/python -scripts = {base}/bin -data = {base} - -[nt] -stdlib = {base}/Lib -platstdlib = {base}/Lib -purelib = {base}/Lib/site-packages -platlib = {base}/Lib/site-packages -include = {base}/Include -platinclude = {base}/Include -scripts = {base}/Scripts -data = {base} - -[os2] -stdlib = {base}/Lib -platstdlib = {base}/Lib -purelib = {base}/Lib/site-packages -platlib = {base}/Lib/site-packages -include = {base}/Include -platinclude = {base}/Include -scripts = {base}/Scripts -data = {base} - -[os2_home] -stdlib = {userbase}/lib/python{py_version_short} -platstdlib = {userbase}/lib/python{py_version_short} -purelib = {userbase}/lib/python{py_version_short}/site-packages -platlib = {userbase}/lib/python{py_version_short}/site-packages -include = {userbase}/include/python{py_version_short} -scripts = {userbase}/bin -data = {userbase} - -[nt_user] -stdlib = {userbase}/Python{py_version_nodot} -platstdlib = {userbase}/Python{py_version_nodot} -purelib = {userbase}/Python{py_version_nodot}/site-packages -platlib = {userbase}/Python{py_version_nodot}/site-packages -include = {userbase}/Python{py_version_nodot}/Include -scripts = {userbase}/Scripts -data = {userbase} - -[posix_user] -stdlib = {userbase}/lib/python{py_version_short} -platstdlib = {userbase}/lib/python{py_version_short} -purelib = {userbase}/lib/python{py_version_short}/site-packages -platlib = {userbase}/lib/python{py_version_short}/site-packages -include = {userbase}/include/python{py_version_short} -scripts = {userbase}/bin -data = {userbase} - -[osx_framework_user] -stdlib = {userbase}/lib/python -platstdlib = {userbase}/lib/python -purelib = {userbase}/lib/python/site-packages -platlib = {userbase}/lib/python/site-packages -include = {userbase}/include -scripts = {userbase}/bin -data = {userbase} diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.py deleted file mode 100644 index b470a373..00000000 --- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.py +++ /dev/null @@ -1,786 +0,0 @@ -# -*- coding: utf-8 -*- -# -# Copyright (C) 2012 The Python Software Foundation. -# See LICENSE.txt and CONTRIBUTORS.txt. -# -"""Access to Python's configuration information.""" - -import codecs -import os -import re -import sys -from os.path import pardir, realpath -try: - import configparser -except ImportError: - import ConfigParser as configparser - - -__all__ = [ - 'get_config_h_filename', - 'get_config_var', - 'get_config_vars', - 'get_makefile_filename', - 'get_path', - 'get_path_names', - 'get_paths', - 'get_platform', - 'get_python_version', - 'get_scheme_names', - 'parse_config_h', -] - - -def _safe_realpath(path): - try: - return realpath(path) - except OSError: - return path - - -if sys.executable: - _PROJECT_BASE = os.path.dirname(_safe_realpath(sys.executable)) -else: - # sys.executable can be empty if argv[0] has been changed and Python is - # unable to retrieve the real program name - _PROJECT_BASE = _safe_realpath(os.getcwd()) - -if os.name == "nt" and "pcbuild" in _PROJECT_BASE[-8:].lower(): - _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir)) -# PC/VS7.1 -if os.name == "nt" and "\\pc\\v" in _PROJECT_BASE[-10:].lower(): - _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir, pardir)) -# PC/AMD64 -if os.name == "nt" and "\\pcbuild\\amd64" in _PROJECT_BASE[-14:].lower(): - _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir, pardir)) - - -def is_python_build(): - for fn in ("Setup.dist", "Setup.local"): - if os.path.isfile(os.path.join(_PROJECT_BASE, "Modules", fn)): - return True - return False - -_PYTHON_BUILD = is_python_build() - -_cfg_read = False - -def _ensure_cfg_read(): - global _cfg_read - if not _cfg_read: - from ..resources import finder - backport_package = __name__.rsplit('.', 1)[0] - _finder = finder(backport_package) - _cfgfile = _finder.find('sysconfig.cfg') - assert _cfgfile, 'sysconfig.cfg exists' - with _cfgfile.as_stream() as s: - _SCHEMES.readfp(s) - if _PYTHON_BUILD: - for scheme in ('posix_prefix', 'posix_home'): - _SCHEMES.set(scheme, 'include', '{srcdir}/Include') - _SCHEMES.set(scheme, 'platinclude', '{projectbase}/.') - - _cfg_read = True - - -_SCHEMES = configparser.RawConfigParser() -_VAR_REPL = re.compile(r'\{([^{]*?)\}') - -def _expand_globals(config): - _ensure_cfg_read() - if config.has_section('globals'): - globals = config.items('globals') - else: - globals = tuple() - - sections = config.sections() - for section in sections: - if section == 'globals': - continue - for option, value in globals: - if config.has_option(section, option): - continue - config.set(section, option, value) - config.remove_section('globals') - - # now expanding local variables defined in the cfg file - # - for section in config.sections(): - variables = dict(config.items(section)) - - def _replacer(matchobj): - name = matchobj.group(1) - if name in variables: - return variables[name] - return matchobj.group(0) - - for option, value in config.items(section): - config.set(section, option, _VAR_REPL.sub(_replacer, value)) - -#_expand_globals(_SCHEMES) - -_PY_VERSION = '%s.%s.%s' % sys.version_info[:3] -_PY_VERSION_SHORT = '%s.%s' % sys.version_info[:2] -_PY_VERSION_SHORT_NO_DOT = '%s%s' % sys.version_info[:2] -_PREFIX = os.path.normpath(sys.prefix) -_EXEC_PREFIX = os.path.normpath(sys.exec_prefix) -_CONFIG_VARS = None -_USER_BASE = None - - -def _subst_vars(path, local_vars): - """In the string `path`, replace tokens like {some.thing} with the - corresponding value from the map `local_vars`. - - If there is no corresponding value, leave the token unchanged. - """ - def _replacer(matchobj): - name = matchobj.group(1) - if name in local_vars: - return local_vars[name] - elif name in os.environ: - return os.environ[name] - return matchobj.group(0) - return _VAR_REPL.sub(_replacer, path) - - -def _extend_dict(target_dict, other_dict): - target_keys = target_dict.keys() - for key, value in other_dict.items(): - if key in target_keys: - continue - target_dict[key] = value - - -def _expand_vars(scheme, vars): - res = {} - if vars is None: - vars = {} - _extend_dict(vars, get_config_vars()) - - for key, value in _SCHEMES.items(scheme): - if os.name in ('posix', 'nt'): - value = os.path.expanduser(value) - res[key] = os.path.normpath(_subst_vars(value, vars)) - return res - - -def format_value(value, vars): - def _replacer(matchobj): - name = matchobj.group(1) - if name in vars: - return vars[name] - return matchobj.group(0) - return _VAR_REPL.sub(_replacer, value) - - -def _get_default_scheme(): - if os.name == 'posix': - # the default scheme for posix is posix_prefix - return 'posix_prefix' - return os.name - - -def _getuserbase(): - env_base = os.environ.get("PYTHONUSERBASE", None) - - def joinuser(*args): - return os.path.expanduser(os.path.join(*args)) - - # what about 'os2emx', 'riscos' ? - if os.name == "nt": - base = os.environ.get("APPDATA") or "~" - if env_base: - return env_base - else: - return joinuser(base, "Python") - - if sys.platform == "darwin": - framework = get_config_var("PYTHONFRAMEWORK") - if framework: - if env_base: - return env_base - else: - return joinuser("~", "Library", framework, "%d.%d" % - sys.version_info[:2]) - - if env_base: - return env_base - else: - return joinuser("~", ".local") - - -def _parse_makefile(filename, vars=None): - """Parse a Makefile-style file. - - A dictionary containing name/value pairs is returned. If an - optional dictionary is passed in as the second argument, it is - used instead of a new dictionary. - """ - # Regexes needed for parsing Makefile (and similar syntaxes, - # like old-style Setup files). - _variable_rx = re.compile(r"([a-zA-Z][a-zA-Z0-9_]+)\s*=\s*(.*)") - _findvar1_rx = re.compile(r"\$\(([A-Za-z][A-Za-z0-9_]*)\)") - _findvar2_rx = re.compile(r"\${([A-Za-z][A-Za-z0-9_]*)}") - - if vars is None: - vars = {} - done = {} - notdone = {} - - with codecs.open(filename, encoding='utf-8', errors="surrogateescape") as f: - lines = f.readlines() - - for line in lines: - if line.startswith('#') or line.strip() == '': - continue - m = _variable_rx.match(line) - if m: - n, v = m.group(1, 2) - v = v.strip() - # `$$' is a literal `$' in make - tmpv = v.replace('$$', '') - - if "$" in tmpv: - notdone[n] = v - else: - try: - v = int(v) - except ValueError: - # insert literal `$' - done[n] = v.replace('$$', '$') - else: - done[n] = v - - # do variable interpolation here - variables = list(notdone.keys()) - - # Variables with a 'PY_' prefix in the makefile. These need to - # be made available without that prefix through sysconfig. - # Special care is needed to ensure that variable expansion works, even - # if the expansion uses the name without a prefix. - renamed_variables = ('CFLAGS', 'LDFLAGS', 'CPPFLAGS') - - while len(variables) > 0: - for name in tuple(variables): - value = notdone[name] - m = _findvar1_rx.search(value) or _findvar2_rx.search(value) - if m is not None: - n = m.group(1) - found = True - if n in done: - item = str(done[n]) - elif n in notdone: - # get it on a subsequent round - found = False - elif n in os.environ: - # do it like make: fall back to environment - item = os.environ[n] - - elif n in renamed_variables: - if (name.startswith('PY_') and - name[3:] in renamed_variables): - item = "" - - elif 'PY_' + n in notdone: - found = False - - else: - item = str(done['PY_' + n]) - - else: - done[n] = item = "" - - if found: - after = value[m.end():] - value = value[:m.start()] + item + after - if "$" in after: - notdone[name] = value - else: - try: - value = int(value) - except ValueError: - done[name] = value.strip() - else: - done[name] = value - variables.remove(name) - - if (name.startswith('PY_') and - name[3:] in renamed_variables): - - name = name[3:] - if name not in done: - done[name] = value - - else: - # bogus variable reference (e.g. "prefix=$/opt/python"); - # just drop it since we can't deal - done[name] = value - variables.remove(name) - - # strip spurious spaces - for k, v in done.items(): - if isinstance(v, str): - done[k] = v.strip() - - # save the results in the global dictionary - vars.update(done) - return vars - - -def get_makefile_filename(): - """Return the path of the Makefile.""" - if _PYTHON_BUILD: - return os.path.join(_PROJECT_BASE, "Makefile") - if hasattr(sys, 'abiflags'): - config_dir_name = 'config-%s%s' % (_PY_VERSION_SHORT, sys.abiflags) - else: - config_dir_name = 'config' - return os.path.join(get_path('stdlib'), config_dir_name, 'Makefile') - - -def _init_posix(vars): - """Initialize the module as appropriate for POSIX systems.""" - # load the installed Makefile: - makefile = get_makefile_filename() - try: - _parse_makefile(makefile, vars) - except IOError as e: - msg = "invalid Python installation: unable to open %s" % makefile - if hasattr(e, "strerror"): - msg = msg + " (%s)" % e.strerror - raise IOError(msg) - # load the installed pyconfig.h: - config_h = get_config_h_filename() - try: - with open(config_h) as f: - parse_config_h(f, vars) - except IOError as e: - msg = "invalid Python installation: unable to open %s" % config_h - if hasattr(e, "strerror"): - msg = msg + " (%s)" % e.strerror - raise IOError(msg) - # On AIX, there are wrong paths to the linker scripts in the Makefile - # -- these paths are relative to the Python source, but when installed - # the scripts are in another directory. - if _PYTHON_BUILD: - vars['LDSHARED'] = vars['BLDSHARED'] - - -def _init_non_posix(vars): - """Initialize the module as appropriate for NT""" - # set basic install directories - vars['LIBDEST'] = get_path('stdlib') - vars['BINLIBDEST'] = get_path('platstdlib') - vars['INCLUDEPY'] = get_path('include') - vars['SO'] = '.pyd' - vars['EXE'] = '.exe' - vars['VERSION'] = _PY_VERSION_SHORT_NO_DOT - vars['BINDIR'] = os.path.dirname(_safe_realpath(sys.executable)) - -# -# public APIs -# - - -def parse_config_h(fp, vars=None): - """Parse a config.h-style file. - - A dictionary containing name/value pairs is returned. If an - optional dictionary is passed in as the second argument, it is - used instead of a new dictionary. - """ - if vars is None: - vars = {} - define_rx = re.compile("#define ([A-Z][A-Za-z0-9_]+) (.*)\n") - undef_rx = re.compile("/[*] #undef ([A-Z][A-Za-z0-9_]+) [*]/\n") - - while True: - line = fp.readline() - if not line: - break - m = define_rx.match(line) - if m: - n, v = m.group(1, 2) - try: - v = int(v) - except ValueError: - pass - vars[n] = v - else: - m = undef_rx.match(line) - if m: - vars[m.group(1)] = 0 - return vars - - -def get_config_h_filename(): - """Return the path of pyconfig.h.""" - if _PYTHON_BUILD: - if os.name == "nt": - inc_dir = os.path.join(_PROJECT_BASE, "PC") - else: - inc_dir = _PROJECT_BASE - else: - inc_dir = get_path('platinclude') - return os.path.join(inc_dir, 'pyconfig.h') - - -def get_scheme_names(): - """Return a tuple containing the schemes names.""" - return tuple(sorted(_SCHEMES.sections())) - - -def get_path_names(): - """Return a tuple containing the paths names.""" - # xxx see if we want a static list - return _SCHEMES.options('posix_prefix') - - -def get_paths(scheme=_get_default_scheme(), vars=None, expand=True): - """Return a mapping containing an install scheme. - - ``scheme`` is the install scheme name. If not provided, it will - return the default scheme for the current platform. - """ - _ensure_cfg_read() - if expand: - return _expand_vars(scheme, vars) - else: - return dict(_SCHEMES.items(scheme)) - - -def get_path(name, scheme=_get_default_scheme(), vars=None, expand=True): - """Return a path corresponding to the scheme. - - ``scheme`` is the install scheme name. - """ - return get_paths(scheme, vars, expand)[name] - - -def get_config_vars(*args): - """With no arguments, return a dictionary of all configuration - variables relevant for the current platform. - - On Unix, this means every variable defined in Python's installed Makefile; - On Windows and Mac OS it's a much smaller set. - - With arguments, return a list of values that result from looking up - each argument in the configuration variable dictionary. - """ - global _CONFIG_VARS - if _CONFIG_VARS is None: - _CONFIG_VARS = {} - # Normalized versions of prefix and exec_prefix are handy to have; - # in fact, these are the standard versions used most places in the - # distutils2 module. - _CONFIG_VARS['prefix'] = _PREFIX - _CONFIG_VARS['exec_prefix'] = _EXEC_PREFIX - _CONFIG_VARS['py_version'] = _PY_VERSION - _CONFIG_VARS['py_version_short'] = _PY_VERSION_SHORT - _CONFIG_VARS['py_version_nodot'] = _PY_VERSION[0] + _PY_VERSION[2] - _CONFIG_VARS['base'] = _PREFIX - _CONFIG_VARS['platbase'] = _EXEC_PREFIX - _CONFIG_VARS['projectbase'] = _PROJECT_BASE - try: - _CONFIG_VARS['abiflags'] = sys.abiflags - except AttributeError: - # sys.abiflags may not be defined on all platforms. - _CONFIG_VARS['abiflags'] = '' - - if os.name in ('nt', 'os2'): - _init_non_posix(_CONFIG_VARS) - if os.name == 'posix': - _init_posix(_CONFIG_VARS) - # Setting 'userbase' is done below the call to the - # init function to enable using 'get_config_var' in - # the init-function. - if sys.version >= '2.6': - _CONFIG_VARS['userbase'] = _getuserbase() - - if 'srcdir' not in _CONFIG_VARS: - _CONFIG_VARS['srcdir'] = _PROJECT_BASE - else: - _CONFIG_VARS['srcdir'] = _safe_realpath(_CONFIG_VARS['srcdir']) - - # Convert srcdir into an absolute path if it appears necessary. - # Normally it is relative to the build directory. However, during - # testing, for example, we might be running a non-installed python - # from a different directory. - if _PYTHON_BUILD and os.name == "posix": - base = _PROJECT_BASE - try: - cwd = os.getcwd() - except OSError: - cwd = None - if (not os.path.isabs(_CONFIG_VARS['srcdir']) and - base != cwd): - # srcdir is relative and we are not in the same directory - # as the executable. Assume executable is in the build - # directory and make srcdir absolute. - srcdir = os.path.join(base, _CONFIG_VARS['srcdir']) - _CONFIG_VARS['srcdir'] = os.path.normpath(srcdir) - - if sys.platform == 'darwin': - kernel_version = os.uname()[2] # Kernel version (8.4.3) - major_version = int(kernel_version.split('.')[0]) - - if major_version < 8: - # On Mac OS X before 10.4, check if -arch and -isysroot - # are in CFLAGS or LDFLAGS and remove them if they are. - # This is needed when building extensions on a 10.3 system - # using a universal build of python. - for key in ('LDFLAGS', 'BASECFLAGS', - # a number of derived variables. These need to be - # patched up as well. - 'CFLAGS', 'PY_CFLAGS', 'BLDSHARED'): - flags = _CONFIG_VARS[key] - flags = re.sub(r'-arch\s+\w+\s', ' ', flags) - flags = re.sub('-isysroot [^ \t]*', ' ', flags) - _CONFIG_VARS[key] = flags - else: - # Allow the user to override the architecture flags using - # an environment variable. - # NOTE: This name was introduced by Apple in OSX 10.5 and - # is used by several scripting languages distributed with - # that OS release. - if 'ARCHFLAGS' in os.environ: - arch = os.environ['ARCHFLAGS'] - for key in ('LDFLAGS', 'BASECFLAGS', - # a number of derived variables. These need to be - # patched up as well. - 'CFLAGS', 'PY_CFLAGS', 'BLDSHARED'): - - flags = _CONFIG_VARS[key] - flags = re.sub(r'-arch\s+\w+\s', ' ', flags) - flags = flags + ' ' + arch - _CONFIG_VARS[key] = flags - - # If we're on OSX 10.5 or later and the user tries to - # compiles an extension using an SDK that is not present - # on the current machine it is better to not use an SDK - # than to fail. - # - # The major usecase for this is users using a Python.org - # binary installer on OSX 10.6: that installer uses - # the 10.4u SDK, but that SDK is not installed by default - # when you install Xcode. - # - CFLAGS = _CONFIG_VARS.get('CFLAGS', '') - m = re.search(r'-isysroot\s+(\S+)', CFLAGS) - if m is not None: - sdk = m.group(1) - if not os.path.exists(sdk): - for key in ('LDFLAGS', 'BASECFLAGS', - # a number of derived variables. These need to be - # patched up as well. - 'CFLAGS', 'PY_CFLAGS', 'BLDSHARED'): - - flags = _CONFIG_VARS[key] - flags = re.sub(r'-isysroot\s+\S+(\s|$)', ' ', flags) - _CONFIG_VARS[key] = flags - - if args: - vals = [] - for name in args: - vals.append(_CONFIG_VARS.get(name)) - return vals - else: - return _CONFIG_VARS - - -def get_config_var(name): - """Return the value of a single variable using the dictionary returned by - 'get_config_vars()'. - - Equivalent to get_config_vars().get(name) - """ - return get_config_vars().get(name) - - -def get_platform(): - """Return a string that identifies the current platform. - - This is used mainly to distinguish platform-specific build directories and - platform-specific built distributions. Typically includes the OS name - and version and the architecture (as supplied by 'os.uname()'), - although the exact information included depends on the OS; eg. for IRIX - the architecture isn't particularly important (IRIX only runs on SGI - hardware), but for Linux the kernel version isn't particularly - important. - - Examples of returned values: - linux-i586 - linux-alpha (?) - solaris-2.6-sun4u - irix-5.3 - irix64-6.2 - - Windows will return one of: - win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc) - win-ia64 (64bit Windows on Itanium) - win32 (all others - specifically, sys.platform is returned) - - For other non-POSIX platforms, currently just returns 'sys.platform'. - """ - if os.name == 'nt': - # sniff sys.version for architecture. - prefix = " bit (" - i = sys.version.find(prefix) - if i == -1: - return sys.platform - j = sys.version.find(")", i) - look = sys.version[i+len(prefix):j].lower() - if look == 'amd64': - return 'win-amd64' - if look == 'itanium': - return 'win-ia64' - return sys.platform - - if os.name != "posix" or not hasattr(os, 'uname'): - # XXX what about the architecture? NT is Intel or Alpha, - # Mac OS is M68k or PPC, etc. - return sys.platform - - # Try to distinguish various flavours of Unix - osname, host, release, version, machine = os.uname() - - # Convert the OS name to lowercase, remove '/' characters - # (to accommodate BSD/OS), and translate spaces (for "Power Macintosh") - osname = osname.lower().replace('/', '') - machine = machine.replace(' ', '_') - machine = machine.replace('/', '-') - - if osname[:5] == "linux": - # At least on Linux/Intel, 'machine' is the processor -- - # i386, etc. - # XXX what about Alpha, SPARC, etc? - return "%s-%s" % (osname, machine) - elif osname[:5] == "sunos": - if release[0] >= "5": # SunOS 5 == Solaris 2 - osname = "solaris" - release = "%d.%s" % (int(release[0]) - 3, release[2:]) - # fall through to standard osname-release-machine representation - elif osname[:4] == "irix": # could be "irix64"! - return "%s-%s" % (osname, release) - elif osname[:3] == "aix": - return "%s-%s.%s" % (osname, version, release) - elif osname[:6] == "cygwin": - osname = "cygwin" - rel_re = re.compile(r'[\d.]+') - m = rel_re.match(release) - if m: - release = m.group() - elif osname[:6] == "darwin": - # - # For our purposes, we'll assume that the system version from - # distutils' perspective is what MACOSX_DEPLOYMENT_TARGET is set - # to. This makes the compatibility story a bit more sane because the - # machine is going to compile and link as if it were - # MACOSX_DEPLOYMENT_TARGET. - cfgvars = get_config_vars() - macver = cfgvars.get('MACOSX_DEPLOYMENT_TARGET') - - if True: - # Always calculate the release of the running machine, - # needed to determine if we can build fat binaries or not. - - macrelease = macver - # Get the system version. Reading this plist is a documented - # way to get the system version (see the documentation for - # the Gestalt Manager) - try: - f = open('/System/Library/CoreServices/SystemVersion.plist') - except IOError: - # We're on a plain darwin box, fall back to the default - # behaviour. - pass - else: - try: - m = re.search(r'<key>ProductUserVisibleVersion</key>\s*' - r'<string>(.*?)</string>', f.read()) - finally: - f.close() - if m is not None: - macrelease = '.'.join(m.group(1).split('.')[:2]) - # else: fall back to the default behaviour - - if not macver: - macver = macrelease - - if macver: - release = macver - osname = "macosx" - - if ((macrelease + '.') >= '10.4.' and - '-arch' in get_config_vars().get('CFLAGS', '').strip()): - # The universal build will build fat binaries, but not on - # systems before 10.4 - # - # Try to detect 4-way universal builds, those have machine-type - # 'universal' instead of 'fat'. - - machine = 'fat' - cflags = get_config_vars().get('CFLAGS') - - archs = re.findall(r'-arch\s+(\S+)', cflags) - archs = tuple(sorted(set(archs))) - - if len(archs) == 1: - machine = archs[0] - elif archs == ('i386', 'ppc'): - machine = 'fat' - elif archs == ('i386', 'x86_64'): - machine = 'intel' - elif archs == ('i386', 'ppc', 'x86_64'): - machine = 'fat3' - elif archs == ('ppc64', 'x86_64'): - machine = 'fat64' - elif archs == ('i386', 'ppc', 'ppc64', 'x86_64'): - machine = 'universal' - else: - raise ValueError( - "Don't know machine value for archs=%r" % (archs,)) - - elif machine == 'i386': - # On OSX the machine type returned by uname is always the - # 32-bit variant, even if the executable architecture is - # the 64-bit variant - if sys.maxsize >= 2**32: - machine = 'x86_64' - - elif machine in ('PowerPC', 'Power_Macintosh'): - # Pick a sane name for the PPC architecture. - # See 'i386' case - if sys.maxsize >= 2**32: - machine = 'ppc64' - else: - machine = 'ppc' - - return "%s-%s-%s" % (osname, release, machine) - - -def get_python_version(): - return _PY_VERSION_SHORT - - -def _print_dict(title, data): - for index, (key, value) in enumerate(sorted(data.items())): - if index == 0: - print('%s: ' % (title)) - print('\t%s = "%s"' % (key, value)) - - -def _main(): - """Display all information sysconfig detains.""" - print('Platform: "%s"' % get_platform()) - print('Python version: "%s"' % get_python_version()) - print('Current installation scheme: "%s"' % _get_default_scheme()) - print() - _print_dict('Paths', get_paths()) - print() - _print_dict('Variables', get_config_vars()) - - -if __name__ == '__main__': - _main() diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/tarfile.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/tarfile.py deleted file mode 100644 index d66d8566..00000000 --- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/tarfile.py +++ /dev/null @@ -1,2607 +0,0 @@ -#------------------------------------------------------------------- -# tarfile.py -#------------------------------------------------------------------- -# Copyright (C) 2002 Lars Gustaebel <lars@gustaebel.de> -# All rights reserved. -# -# Permission is hereby granted, free of charge, to any person -# obtaining a copy of this software and associated documentation -# files (the "Software"), to deal in the Software without -# restriction, including without limitation the rights to use, -# copy, modify, merge, publish, distribute, sublicense, and/or sell -# copies of the Software, and to permit persons to whom the -# Software is furnished to do so, subject to the following -# conditions: -# -# The above copyright notice and this permission notice shall be -# included in all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES -# OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND -# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT -# HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, -# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING -# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR -# OTHER DEALINGS IN THE SOFTWARE. -# -from __future__ import print_function - -"""Read from and write to tar format archives. -""" - -__version__ = "$Revision$" - -version = "0.9.0" -__author__ = "Lars Gust\u00e4bel (lars@gustaebel.de)" -__date__ = "$Date: 2011-02-25 17:42:01 +0200 (Fri, 25 Feb 2011) $" -__cvsid__ = "$Id: tarfile.py 88586 2011-02-25 15:42:01Z marc-andre.lemburg $" -__credits__ = "Gustavo Niemeyer, Niels Gust\u00e4bel, Richard Townsend." - -#--------- -# Imports -#--------- -import sys -import os -import stat -import errno -import time -import struct -import copy -import re - -try: - import grp, pwd -except ImportError: - grp = pwd = None - -# os.symlink on Windows prior to 6.0 raises NotImplementedError -symlink_exception = (AttributeError, NotImplementedError) -try: - # WindowsError (1314) will be raised if the caller does not hold the - # SeCreateSymbolicLinkPrivilege privilege - symlink_exception += (WindowsError,) -except NameError: - pass - -# from tarfile import * -__all__ = ["TarFile", "TarInfo", "is_tarfile", "TarError"] - -if sys.version_info[0] < 3: - import __builtin__ as builtins -else: - import builtins - -_open = builtins.open # Since 'open' is TarFile.open - -#--------------------------------------------------------- -# tar constants -#--------------------------------------------------------- -NUL = b"\0" # the null character -BLOCKSIZE = 512 # length of processing blocks -RECORDSIZE = BLOCKSIZE * 20 # length of records -GNU_MAGIC = b"ustar \0" # magic gnu tar string -POSIX_MAGIC = b"ustar\x0000" # magic posix tar string - -LENGTH_NAME = 100 # maximum length of a filename -LENGTH_LINK = 100 # maximum length of a linkname -LENGTH_PREFIX = 155 # maximum length of the prefix field - -REGTYPE = b"0" # regular file -AREGTYPE = b"\0" # regular file -LNKTYPE = b"1" # link (inside tarfile) -SYMTYPE = b"2" # symbolic link -CHRTYPE = b"3" # character special device -BLKTYPE = b"4" # block special device -DIRTYPE = b"5" # directory -FIFOTYPE = b"6" # fifo special device -CONTTYPE = b"7" # contiguous file - -GNUTYPE_LONGNAME = b"L" # GNU tar longname -GNUTYPE_LONGLINK = b"K" # GNU tar longlink -GNUTYPE_SPARSE = b"S" # GNU tar sparse file - -XHDTYPE = b"x" # POSIX.1-2001 extended header -XGLTYPE = b"g" # POSIX.1-2001 global header -SOLARIS_XHDTYPE = b"X" # Solaris extended header - -USTAR_FORMAT = 0 # POSIX.1-1988 (ustar) format -GNU_FORMAT = 1 # GNU tar format -PAX_FORMAT = 2 # POSIX.1-2001 (pax) format -DEFAULT_FORMAT = GNU_FORMAT - -#--------------------------------------------------------- -# tarfile constants -#--------------------------------------------------------- -# File types that tarfile supports: -SUPPORTED_TYPES = (REGTYPE, AREGTYPE, LNKTYPE, - SYMTYPE, DIRTYPE, FIFOTYPE, - CONTTYPE, CHRTYPE, BLKTYPE, - GNUTYPE_LONGNAME, GNUTYPE_LONGLINK, - GNUTYPE_SPARSE) - -# File types that will be treated as a regular file. -REGULAR_TYPES = (REGTYPE, AREGTYPE, - CONTTYPE, GNUTYPE_SPARSE) - -# File types that are part of the GNU tar format. -GNU_TYPES = (GNUTYPE_LONGNAME, GNUTYPE_LONGLINK, - GNUTYPE_SPARSE) - -# Fields from a pax header that override a TarInfo attribute. -PAX_FIELDS = ("path", "linkpath", "size", "mtime", - "uid", "gid", "uname", "gname") - -# Fields from a pax header that are affected by hdrcharset. -PAX_NAME_FIELDS = set(("path", "linkpath", "uname", "gname")) - -# Fields in a pax header that are numbers, all other fields -# are treated as strings. -PAX_NUMBER_FIELDS = { - "atime": float, - "ctime": float, - "mtime": float, - "uid": int, - "gid": int, - "size": int -} - -#--------------------------------------------------------- -# Bits used in the mode field, values in octal. -#--------------------------------------------------------- -S_IFLNK = 0o120000 # symbolic link -S_IFREG = 0o100000 # regular file -S_IFBLK = 0o060000 # block device -S_IFDIR = 0o040000 # directory -S_IFCHR = 0o020000 # character device -S_IFIFO = 0o010000 # fifo - -TSUID = 0o4000 # set UID on execution -TSGID = 0o2000 # set GID on execution -TSVTX = 0o1000 # reserved - -TUREAD = 0o400 # read by owner -TUWRITE = 0o200 # write by owner -TUEXEC = 0o100 # execute/search by owner -TGREAD = 0o040 # read by group -TGWRITE = 0o020 # write by group -TGEXEC = 0o010 # execute/search by group -TOREAD = 0o004 # read by other -TOWRITE = 0o002 # write by other -TOEXEC = 0o001 # execute/search by other - -#--------------------------------------------------------- -# initialization -#--------------------------------------------------------- -if os.name in ("nt", "ce"): - ENCODING = "utf-8" -else: - ENCODING = sys.getfilesystemencoding() - -#--------------------------------------------------------- -# Some useful functions -#--------------------------------------------------------- - -def stn(s, length, encoding, errors): - """Convert a string to a null-terminated bytes object. - """ - s = s.encode(encoding, errors) - return s[:length] + (length - len(s)) * NUL - -def nts(s, encoding, errors): - """Convert a null-terminated bytes object to a string. - """ - p = s.find(b"\0") - if p != -1: - s = s[:p] - return s.decode(encoding, errors) - -def nti(s): - """Convert a number field to a python number. - """ - # There are two possible encodings for a number field, see - # itn() below. - if s[0] != chr(0o200): - try: - n = int(nts(s, "ascii", "strict") or "0", 8) - except ValueError: - raise InvalidHeaderError("invalid header") - else: - n = 0 - for i in range(len(s) - 1): - n <<= 8 - n += ord(s[i + 1]) - return n - -def itn(n, digits=8, format=DEFAULT_FORMAT): - """Convert a python number to a number field. - """ - # POSIX 1003.1-1988 requires numbers to be encoded as a string of - # octal digits followed by a null-byte, this allows values up to - # (8**(digits-1))-1. GNU tar allows storing numbers greater than - # that if necessary. A leading 0o200 byte indicates this particular - # encoding, the following digits-1 bytes are a big-endian - # representation. This allows values up to (256**(digits-1))-1. - if 0 <= n < 8 ** (digits - 1): - s = ("%0*o" % (digits - 1, n)).encode("ascii") + NUL - else: - if format != GNU_FORMAT or n >= 256 ** (digits - 1): - raise ValueError("overflow in number field") - - if n < 0: - # XXX We mimic GNU tar's behaviour with negative numbers, - # this could raise OverflowError. - n = struct.unpack("L", struct.pack("l", n))[0] - - s = bytearray() - for i in range(digits - 1): - s.insert(0, n & 0o377) - n >>= 8 - s.insert(0, 0o200) - return s - -def calc_chksums(buf): - """Calculate the checksum for a member's header by summing up all - characters except for the chksum field which is treated as if - it was filled with spaces. According to the GNU tar sources, - some tars (Sun and NeXT) calculate chksum with signed char, - which will be different if there are chars in the buffer with - the high bit set. So we calculate two checksums, unsigned and - signed. - """ - unsigned_chksum = 256 + sum(struct.unpack("148B", buf[:148]) + struct.unpack("356B", buf[156:512])) - signed_chksum = 256 + sum(struct.unpack("148b", buf[:148]) + struct.unpack("356b", buf[156:512])) - return unsigned_chksum, signed_chksum - -def copyfileobj(src, dst, length=None): - """Copy length bytes from fileobj src to fileobj dst. - If length is None, copy the entire content. - """ - if length == 0: - return - if length is None: - while True: - buf = src.read(16*1024) - if not buf: - break - dst.write(buf) - return - - BUFSIZE = 16 * 1024 - blocks, remainder = divmod(length, BUFSIZE) - for b in range(blocks): - buf = src.read(BUFSIZE) - if len(buf) < BUFSIZE: - raise IOError("end of file reached") - dst.write(buf) - - if remainder != 0: - buf = src.read(remainder) - if len(buf) < remainder: - raise IOError("end of file reached") - dst.write(buf) - return - -filemode_table = ( - ((S_IFLNK, "l"), - (S_IFREG, "-"), - (S_IFBLK, "b"), - (S_IFDIR, "d"), - (S_IFCHR, "c"), - (S_IFIFO, "p")), - - ((TUREAD, "r"),), - ((TUWRITE, "w"),), - ((TUEXEC|TSUID, "s"), - (TSUID, "S"), - (TUEXEC, "x")), - - ((TGREAD, "r"),), - ((TGWRITE, "w"),), - ((TGEXEC|TSGID, "s"), - (TSGID, "S"), - (TGEXEC, "x")), - - ((TOREAD, "r"),), - ((TOWRITE, "w"),), - ((TOEXEC|TSVTX, "t"), - (TSVTX, "T"), - (TOEXEC, "x")) -) - -def filemode(mode): - """Convert a file's mode to a string of the form - -rwxrwxrwx. - Used by TarFile.list() - """ - perm = [] - for table in filemode_table: - for bit, char in table: - if mode & bit == bit: - perm.append(char) - break - else: - perm.append("-") - return "".join(perm) - -class TarError(Exception): - """Base exception.""" - pass -class ExtractError(TarError): - """General exception for extract errors.""" - pass -class ReadError(TarError): - """Exception for unreadable tar archives.""" - pass -class CompressionError(TarError): - """Exception for unavailable compression methods.""" - pass -class StreamError(TarError): - """Exception for unsupported operations on stream-like TarFiles.""" - pass -class HeaderError(TarError): - """Base exception for header errors.""" - pass -class EmptyHeaderError(HeaderError): - """Exception for empty headers.""" - pass -class TruncatedHeaderError(HeaderError): - """Exception for truncated headers.""" - pass -class EOFHeaderError(HeaderError): - """Exception for end of file headers.""" - pass -class InvalidHeaderError(HeaderError): - """Exception for invalid headers.""" - pass -class SubsequentHeaderError(HeaderError): - """Exception for missing and invalid extended headers.""" - pass - -#--------------------------- -# internal stream interface -#--------------------------- -class _LowLevelFile(object): - """Low-level file object. Supports reading and writing. - It is used instead of a regular file object for streaming - access. - """ - - def __init__(self, name, mode): - mode = { - "r": os.O_RDONLY, - "w": os.O_WRONLY | os.O_CREAT | os.O_TRUNC, - }[mode] - if hasattr(os, "O_BINARY"): - mode |= os.O_BINARY - self.fd = os.open(name, mode, 0o666) - - def close(self): - os.close(self.fd) - - def read(self, size): - return os.read(self.fd, size) - - def write(self, s): - os.write(self.fd, s) - -class _Stream(object): - """Class that serves as an adapter between TarFile and - a stream-like object. The stream-like object only - needs to have a read() or write() method and is accessed - blockwise. Use of gzip or bzip2 compression is possible. - A stream-like object could be for example: sys.stdin, - sys.stdout, a socket, a tape device etc. - - _Stream is intended to be used only internally. - """ - - def __init__(self, name, mode, comptype, fileobj, bufsize): - """Construct a _Stream object. - """ - self._extfileobj = True - if fileobj is None: - fileobj = _LowLevelFile(name, mode) - self._extfileobj = False - - if comptype == '*': - # Enable transparent compression detection for the - # stream interface - fileobj = _StreamProxy(fileobj) - comptype = fileobj.getcomptype() - - self.name = name or "" - self.mode = mode - self.comptype = comptype - self.fileobj = fileobj - self.bufsize = bufsize - self.buf = b"" - self.pos = 0 - self.closed = False - - try: - if comptype == "gz": - try: - import zlib - except ImportError: - raise CompressionError("zlib module is not available") - self.zlib = zlib - self.crc = zlib.crc32(b"") - if mode == "r": - self._init_read_gz() - else: - self._init_write_gz() - - if comptype == "bz2": - try: - import bz2 - except ImportError: - raise CompressionError("bz2 module is not available") - if mode == "r": - self.dbuf = b"" - self.cmp = bz2.BZ2Decompressor() - else: - self.cmp = bz2.BZ2Compressor() - except: - if not self._extfileobj: - self.fileobj.close() - self.closed = True - raise - - def __del__(self): - if hasattr(self, "closed") and not self.closed: - self.close() - - def _init_write_gz(self): - """Initialize for writing with gzip compression. - """ - self.cmp = self.zlib.compressobj(9, self.zlib.DEFLATED, - -self.zlib.MAX_WBITS, - self.zlib.DEF_MEM_LEVEL, - 0) - timestamp = struct.pack("<L", int(time.time())) - self.__write(b"\037\213\010\010" + timestamp + b"\002\377") - if self.name.endswith(".gz"): - self.name = self.name[:-3] - # RFC1952 says we must use ISO-8859-1 for the FNAME field. - self.__write(self.name.encode("iso-8859-1", "replace") + NUL) - - def write(self, s): - """Write string s to the stream. - """ - if self.comptype == "gz": - self.crc = self.zlib.crc32(s, self.crc) - self.pos += len(s) - if self.comptype != "tar": - s = self.cmp.compress(s) - self.__write(s) - - def __write(self, s): - """Write string s to the stream if a whole new block - is ready to be written. - """ - self.buf += s - while len(self.buf) > self.bufsize: - self.fileobj.write(self.buf[:self.bufsize]) - self.buf = self.buf[self.bufsize:] - - def close(self): - """Close the _Stream object. No operation should be - done on it afterwards. - """ - if self.closed: - return - - if self.mode == "w" and self.comptype != "tar": - self.buf += self.cmp.flush() - - if self.mode == "w" and self.buf: - self.fileobj.write(self.buf) - self.buf = b"" - if self.comptype == "gz": - # The native zlib crc is an unsigned 32-bit integer, but - # the Python wrapper implicitly casts that to a signed C - # long. So, on a 32-bit box self.crc may "look negative", - # while the same crc on a 64-bit box may "look positive". - # To avoid irksome warnings from the `struct` module, force - # it to look positive on all boxes. - self.fileobj.write(struct.pack("<L", self.crc & 0xffffffff)) - self.fileobj.write(struct.pack("<L", self.pos & 0xffffFFFF)) - - if not self._extfileobj: - self.fileobj.close() - - self.closed = True - - def _init_read_gz(self): - """Initialize for reading a gzip compressed fileobj. - """ - self.cmp = self.zlib.decompressobj(-self.zlib.MAX_WBITS) - self.dbuf = b"" - - # taken from gzip.GzipFile with some alterations - if self.__read(2) != b"\037\213": - raise ReadError("not a gzip file") - if self.__read(1) != b"\010": - raise CompressionError("unsupported compression method") - - flag = ord(self.__read(1)) - self.__read(6) - - if flag & 4: - xlen = ord(self.__read(1)) + 256 * ord(self.__read(1)) - self.read(xlen) - if flag & 8: - while True: - s = self.__read(1) - if not s or s == NUL: - break - if flag & 16: - while True: - s = self.__read(1) - if not s or s == NUL: - break - if flag & 2: - self.__read(2) - - def tell(self): - """Return the stream's file pointer position. - """ - return self.pos - - def seek(self, pos=0): - """Set the stream's file pointer to pos. Negative seeking - is forbidden. - """ - if pos - self.pos >= 0: - blocks, remainder = divmod(pos - self.pos, self.bufsize) - for i in range(blocks): - self.read(self.bufsize) - self.read(remainder) - else: - raise StreamError("seeking backwards is not allowed") - return self.pos - - def read(self, size=None): - """Return the next size number of bytes from the stream. - If size is not defined, return all bytes of the stream - up to EOF. - """ - if size is None: - t = [] - while True: - buf = self._read(self.bufsize) - if not buf: - break - t.append(buf) - buf = "".join(t) - else: - buf = self._read(size) - self.pos += len(buf) - return buf - - def _read(self, size): - """Return size bytes from the stream. - """ - if self.comptype == "tar": - return self.__read(size) - - c = len(self.dbuf) - while c < size: - buf = self.__read(self.bufsize) - if not buf: - break - try: - buf = self.cmp.decompress(buf) - except IOError: - raise ReadError("invalid compressed data") - self.dbuf += buf - c += len(buf) - buf = self.dbuf[:size] - self.dbuf = self.dbuf[size:] - return buf - - def __read(self, size): - """Return size bytes from stream. If internal buffer is empty, - read another block from the stream. - """ - c = len(self.buf) - while c < size: - buf = self.fileobj.read(self.bufsize) - if not buf: - break - self.buf += buf - c += len(buf) - buf = self.buf[:size] - self.buf = self.buf[size:] - return buf -# class _Stream - -class _StreamProxy(object): - """Small proxy class that enables transparent compression - detection for the Stream interface (mode 'r|*'). - """ - - def __init__(self, fileobj): - self.fileobj = fileobj - self.buf = self.fileobj.read(BLOCKSIZE) - - def read(self, size): - self.read = self.fileobj.read - return self.buf - - def getcomptype(self): - if self.buf.startswith(b"\037\213\010"): - return "gz" - if self.buf.startswith(b"BZh91"): - return "bz2" - return "tar" - - def close(self): - self.fileobj.close() -# class StreamProxy - -class _BZ2Proxy(object): - """Small proxy class that enables external file object - support for "r:bz2" and "w:bz2" modes. This is actually - a workaround for a limitation in bz2 module's BZ2File - class which (unlike gzip.GzipFile) has no support for - a file object argument. - """ - - blocksize = 16 * 1024 - - def __init__(self, fileobj, mode): - self.fileobj = fileobj - self.mode = mode - self.name = getattr(self.fileobj, "name", None) - self.init() - - def init(self): - import bz2 - self.pos = 0 - if self.mode == "r": - self.bz2obj = bz2.BZ2Decompressor() - self.fileobj.seek(0) - self.buf = b"" - else: - self.bz2obj = bz2.BZ2Compressor() - - def read(self, size): - x = len(self.buf) - while x < size: - raw = self.fileobj.read(self.blocksize) - if not raw: - break - data = self.bz2obj.decompress(raw) - self.buf += data - x += len(data) - - buf = self.buf[:size] - self.buf = self.buf[size:] - self.pos += len(buf) - return buf - - def seek(self, pos): - if pos < self.pos: - self.init() - self.read(pos - self.pos) - - def tell(self): - return self.pos - - def write(self, data): - self.pos += len(data) - raw = self.bz2obj.compress(data) - self.fileobj.write(raw) - - def close(self): - if self.mode == "w": - raw = self.bz2obj.flush() - self.fileobj.write(raw) -# class _BZ2Proxy - -#------------------------ -# Extraction file object -#------------------------ -class _FileInFile(object): - """A thin wrapper around an existing file object that - provides a part of its data as an individual file - object. - """ - - def __init__(self, fileobj, offset, size, blockinfo=None): - self.fileobj = fileobj - self.offset = offset - self.size = size - self.position = 0 - - if blockinfo is None: - blockinfo = [(0, size)] - - # Construct a map with data and zero blocks. - self.map_index = 0 - self.map = [] - lastpos = 0 - realpos = self.offset - for offset, size in blockinfo: - if offset > lastpos: - self.map.append((False, lastpos, offset, None)) - self.map.append((True, offset, offset + size, realpos)) - realpos += size - lastpos = offset + size - if lastpos < self.size: - self.map.append((False, lastpos, self.size, None)) - - def seekable(self): - if not hasattr(self.fileobj, "seekable"): - # XXX gzip.GzipFile and bz2.BZ2File - return True - return self.fileobj.seekable() - - def tell(self): - """Return the current file position. - """ - return self.position - - def seek(self, position): - """Seek to a position in the file. - """ - self.position = position - - def read(self, size=None): - """Read data from the file. - """ - if size is None: - size = self.size - self.position - else: - size = min(size, self.size - self.position) - - buf = b"" - while size > 0: - while True: - data, start, stop, offset = self.map[self.map_index] - if start <= self.position < stop: - break - else: - self.map_index += 1 - if self.map_index == len(self.map): - self.map_index = 0 - length = min(size, stop - self.position) - if data: - self.fileobj.seek(offset + (self.position - start)) - buf += self.fileobj.read(length) - else: - buf += NUL * length - size -= length - self.position += length - return buf -#class _FileInFile - - -class ExFileObject(object): - """File-like object for reading an archive member. - Is returned by TarFile.extractfile(). - """ - blocksize = 1024 - - def __init__(self, tarfile, tarinfo): - self.fileobj = _FileInFile(tarfile.fileobj, - tarinfo.offset_data, - tarinfo.size, - tarinfo.sparse) - self.name = tarinfo.name - self.mode = "r" - self.closed = False - self.size = tarinfo.size - - self.position = 0 - self.buffer = b"" - - def readable(self): - return True - - def writable(self): - return False - - def seekable(self): - return self.fileobj.seekable() - - def read(self, size=None): - """Read at most size bytes from the file. If size is not - present or None, read all data until EOF is reached. - """ - if self.closed: - raise ValueError("I/O operation on closed file") - - buf = b"" - if self.buffer: - if size is None: - buf = self.buffer - self.buffer = b"" - else: - buf = self.buffer[:size] - self.buffer = self.buffer[size:] - - if size is None: - buf += self.fileobj.read() - else: - buf += self.fileobj.read(size - len(buf)) - - self.position += len(buf) - return buf - - # XXX TextIOWrapper uses the read1() method. - read1 = read - - def readline(self, size=-1): - """Read one entire line from the file. If size is present - and non-negative, return a string with at most that - size, which may be an incomplete line. - """ - if self.closed: - raise ValueError("I/O operation on closed file") - - pos = self.buffer.find(b"\n") + 1 - if pos == 0: - # no newline found. - while True: - buf = self.fileobj.read(self.blocksize) - self.buffer += buf - if not buf or b"\n" in buf: - pos = self.buffer.find(b"\n") + 1 - if pos == 0: - # no newline found. - pos = len(self.buffer) - break - - if size != -1: - pos = min(size, pos) - - buf = self.buffer[:pos] - self.buffer = self.buffer[pos:] - self.position += len(buf) - return buf - - def readlines(self): - """Return a list with all remaining lines. - """ - result = [] - while True: - line = self.readline() - if not line: break - result.append(line) - return result - - def tell(self): - """Return the current file position. - """ - if self.closed: - raise ValueError("I/O operation on closed file") - - return self.position - - def seek(self, pos, whence=os.SEEK_SET): - """Seek to a position in the file. - """ - if self.closed: - raise ValueError("I/O operation on closed file") - - if whence == os.SEEK_SET: - self.position = min(max(pos, 0), self.size) - elif whence == os.SEEK_CUR: - if pos < 0: - self.position = max(self.position + pos, 0) - else: - self.position = min(self.position + pos, self.size) - elif whence == os.SEEK_END: - self.position = max(min(self.size + pos, self.size), 0) - else: - raise ValueError("Invalid argument") - - self.buffer = b"" - self.fileobj.seek(self.position) - - def close(self): - """Close the file object. - """ - self.closed = True - - def __iter__(self): - """Get an iterator over the file's lines. - """ - while True: - line = self.readline() - if not line: - break - yield line -#class ExFileObject - -#------------------ -# Exported Classes -#------------------ -class TarInfo(object): - """Informational class which holds the details about an - archive member given by a tar header block. - TarInfo objects are returned by TarFile.getmember(), - TarFile.getmembers() and TarFile.gettarinfo() and are - usually created internally. - """ - - __slots__ = ("name", "mode", "uid", "gid", "size", "mtime", - "chksum", "type", "linkname", "uname", "gname", - "devmajor", "devminor", - "offset", "offset_data", "pax_headers", "sparse", - "tarfile", "_sparse_structs", "_link_target") - - def __init__(self, name=""): - """Construct a TarInfo object. name is the optional name - of the member. - """ - self.name = name # member name - self.mode = 0o644 # file permissions - self.uid = 0 # user id - self.gid = 0 # group id - self.size = 0 # file size - self.mtime = 0 # modification time - self.chksum = 0 # header checksum - self.type = REGTYPE # member type - self.linkname = "" # link name - self.uname = "" # user name - self.gname = "" # group name - self.devmajor = 0 # device major number - self.devminor = 0 # device minor number - - self.offset = 0 # the tar header starts here - self.offset_data = 0 # the file's data starts here - - self.sparse = None # sparse member information - self.pax_headers = {} # pax header information - - # In pax headers the "name" and "linkname" field are called - # "path" and "linkpath". - def _getpath(self): - return self.name - def _setpath(self, name): - self.name = name - path = property(_getpath, _setpath) - - def _getlinkpath(self): - return self.linkname - def _setlinkpath(self, linkname): - self.linkname = linkname - linkpath = property(_getlinkpath, _setlinkpath) - - def __repr__(self): - return "<%s %r at %#x>" % (self.__class__.__name__,self.name,id(self)) - - def get_info(self): - """Return the TarInfo's attributes as a dictionary. - """ - info = { - "name": self.name, - "mode": self.mode & 0o7777, - "uid": self.uid, - "gid": self.gid, - "size": self.size, - "mtime": self.mtime, - "chksum": self.chksum, - "type": self.type, - "linkname": self.linkname, - "uname": self.uname, - "gname": self.gname, - "devmajor": self.devmajor, - "devminor": self.devminor - } - - if info["type"] == DIRTYPE and not info["name"].endswith("/"): - info["name"] += "/" - - return info - - def tobuf(self, format=DEFAULT_FORMAT, encoding=ENCODING, errors="surrogateescape"): - """Return a tar header as a string of 512 byte blocks. - """ - info = self.get_info() - - if format == USTAR_FORMAT: - return self.create_ustar_header(info, encoding, errors) - elif format == GNU_FORMAT: - return self.create_gnu_header(info, encoding, errors) - elif format == PAX_FORMAT: - return self.create_pax_header(info, encoding) - else: - raise ValueError("invalid format") - - def create_ustar_header(self, info, encoding, errors): - """Return the object as a ustar header block. - """ - info["magic"] = POSIX_MAGIC - - if len(info["linkname"]) > LENGTH_LINK: - raise ValueError("linkname is too long") - - if len(info["name"]) > LENGTH_NAME: - info["prefix"], info["name"] = self._posix_split_name(info["name"]) - - return self._create_header(info, USTAR_FORMAT, encoding, errors) - - def create_gnu_header(self, info, encoding, errors): - """Return the object as a GNU header block sequence. - """ - info["magic"] = GNU_MAGIC - - buf = b"" - if len(info["linkname"]) > LENGTH_LINK: - buf += self._create_gnu_long_header(info["linkname"], GNUTYPE_LONGLINK, encoding, errors) - - if len(info["name"]) > LENGTH_NAME: - buf += self._create_gnu_long_header(info["name"], GNUTYPE_LONGNAME, encoding, errors) - - return buf + self._create_header(info, GNU_FORMAT, encoding, errors) - - def create_pax_header(self, info, encoding): - """Return the object as a ustar header block. If it cannot be - represented this way, prepend a pax extended header sequence - with supplement information. - """ - info["magic"] = POSIX_MAGIC - pax_headers = self.pax_headers.copy() - - # Test string fields for values that exceed the field length or cannot - # be represented in ASCII encoding. - for name, hname, length in ( - ("name", "path", LENGTH_NAME), ("linkname", "linkpath", LENGTH_LINK), - ("uname", "uname", 32), ("gname", "gname", 32)): - - if hname in pax_headers: - # The pax header has priority. - continue - - # Try to encode the string as ASCII. - try: - info[name].encode("ascii", "strict") - except UnicodeEncodeError: - pax_headers[hname] = info[name] - continue - - if len(info[name]) > length: - pax_headers[hname] = info[name] - - # Test number fields for values that exceed the field limit or values - # that like to be stored as float. - for name, digits in (("uid", 8), ("gid", 8), ("size", 12), ("mtime", 12)): - if name in pax_headers: - # The pax header has priority. Avoid overflow. - info[name] = 0 - continue - - val = info[name] - if not 0 <= val < 8 ** (digits - 1) or isinstance(val, float): - pax_headers[name] = str(val) - info[name] = 0 - - # Create a pax extended header if necessary. - if pax_headers: - buf = self._create_pax_generic_header(pax_headers, XHDTYPE, encoding) - else: - buf = b"" - - return buf + self._create_header(info, USTAR_FORMAT, "ascii", "replace") - - @classmethod - def create_pax_global_header(cls, pax_headers): - """Return the object as a pax global header block sequence. - """ - return cls._create_pax_generic_header(pax_headers, XGLTYPE, "utf8") - - def _posix_split_name(self, name): - """Split a name longer than 100 chars into a prefix - and a name part. - """ - prefix = name[:LENGTH_PREFIX + 1] - while prefix and prefix[-1] != "/": - prefix = prefix[:-1] - - name = name[len(prefix):] - prefix = prefix[:-1] - - if not prefix or len(name) > LENGTH_NAME: - raise ValueError("name is too long") - return prefix, name - - @staticmethod - def _create_header(info, format, encoding, errors): - """Return a header block. info is a dictionary with file - information, format must be one of the *_FORMAT constants. - """ - parts = [ - stn(info.get("name", ""), 100, encoding, errors), - itn(info.get("mode", 0) & 0o7777, 8, format), - itn(info.get("uid", 0), 8, format), - itn(info.get("gid", 0), 8, format), - itn(info.get("size", 0), 12, format), - itn(info.get("mtime", 0), 12, format), - b" ", # checksum field - info.get("type", REGTYPE), - stn(info.get("linkname", ""), 100, encoding, errors), - info.get("magic", POSIX_MAGIC), - stn(info.get("uname", ""), 32, encoding, errors), - stn(info.get("gname", ""), 32, encoding, errors), - itn(info.get("devmajor", 0), 8, format), - itn(info.get("devminor", 0), 8, format), - stn(info.get("prefix", ""), 155, encoding, errors) - ] - - buf = struct.pack("%ds" % BLOCKSIZE, b"".join(parts)) - chksum = calc_chksums(buf[-BLOCKSIZE:])[0] - buf = buf[:-364] + ("%06o\0" % chksum).encode("ascii") + buf[-357:] - return buf - - @staticmethod - def _create_payload(payload): - """Return the string payload filled with zero bytes - up to the next 512 byte border. - """ - blocks, remainder = divmod(len(payload), BLOCKSIZE) - if remainder > 0: - payload += (BLOCKSIZE - remainder) * NUL - return payload - - @classmethod - def _create_gnu_long_header(cls, name, type, encoding, errors): - """Return a GNUTYPE_LONGNAME or GNUTYPE_LONGLINK sequence - for name. - """ - name = name.encode(encoding, errors) + NUL - - info = {} - info["name"] = "././@LongLink" - info["type"] = type - info["size"] = len(name) - info["magic"] = GNU_MAGIC - - # create extended header + name blocks. - return cls._create_header(info, USTAR_FORMAT, encoding, errors) + \ - cls._create_payload(name) - - @classmethod - def _create_pax_generic_header(cls, pax_headers, type, encoding): - """Return a POSIX.1-2008 extended or global header sequence - that contains a list of keyword, value pairs. The values - must be strings. - """ - # Check if one of the fields contains surrogate characters and thereby - # forces hdrcharset=BINARY, see _proc_pax() for more information. - binary = False - for keyword, value in pax_headers.items(): - try: - value.encode("utf8", "strict") - except UnicodeEncodeError: - binary = True - break - - records = b"" - if binary: - # Put the hdrcharset field at the beginning of the header. - records += b"21 hdrcharset=BINARY\n" - - for keyword, value in pax_headers.items(): - keyword = keyword.encode("utf8") - if binary: - # Try to restore the original byte representation of `value'. - # Needless to say, that the encoding must match the string. - value = value.encode(encoding, "surrogateescape") - else: - value = value.encode("utf8") - - l = len(keyword) + len(value) + 3 # ' ' + '=' + '\n' - n = p = 0 - while True: - n = l + len(str(p)) - if n == p: - break - p = n - records += bytes(str(p), "ascii") + b" " + keyword + b"=" + value + b"\n" - - # We use a hardcoded "././@PaxHeader" name like star does - # instead of the one that POSIX recommends. - info = {} - info["name"] = "././@PaxHeader" - info["type"] = type - info["size"] = len(records) - info["magic"] = POSIX_MAGIC - - # Create pax header + record blocks. - return cls._create_header(info, USTAR_FORMAT, "ascii", "replace") + \ - cls._create_payload(records) - - @classmethod - def frombuf(cls, buf, encoding, errors): - """Construct a TarInfo object from a 512 byte bytes object. - """ - if len(buf) == 0: - raise EmptyHeaderError("empty header") - if len(buf) != BLOCKSIZE: - raise TruncatedHeaderError("truncated header") - if buf.count(NUL) == BLOCKSIZE: - raise EOFHeaderError("end of file header") - - chksum = nti(buf[148:156]) - if chksum not in calc_chksums(buf): - raise InvalidHeaderError("bad checksum") - - obj = cls() - obj.name = nts(buf[0:100], encoding, errors) - obj.mode = nti(buf[100:108]) - obj.uid = nti(buf[108:116]) - obj.gid = nti(buf[116:124]) - obj.size = nti(buf[124:136]) - obj.mtime = nti(buf[136:148]) - obj.chksum = chksum - obj.type = buf[156:157] - obj.linkname = nts(buf[157:257], encoding, errors) - obj.uname = nts(buf[265:297], encoding, errors) - obj.gname = nts(buf[297:329], encoding, errors) - obj.devmajor = nti(buf[329:337]) - obj.devminor = nti(buf[337:345]) - prefix = nts(buf[345:500], encoding, errors) - - # Old V7 tar format represents a directory as a regular - # file with a trailing slash. - if obj.type == AREGTYPE and obj.name.endswith("/"): - obj.type = DIRTYPE - - # The old GNU sparse format occupies some of the unused - # space in the buffer for up to 4 sparse structures. - # Save the them for later processing in _proc_sparse(). - if obj.type == GNUTYPE_SPARSE: - pos = 386 - structs = [] - for i in range(4): - try: - offset = nti(buf[pos:pos + 12]) - numbytes = nti(buf[pos + 12:pos + 24]) - except ValueError: - break - structs.append((offset, numbytes)) - pos += 24 - isextended = bool(buf[482]) - origsize = nti(buf[483:495]) - obj._sparse_structs = (structs, isextended, origsize) - - # Remove redundant slashes from directories. - if obj.isdir(): - obj.name = obj.name.rstrip("/") - - # Reconstruct a ustar longname. - if prefix and obj.type not in GNU_TYPES: - obj.name = prefix + "/" + obj.name - return obj - - @classmethod - def fromtarfile(cls, tarfile): - """Return the next TarInfo object from TarFile object - tarfile. - """ - buf = tarfile.fileobj.read(BLOCKSIZE) - obj = cls.frombuf(buf, tarfile.encoding, tarfile.errors) - obj.offset = tarfile.fileobj.tell() - BLOCKSIZE - return obj._proc_member(tarfile) - - #-------------------------------------------------------------------------- - # The following are methods that are called depending on the type of a - # member. The entry point is _proc_member() which can be overridden in a - # subclass to add custom _proc_*() methods. A _proc_*() method MUST - # implement the following - # operations: - # 1. Set self.offset_data to the position where the data blocks begin, - # if there is data that follows. - # 2. Set tarfile.offset to the position where the next member's header will - # begin. - # 3. Return self or another valid TarInfo object. - def _proc_member(self, tarfile): - """Choose the right processing method depending on - the type and call it. - """ - if self.type in (GNUTYPE_LONGNAME, GNUTYPE_LONGLINK): - return self._proc_gnulong(tarfile) - elif self.type == GNUTYPE_SPARSE: - return self._proc_sparse(tarfile) - elif self.type in (XHDTYPE, XGLTYPE, SOLARIS_XHDTYPE): - return self._proc_pax(tarfile) - else: - return self._proc_builtin(tarfile) - - def _proc_builtin(self, tarfile): - """Process a builtin type or an unknown type which - will be treated as a regular file. - """ - self.offset_data = tarfile.fileobj.tell() - offset = self.offset_data - if self.isreg() or self.type not in SUPPORTED_TYPES: - # Skip the following data blocks. - offset += self._block(self.size) - tarfile.offset = offset - - # Patch the TarInfo object with saved global - # header information. - self._apply_pax_info(tarfile.pax_headers, tarfile.encoding, tarfile.errors) - - return self - - def _proc_gnulong(self, tarfile): - """Process the blocks that hold a GNU longname - or longlink member. - """ - buf = tarfile.fileobj.read(self._block(self.size)) - - # Fetch the next header and process it. - try: - next = self.fromtarfile(tarfile) - except HeaderError: - raise SubsequentHeaderError("missing or bad subsequent header") - - # Patch the TarInfo object from the next header with - # the longname information. - next.offset = self.offset - if self.type == GNUTYPE_LONGNAME: - next.name = nts(buf, tarfile.encoding, tarfile.errors) - elif self.type == GNUTYPE_LONGLINK: - next.linkname = nts(buf, tarfile.encoding, tarfile.errors) - - return next - - def _proc_sparse(self, tarfile): - """Process a GNU sparse header plus extra headers. - """ - # We already collected some sparse structures in frombuf(). - structs, isextended, origsize = self._sparse_structs - del self._sparse_structs - - # Collect sparse structures from extended header blocks. - while isextended: - buf = tarfile.fileobj.read(BLOCKSIZE) - pos = 0 - for i in range(21): - try: - offset = nti(buf[pos:pos + 12]) - numbytes = nti(buf[pos + 12:pos + 24]) - except ValueError: - break - if offset and numbytes: - structs.append((offset, numbytes)) - pos += 24 - isextended = bool(buf[504]) - self.sparse = structs - - self.offset_data = tarfile.fileobj.tell() - tarfile.offset = self.offset_data + self._block(self.size) - self.size = origsize - return self - - def _proc_pax(self, tarfile): - """Process an extended or global header as described in - POSIX.1-2008. - """ - # Read the header information. - buf = tarfile.fileobj.read(self._block(self.size)) - - # A pax header stores supplemental information for either - # the following file (extended) or all following files - # (global). - if self.type == XGLTYPE: - pax_headers = tarfile.pax_headers - else: - pax_headers = tarfile.pax_headers.copy() - - # Check if the pax header contains a hdrcharset field. This tells us - # the encoding of the path, linkpath, uname and gname fields. Normally, - # these fields are UTF-8 encoded but since POSIX.1-2008 tar - # implementations are allowed to store them as raw binary strings if - # the translation to UTF-8 fails. - match = re.search(br"\d+ hdrcharset=([^\n]+)\n", buf) - if match is not None: - pax_headers["hdrcharset"] = match.group(1).decode("utf8") - - # For the time being, we don't care about anything other than "BINARY". - # The only other value that is currently allowed by the standard is - # "ISO-IR 10646 2000 UTF-8" in other words UTF-8. - hdrcharset = pax_headers.get("hdrcharset") - if hdrcharset == "BINARY": - encoding = tarfile.encoding - else: - encoding = "utf8" - - # Parse pax header information. A record looks like that: - # "%d %s=%s\n" % (length, keyword, value). length is the size - # of the complete record including the length field itself and - # the newline. keyword and value are both UTF-8 encoded strings. - regex = re.compile(br"(\d+) ([^=]+)=") - pos = 0 - while True: - match = regex.match(buf, pos) - if not match: - break - - length, keyword = match.groups() - length = int(length) - value = buf[match.end(2) + 1:match.start(1) + length - 1] - - # Normally, we could just use "utf8" as the encoding and "strict" - # as the error handler, but we better not take the risk. For - # example, GNU tar <= 1.23 is known to store filenames it cannot - # translate to UTF-8 as raw strings (unfortunately without a - # hdrcharset=BINARY header). - # We first try the strict standard encoding, and if that fails we - # fall back on the user's encoding and error handler. - keyword = self._decode_pax_field(keyword, "utf8", "utf8", - tarfile.errors) - if keyword in PAX_NAME_FIELDS: - value = self._decode_pax_field(value, encoding, tarfile.encoding, - tarfile.errors) - else: - value = self._decode_pax_field(value, "utf8", "utf8", - tarfile.errors) - - pax_headers[keyword] = value - pos += length - - # Fetch the next header. - try: - next = self.fromtarfile(tarfile) - except HeaderError: - raise SubsequentHeaderError("missing or bad subsequent header") - - # Process GNU sparse information. - if "GNU.sparse.map" in pax_headers: - # GNU extended sparse format version 0.1. - self._proc_gnusparse_01(next, pax_headers) - - elif "GNU.sparse.size" in pax_headers: - # GNU extended sparse format version 0.0. - self._proc_gnusparse_00(next, pax_headers, buf) - - elif pax_headers.get("GNU.sparse.major") == "1" and pax_headers.get("GNU.sparse.minor") == "0": - # GNU extended sparse format version 1.0. - self._proc_gnusparse_10(next, pax_headers, tarfile) - - if self.type in (XHDTYPE, SOLARIS_XHDTYPE): - # Patch the TarInfo object with the extended header info. - next._apply_pax_info(pax_headers, tarfile.encoding, tarfile.errors) - next.offset = self.offset - - if "size" in pax_headers: - # If the extended header replaces the size field, - # we need to recalculate the offset where the next - # header starts. - offset = next.offset_data - if next.isreg() or next.type not in SUPPORTED_TYPES: - offset += next._block(next.size) - tarfile.offset = offset - - return next - - def _proc_gnusparse_00(self, next, pax_headers, buf): - """Process a GNU tar extended sparse header, version 0.0. - """ - offsets = [] - for match in re.finditer(br"\d+ GNU.sparse.offset=(\d+)\n", buf): - offsets.append(int(match.group(1))) - numbytes = [] - for match in re.finditer(br"\d+ GNU.sparse.numbytes=(\d+)\n", buf): - numbytes.append(int(match.group(1))) - next.sparse = list(zip(offsets, numbytes)) - - def _proc_gnusparse_01(self, next, pax_headers): - """Process a GNU tar extended sparse header, version 0.1. - """ - sparse = [int(x) for x in pax_headers["GNU.sparse.map"].split(",")] - next.sparse = list(zip(sparse[::2], sparse[1::2])) - - def _proc_gnusparse_10(self, next, pax_headers, tarfile): - """Process a GNU tar extended sparse header, version 1.0. - """ - fields = None - sparse = [] - buf = tarfile.fileobj.read(BLOCKSIZE) - fields, buf = buf.split(b"\n", 1) - fields = int(fields) - while len(sparse) < fields * 2: - if b"\n" not in buf: - buf += tarfile.fileobj.read(BLOCKSIZE) - number, buf = buf.split(b"\n", 1) - sparse.append(int(number)) - next.offset_data = tarfile.fileobj.tell() - next.sparse = list(zip(sparse[::2], sparse[1::2])) - - def _apply_pax_info(self, pax_headers, encoding, errors): - """Replace fields with supplemental information from a previous - pax extended or global header. - """ - for keyword, value in pax_headers.items(): - if keyword == "GNU.sparse.name": - setattr(self, "path", value) - elif keyword == "GNU.sparse.size": - setattr(self, "size", int(value)) - elif keyword == "GNU.sparse.realsize": - setattr(self, "size", int(value)) - elif keyword in PAX_FIELDS: - if keyword in PAX_NUMBER_FIELDS: - try: - value = PAX_NUMBER_FIELDS[keyword](value) - except ValueError: - value = 0 - if keyword == "path": - value = value.rstrip("/") - setattr(self, keyword, value) - - self.pax_headers = pax_headers.copy() - - def _decode_pax_field(self, value, encoding, fallback_encoding, fallback_errors): - """Decode a single field from a pax record. - """ - try: - return value.decode(encoding, "strict") - except UnicodeDecodeError: - return value.decode(fallback_encoding, fallback_errors) - - def _block(self, count): - """Round up a byte count by BLOCKSIZE and return it, - e.g. _block(834) => 1024. - """ - blocks, remainder = divmod(count, BLOCKSIZE) - if remainder: - blocks += 1 - return blocks * BLOCKSIZE - - def isreg(self): - return self.type in REGULAR_TYPES - def isfile(self): - return self.isreg() - def isdir(self): - return self.type == DIRTYPE - def issym(self): - return self.type == SYMTYPE - def islnk(self): - return self.type == LNKTYPE - def ischr(self): - return self.type == CHRTYPE - def isblk(self): - return self.type == BLKTYPE - def isfifo(self): - return self.type == FIFOTYPE - def issparse(self): - return self.sparse is not None - def isdev(self): - return self.type in (CHRTYPE, BLKTYPE, FIFOTYPE) -# class TarInfo - -class TarFile(object): - """The TarFile Class provides an interface to tar archives. - """ - - debug = 0 # May be set from 0 (no msgs) to 3 (all msgs) - - dereference = False # If true, add content of linked file to the - # tar file, else the link. - - ignore_zeros = False # If true, skips empty or invalid blocks and - # continues processing. - - errorlevel = 1 # If 0, fatal errors only appear in debug - # messages (if debug >= 0). If > 0, errors - # are passed to the caller as exceptions. - - format = DEFAULT_FORMAT # The format to use when creating an archive. - - encoding = ENCODING # Encoding for 8-bit character strings. - - errors = None # Error handler for unicode conversion. - - tarinfo = TarInfo # The default TarInfo class to use. - - fileobject = ExFileObject # The default ExFileObject class to use. - - def __init__(self, name=None, mode="r", fileobj=None, format=None, - tarinfo=None, dereference=None, ignore_zeros=None, encoding=None, - errors="surrogateescape", pax_headers=None, debug=None, errorlevel=None): - """Open an (uncompressed) tar archive `name'. `mode' is either 'r' to - read from an existing archive, 'a' to append data to an existing - file or 'w' to create a new file overwriting an existing one. `mode' - defaults to 'r'. - If `fileobj' is given, it is used for reading or writing data. If it - can be determined, `mode' is overridden by `fileobj's mode. - `fileobj' is not closed, when TarFile is closed. - """ - if len(mode) > 1 or mode not in "raw": - raise ValueError("mode must be 'r', 'a' or 'w'") - self.mode = mode - self._mode = {"r": "rb", "a": "r+b", "w": "wb"}[mode] - - if not fileobj: - if self.mode == "a" and not os.path.exists(name): - # Create nonexistent files in append mode. - self.mode = "w" - self._mode = "wb" - fileobj = bltn_open(name, self._mode) - self._extfileobj = False - else: - if name is None and hasattr(fileobj, "name"): - name = fileobj.name - if hasattr(fileobj, "mode"): - self._mode = fileobj.mode - self._extfileobj = True - self.name = os.path.abspath(name) if name else None - self.fileobj = fileobj - - # Init attributes. - if format is not None: - self.format = format - if tarinfo is not None: - self.tarinfo = tarinfo - if dereference is not None: - self.dereference = dereference - if ignore_zeros is not None: - self.ignore_zeros = ignore_zeros - if encoding is not None: - self.encoding = encoding - self.errors = errors - - if pax_headers is not None and self.format == PAX_FORMAT: - self.pax_headers = pax_headers - else: - self.pax_headers = {} - - if debug is not None: - self.debug = debug - if errorlevel is not None: - self.errorlevel = errorlevel - - # Init datastructures. - self.closed = False - self.members = [] # list of members as TarInfo objects - self._loaded = False # flag if all members have been read - self.offset = self.fileobj.tell() - # current position in the archive file - self.inodes = {} # dictionary caching the inodes of - # archive members already added - - try: - if self.mode == "r": - self.firstmember = None - self.firstmember = self.next() - - if self.mode == "a": - # Move to the end of the archive, - # before the first empty block. - while True: - self.fileobj.seek(self.offset) - try: - tarinfo = self.tarinfo.fromtarfile(self) - self.members.append(tarinfo) - except EOFHeaderError: - self.fileobj.seek(self.offset) - break - except HeaderError as e: - raise ReadError(str(e)) - - if self.mode in "aw": - self._loaded = True - - if self.pax_headers: - buf = self.tarinfo.create_pax_global_header(self.pax_headers.copy()) - self.fileobj.write(buf) - self.offset += len(buf) - except: - if not self._extfileobj: - self.fileobj.close() - self.closed = True - raise - - #-------------------------------------------------------------------------- - # Below are the classmethods which act as alternate constructors to the - # TarFile class. The open() method is the only one that is needed for - # public use; it is the "super"-constructor and is able to select an - # adequate "sub"-constructor for a particular compression using the mapping - # from OPEN_METH. - # - # This concept allows one to subclass TarFile without losing the comfort of - # the super-constructor. A sub-constructor is registered and made available - # by adding it to the mapping in OPEN_METH. - - @classmethod - def open(cls, name=None, mode="r", fileobj=None, bufsize=RECORDSIZE, **kwargs): - """Open a tar archive for reading, writing or appending. Return - an appropriate TarFile class. - - mode: - 'r' or 'r:*' open for reading with transparent compression - 'r:' open for reading exclusively uncompressed - 'r:gz' open for reading with gzip compression - 'r:bz2' open for reading with bzip2 compression - 'a' or 'a:' open for appending, creating the file if necessary - 'w' or 'w:' open for writing without compression - 'w:gz' open for writing with gzip compression - 'w:bz2' open for writing with bzip2 compression - - 'r|*' open a stream of tar blocks with transparent compression - 'r|' open an uncompressed stream of tar blocks for reading - 'r|gz' open a gzip compressed stream of tar blocks - 'r|bz2' open a bzip2 compressed stream of tar blocks - 'w|' open an uncompressed stream for writing - 'w|gz' open a gzip compressed stream for writing - 'w|bz2' open a bzip2 compressed stream for writing - """ - - if not name and not fileobj: - raise ValueError("nothing to open") - - if mode in ("r", "r:*"): - # Find out which *open() is appropriate for opening the file. - for comptype in cls.OPEN_METH: - func = getattr(cls, cls.OPEN_METH[comptype]) - if fileobj is not None: - saved_pos = fileobj.tell() - try: - return func(name, "r", fileobj, **kwargs) - except (ReadError, CompressionError) as e: - if fileobj is not None: - fileobj.seek(saved_pos) - continue - raise ReadError("file could not be opened successfully") - - elif ":" in mode: - filemode, comptype = mode.split(":", 1) - filemode = filemode or "r" - comptype = comptype or "tar" - - # Select the *open() function according to - # given compression. - if comptype in cls.OPEN_METH: - func = getattr(cls, cls.OPEN_METH[comptype]) - else: - raise CompressionError("unknown compression type %r" % comptype) - return func(name, filemode, fileobj, **kwargs) - - elif "|" in mode: - filemode, comptype = mode.split("|", 1) - filemode = filemode or "r" - comptype = comptype or "tar" - - if filemode not in "rw": - raise ValueError("mode must be 'r' or 'w'") - - stream = _Stream(name, filemode, comptype, fileobj, bufsize) - try: - t = cls(name, filemode, stream, **kwargs) - except: - stream.close() - raise - t._extfileobj = False - return t - - elif mode in "aw": - return cls.taropen(name, mode, fileobj, **kwargs) - - raise ValueError("undiscernible mode") - - @classmethod - def taropen(cls, name, mode="r", fileobj=None, **kwargs): - """Open uncompressed tar archive name for reading or writing. - """ - if len(mode) > 1 or mode not in "raw": - raise ValueError("mode must be 'r', 'a' or 'w'") - return cls(name, mode, fileobj, **kwargs) - - @classmethod - def gzopen(cls, name, mode="r", fileobj=None, compresslevel=9, **kwargs): - """Open gzip compressed tar archive name for reading or writing. - Appending is not allowed. - """ - if len(mode) > 1 or mode not in "rw": - raise ValueError("mode must be 'r' or 'w'") - - try: - import gzip - gzip.GzipFile - except (ImportError, AttributeError): - raise CompressionError("gzip module is not available") - - extfileobj = fileobj is not None - try: - fileobj = gzip.GzipFile(name, mode + "b", compresslevel, fileobj) - t = cls.taropen(name, mode, fileobj, **kwargs) - except IOError: - if not extfileobj and fileobj is not None: - fileobj.close() - if fileobj is None: - raise - raise ReadError("not a gzip file") - except: - if not extfileobj and fileobj is not None: - fileobj.close() - raise - t._extfileobj = extfileobj - return t - - @classmethod - def bz2open(cls, name, mode="r", fileobj=None, compresslevel=9, **kwargs): - """Open bzip2 compressed tar archive name for reading or writing. - Appending is not allowed. - """ - if len(mode) > 1 or mode not in "rw": - raise ValueError("mode must be 'r' or 'w'.") - - try: - import bz2 - except ImportError: - raise CompressionError("bz2 module is not available") - - if fileobj is not None: - fileobj = _BZ2Proxy(fileobj, mode) - else: - fileobj = bz2.BZ2File(name, mode, compresslevel=compresslevel) - - try: - t = cls.taropen(name, mode, fileobj, **kwargs) - except (IOError, EOFError): - fileobj.close() - raise ReadError("not a bzip2 file") - t._extfileobj = False - return t - - # All *open() methods are registered here. - OPEN_METH = { - "tar": "taropen", # uncompressed tar - "gz": "gzopen", # gzip compressed tar - "bz2": "bz2open" # bzip2 compressed tar - } - - #-------------------------------------------------------------------------- - # The public methods which TarFile provides: - - def close(self): - """Close the TarFile. In write-mode, two finishing zero blocks are - appended to the archive. - """ - if self.closed: - return - - if self.mode in "aw": - self.fileobj.write(NUL * (BLOCKSIZE * 2)) - self.offset += (BLOCKSIZE * 2) - # fill up the end with zero-blocks - # (like option -b20 for tar does) - blocks, remainder = divmod(self.offset, RECORDSIZE) - if remainder > 0: - self.fileobj.write(NUL * (RECORDSIZE - remainder)) - - if not self._extfileobj: - self.fileobj.close() - self.closed = True - - def getmember(self, name): - """Return a TarInfo object for member `name'. If `name' can not be - found in the archive, KeyError is raised. If a member occurs more - than once in the archive, its last occurrence is assumed to be the - most up-to-date version. - """ - tarinfo = self._getmember(name) - if tarinfo is None: - raise KeyError("filename %r not found" % name) - return tarinfo - - def getmembers(self): - """Return the members of the archive as a list of TarInfo objects. The - list has the same order as the members in the archive. - """ - self._check() - if not self._loaded: # if we want to obtain a list of - self._load() # all members, we first have to - # scan the whole archive. - return self.members - - def getnames(self): - """Return the members of the archive as a list of their names. It has - the same order as the list returned by getmembers(). - """ - return [tarinfo.name for tarinfo in self.getmembers()] - - def gettarinfo(self, name=None, arcname=None, fileobj=None): - """Create a TarInfo object for either the file `name' or the file - object `fileobj' (using os.fstat on its file descriptor). You can - modify some of the TarInfo's attributes before you add it using - addfile(). If given, `arcname' specifies an alternative name for the - file in the archive. - """ - self._check("aw") - - # When fileobj is given, replace name by - # fileobj's real name. - if fileobj is not None: - name = fileobj.name - - # Building the name of the member in the archive. - # Backward slashes are converted to forward slashes, - # Absolute paths are turned to relative paths. - if arcname is None: - arcname = name - drv, arcname = os.path.splitdrive(arcname) - arcname = arcname.replace(os.sep, "/") - arcname = arcname.lstrip("/") - - # Now, fill the TarInfo object with - # information specific for the file. - tarinfo = self.tarinfo() - tarinfo.tarfile = self - - # Use os.stat or os.lstat, depending on platform - # and if symlinks shall be resolved. - if fileobj is None: - if hasattr(os, "lstat") and not self.dereference: - statres = os.lstat(name) - else: - statres = os.stat(name) - else: - statres = os.fstat(fileobj.fileno()) - linkname = "" - - stmd = statres.st_mode - if stat.S_ISREG(stmd): - inode = (statres.st_ino, statres.st_dev) - if not self.dereference and statres.st_nlink > 1 and \ - inode in self.inodes and arcname != self.inodes[inode]: - # Is it a hardlink to an already - # archived file? - type = LNKTYPE - linkname = self.inodes[inode] - else: - # The inode is added only if its valid. - # For win32 it is always 0. - type = REGTYPE - if inode[0]: - self.inodes[inode] = arcname - elif stat.S_ISDIR(stmd): - type = DIRTYPE - elif stat.S_ISFIFO(stmd): - type = FIFOTYPE - elif stat.S_ISLNK(stmd): - type = SYMTYPE - linkname = os.readlink(name) - elif stat.S_ISCHR(stmd): - type = CHRTYPE - elif stat.S_ISBLK(stmd): - type = BLKTYPE - else: - return None - - # Fill the TarInfo object with all - # information we can get. - tarinfo.name = arcname - tarinfo.mode = stmd - tarinfo.uid = statres.st_uid - tarinfo.gid = statres.st_gid - if type == REGTYPE: - tarinfo.size = statres.st_size - else: - tarinfo.size = 0 - tarinfo.mtime = statres.st_mtime - tarinfo.type = type - tarinfo.linkname = linkname - if pwd: - try: - tarinfo.uname = pwd.getpwuid(tarinfo.uid)[0] - except KeyError: - pass - if grp: - try: - tarinfo.gname = grp.getgrgid(tarinfo.gid)[0] - except KeyError: - pass - - if type in (CHRTYPE, BLKTYPE): - if hasattr(os, "major") and hasattr(os, "minor"): - tarinfo.devmajor = os.major(statres.st_rdev) - tarinfo.devminor = os.minor(statres.st_rdev) - return tarinfo - - def list(self, verbose=True): - """Print a table of contents to sys.stdout. If `verbose' is False, only - the names of the members are printed. If it is True, an `ls -l'-like - output is produced. - """ - self._check() - - for tarinfo in self: - if verbose: - print(filemode(tarinfo.mode), end=' ') - print("%s/%s" % (tarinfo.uname or tarinfo.uid, - tarinfo.gname or tarinfo.gid), end=' ') - if tarinfo.ischr() or tarinfo.isblk(): - print("%10s" % ("%d,%d" \ - % (tarinfo.devmajor, tarinfo.devminor)), end=' ') - else: - print("%10d" % tarinfo.size, end=' ') - print("%d-%02d-%02d %02d:%02d:%02d" \ - % time.localtime(tarinfo.mtime)[:6], end=' ') - - print(tarinfo.name + ("/" if tarinfo.isdir() else ""), end=' ') - - if verbose: - if tarinfo.issym(): - print("->", tarinfo.linkname, end=' ') - if tarinfo.islnk(): - print("link to", tarinfo.linkname, end=' ') - print() - - def add(self, name, arcname=None, recursive=True, exclude=None, filter=None): - """Add the file `name' to the archive. `name' may be any type of file - (directory, fifo, symbolic link, etc.). If given, `arcname' - specifies an alternative name for the file in the archive. - Directories are added recursively by default. This can be avoided by - setting `recursive' to False. `exclude' is a function that should - return True for each filename to be excluded. `filter' is a function - that expects a TarInfo object argument and returns the changed - TarInfo object, if it returns None the TarInfo object will be - excluded from the archive. - """ - self._check("aw") - - if arcname is None: - arcname = name - - # Exclude pathnames. - if exclude is not None: - import warnings - warnings.warn("use the filter argument instead", - DeprecationWarning, 2) - if exclude(name): - self._dbg(2, "tarfile: Excluded %r" % name) - return - - # Skip if somebody tries to archive the archive... - if self.name is not None and os.path.abspath(name) == self.name: - self._dbg(2, "tarfile: Skipped %r" % name) - return - - self._dbg(1, name) - - # Create a TarInfo object from the file. - tarinfo = self.gettarinfo(name, arcname) - - if tarinfo is None: - self._dbg(1, "tarfile: Unsupported type %r" % name) - return - - # Change or exclude the TarInfo object. - if filter is not None: - tarinfo = filter(tarinfo) - if tarinfo is None: - self._dbg(2, "tarfile: Excluded %r" % name) - return - - # Append the tar header and data to the archive. - if tarinfo.isreg(): - f = bltn_open(name, "rb") - self.addfile(tarinfo, f) - f.close() - - elif tarinfo.isdir(): - self.addfile(tarinfo) - if recursive: - for f in os.listdir(name): - self.add(os.path.join(name, f), os.path.join(arcname, f), - recursive, exclude, filter=filter) - - else: - self.addfile(tarinfo) - - def addfile(self, tarinfo, fileobj=None): - """Add the TarInfo object `tarinfo' to the archive. If `fileobj' is - given, tarinfo.size bytes are read from it and added to the archive. - You can create TarInfo objects using gettarinfo(). - On Windows platforms, `fileobj' should always be opened with mode - 'rb' to avoid irritation about the file size. - """ - self._check("aw") - - tarinfo = copy.copy(tarinfo) - - buf = tarinfo.tobuf(self.format, self.encoding, self.errors) - self.fileobj.write(buf) - self.offset += len(buf) - - # If there's data to follow, append it. - if fileobj is not None: - copyfileobj(fileobj, self.fileobj, tarinfo.size) - blocks, remainder = divmod(tarinfo.size, BLOCKSIZE) - if remainder > 0: - self.fileobj.write(NUL * (BLOCKSIZE - remainder)) - blocks += 1 - self.offset += blocks * BLOCKSIZE - - self.members.append(tarinfo) - - def extractall(self, path=".", members=None): - """Extract all members from the archive to the current working - directory and set owner, modification time and permissions on - directories afterwards. `path' specifies a different directory - to extract to. `members' is optional and must be a subset of the - list returned by getmembers(). - """ - directories = [] - - if members is None: - members = self - - for tarinfo in members: - if tarinfo.isdir(): - # Extract directories with a safe mode. - directories.append(tarinfo) - tarinfo = copy.copy(tarinfo) - tarinfo.mode = 0o700 - # Do not set_attrs directories, as we will do that further down - self.extract(tarinfo, path, set_attrs=not tarinfo.isdir()) - - # Reverse sort directories. - directories.sort(key=lambda a: a.name) - directories.reverse() - - # Set correct owner, mtime and filemode on directories. - for tarinfo in directories: - dirpath = os.path.join(path, tarinfo.name) - try: - self.chown(tarinfo, dirpath) - self.utime(tarinfo, dirpath) - self.chmod(tarinfo, dirpath) - except ExtractError as e: - if self.errorlevel > 1: - raise - else: - self._dbg(1, "tarfile: %s" % e) - - def extract(self, member, path="", set_attrs=True): - """Extract a member from the archive to the current working directory, - using its full name. Its file information is extracted as accurately - as possible. `member' may be a filename or a TarInfo object. You can - specify a different directory using `path'. File attributes (owner, - mtime, mode) are set unless `set_attrs' is False. - """ - self._check("r") - - if isinstance(member, str): - tarinfo = self.getmember(member) - else: - tarinfo = member - - # Prepare the link target for makelink(). - if tarinfo.islnk(): - tarinfo._link_target = os.path.join(path, tarinfo.linkname) - - try: - self._extract_member(tarinfo, os.path.join(path, tarinfo.name), - set_attrs=set_attrs) - except EnvironmentError as e: - if self.errorlevel > 0: - raise - else: - if e.filename is None: - self._dbg(1, "tarfile: %s" % e.strerror) - else: - self._dbg(1, "tarfile: %s %r" % (e.strerror, e.filename)) - except ExtractError as e: - if self.errorlevel > 1: - raise - else: - self._dbg(1, "tarfile: %s" % e) - - def extractfile(self, member): - """Extract a member from the archive as a file object. `member' may be - a filename or a TarInfo object. If `member' is a regular file, a - file-like object is returned. If `member' is a link, a file-like - object is constructed from the link's target. If `member' is none of - the above, None is returned. - The file-like object is read-only and provides the following - methods: read(), readline(), readlines(), seek() and tell() - """ - self._check("r") - - if isinstance(member, str): - tarinfo = self.getmember(member) - else: - tarinfo = member - - if tarinfo.isreg(): - return self.fileobject(self, tarinfo) - - elif tarinfo.type not in SUPPORTED_TYPES: - # If a member's type is unknown, it is treated as a - # regular file. - return self.fileobject(self, tarinfo) - - elif tarinfo.islnk() or tarinfo.issym(): - if isinstance(self.fileobj, _Stream): - # A small but ugly workaround for the case that someone tries - # to extract a (sym)link as a file-object from a non-seekable - # stream of tar blocks. - raise StreamError("cannot extract (sym)link as file object") - else: - # A (sym)link's file object is its target's file object. - return self.extractfile(self._find_link_target(tarinfo)) - else: - # If there's no data associated with the member (directory, chrdev, - # blkdev, etc.), return None instead of a file object. - return None - - def _extract_member(self, tarinfo, targetpath, set_attrs=True): - """Extract the TarInfo object tarinfo to a physical - file called targetpath. - """ - # Fetch the TarInfo object for the given name - # and build the destination pathname, replacing - # forward slashes to platform specific separators. - targetpath = targetpath.rstrip("/") - targetpath = targetpath.replace("/", os.sep) - - # Create all upper directories. - upperdirs = os.path.dirname(targetpath) - if upperdirs and not os.path.exists(upperdirs): - # Create directories that are not part of the archive with - # default permissions. - os.makedirs(upperdirs) - - if tarinfo.islnk() or tarinfo.issym(): - self._dbg(1, "%s -> %s" % (tarinfo.name, tarinfo.linkname)) - else: - self._dbg(1, tarinfo.name) - - if tarinfo.isreg(): - self.makefile(tarinfo, targetpath) - elif tarinfo.isdir(): - self.makedir(tarinfo, targetpath) - elif tarinfo.isfifo(): - self.makefifo(tarinfo, targetpath) - elif tarinfo.ischr() or tarinfo.isblk(): - self.makedev(tarinfo, targetpath) - elif tarinfo.islnk() or tarinfo.issym(): - self.makelink(tarinfo, targetpath) - elif tarinfo.type not in SUPPORTED_TYPES: - self.makeunknown(tarinfo, targetpath) - else: - self.makefile(tarinfo, targetpath) - - if set_attrs: - self.chown(tarinfo, targetpath) - if not tarinfo.issym(): - self.chmod(tarinfo, targetpath) - self.utime(tarinfo, targetpath) - - #-------------------------------------------------------------------------- - # Below are the different file methods. They are called via - # _extract_member() when extract() is called. They can be replaced in a - # subclass to implement other functionality. - - def makedir(self, tarinfo, targetpath): - """Make a directory called targetpath. - """ - try: - # Use a safe mode for the directory, the real mode is set - # later in _extract_member(). - os.mkdir(targetpath, 0o700) - except EnvironmentError as e: - if e.errno != errno.EEXIST: - raise - - def makefile(self, tarinfo, targetpath): - """Make a file called targetpath. - """ - source = self.fileobj - source.seek(tarinfo.offset_data) - target = bltn_open(targetpath, "wb") - if tarinfo.sparse is not None: - for offset, size in tarinfo.sparse: - target.seek(offset) - copyfileobj(source, target, size) - else: - copyfileobj(source, target, tarinfo.size) - target.seek(tarinfo.size) - target.truncate() - target.close() - - def makeunknown(self, tarinfo, targetpath): - """Make a file from a TarInfo object with an unknown type - at targetpath. - """ - self.makefile(tarinfo, targetpath) - self._dbg(1, "tarfile: Unknown file type %r, " \ - "extracted as regular file." % tarinfo.type) - - def makefifo(self, tarinfo, targetpath): - """Make a fifo called targetpath. - """ - if hasattr(os, "mkfifo"): - os.mkfifo(targetpath) - else: - raise ExtractError("fifo not supported by system") - - def makedev(self, tarinfo, targetpath): - """Make a character or block device called targetpath. - """ - if not hasattr(os, "mknod") or not hasattr(os, "makedev"): - raise ExtractError("special devices not supported by system") - - mode = tarinfo.mode - if tarinfo.isblk(): - mode |= stat.S_IFBLK - else: - mode |= stat.S_IFCHR - - os.mknod(targetpath, mode, - os.makedev(tarinfo.devmajor, tarinfo.devminor)) - - def makelink(self, tarinfo, targetpath): - """Make a (symbolic) link called targetpath. If it cannot be created - (platform limitation), we try to make a copy of the referenced file - instead of a link. - """ - try: - # For systems that support symbolic and hard links. - if tarinfo.issym(): - os.symlink(tarinfo.linkname, targetpath) - else: - # See extract(). - if os.path.exists(tarinfo._link_target): - os.link(tarinfo._link_target, targetpath) - else: - self._extract_member(self._find_link_target(tarinfo), - targetpath) - except symlink_exception: - if tarinfo.issym(): - linkpath = os.path.join(os.path.dirname(tarinfo.name), - tarinfo.linkname) - else: - linkpath = tarinfo.linkname - else: - try: - self._extract_member(self._find_link_target(tarinfo), - targetpath) - except KeyError: - raise ExtractError("unable to resolve link inside archive") - - def chown(self, tarinfo, targetpath): - """Set owner of targetpath according to tarinfo. - """ - if pwd and hasattr(os, "geteuid") and os.geteuid() == 0: - # We have to be root to do so. - try: - g = grp.getgrnam(tarinfo.gname)[2] - except KeyError: - g = tarinfo.gid - try: - u = pwd.getpwnam(tarinfo.uname)[2] - except KeyError: - u = tarinfo.uid - try: - if tarinfo.issym() and hasattr(os, "lchown"): - os.lchown(targetpath, u, g) - else: - if sys.platform != "os2emx": - os.chown(targetpath, u, g) - except EnvironmentError as e: - raise ExtractError("could not change owner") - - def chmod(self, tarinfo, targetpath): - """Set file permissions of targetpath according to tarinfo. - """ - if hasattr(os, 'chmod'): - try: - os.chmod(targetpath, tarinfo.mode) - except EnvironmentError as e: - raise ExtractError("could not change mode") - - def utime(self, tarinfo, targetpath): - """Set modification time of targetpath according to tarinfo. - """ - if not hasattr(os, 'utime'): - return - try: - os.utime(targetpath, (tarinfo.mtime, tarinfo.mtime)) - except EnvironmentError as e: - raise ExtractError("could not change modification time") - - #-------------------------------------------------------------------------- - def next(self): - """Return the next member of the archive as a TarInfo object, when - TarFile is opened for reading. Return None if there is no more - available. - """ - self._check("ra") - if self.firstmember is not None: - m = self.firstmember - self.firstmember = None - return m - - # Read the next block. - self.fileobj.seek(self.offset) - tarinfo = None - while True: - try: - tarinfo = self.tarinfo.fromtarfile(self) - except EOFHeaderError as e: - if self.ignore_zeros: - self._dbg(2, "0x%X: %s" % (self.offset, e)) - self.offset += BLOCKSIZE - continue - except InvalidHeaderError as e: - if self.ignore_zeros: - self._dbg(2, "0x%X: %s" % (self.offset, e)) - self.offset += BLOCKSIZE - continue - elif self.offset == 0: - raise ReadError(str(e)) - except EmptyHeaderError: - if self.offset == 0: - raise ReadError("empty file") - except TruncatedHeaderError as e: - if self.offset == 0: - raise ReadError(str(e)) - except SubsequentHeaderError as e: - raise ReadError(str(e)) - break - - if tarinfo is not None: - self.members.append(tarinfo) - else: - self._loaded = True - - return tarinfo - - #-------------------------------------------------------------------------- - # Little helper methods: - - def _getmember(self, name, tarinfo=None, normalize=False): - """Find an archive member by name from bottom to top. - If tarinfo is given, it is used as the starting point. - """ - # Ensure that all members have been loaded. - members = self.getmembers() - - # Limit the member search list up to tarinfo. - if tarinfo is not None: - members = members[:members.index(tarinfo)] - - if normalize: - name = os.path.normpath(name) - - for member in reversed(members): - if normalize: - member_name = os.path.normpath(member.name) - else: - member_name = member.name - - if name == member_name: - return member - - def _load(self): - """Read through the entire archive file and look for readable - members. - """ - while True: - tarinfo = self.next() - if tarinfo is None: - break - self._loaded = True - - def _check(self, mode=None): - """Check if TarFile is still open, and if the operation's mode - corresponds to TarFile's mode. - """ - if self.closed: - raise IOError("%s is closed" % self.__class__.__name__) - if mode is not None and self.mode not in mode: - raise IOError("bad operation for mode %r" % self.mode) - - def _find_link_target(self, tarinfo): - """Find the target member of a symlink or hardlink member in the - archive. - """ - if tarinfo.issym(): - # Always search the entire archive. - linkname = os.path.dirname(tarinfo.name) + "/" + tarinfo.linkname - limit = None - else: - # Search the archive before the link, because a hard link is - # just a reference to an already archived file. - linkname = tarinfo.linkname - limit = tarinfo - - member = self._getmember(linkname, tarinfo=limit, normalize=True) - if member is None: - raise KeyError("linkname %r not found" % linkname) - return member - - def __iter__(self): - """Provide an iterator object. - """ - if self._loaded: - return iter(self.members) - else: - return TarIter(self) - - def _dbg(self, level, msg): - """Write debugging output to sys.stderr. - """ - if level <= self.debug: - print(msg, file=sys.stderr) - - def __enter__(self): - self._check() - return self - - def __exit__(self, type, value, traceback): - if type is None: - self.close() - else: - # An exception occurred. We must not call close() because - # it would try to write end-of-archive blocks and padding. - if not self._extfileobj: - self.fileobj.close() - self.closed = True -# class TarFile - -class TarIter(object): - """Iterator Class. - - for tarinfo in TarFile(...): - suite... - """ - - def __init__(self, tarfile): - """Construct a TarIter object. - """ - self.tarfile = tarfile - self.index = 0 - def __iter__(self): - """Return iterator object. - """ - return self - - def __next__(self): - """Return the next item using TarFile's next() method. - When all members have been read, set TarFile as _loaded. - """ - # Fix for SF #1100429: Under rare circumstances it can - # happen that getmembers() is called during iteration, - # which will cause TarIter to stop prematurely. - if not self.tarfile._loaded: - tarinfo = self.tarfile.next() - if not tarinfo: - self.tarfile._loaded = True - raise StopIteration - else: - try: - tarinfo = self.tarfile.members[self.index] - except IndexError: - raise StopIteration - self.index += 1 - return tarinfo - - next = __next__ # for Python 2.x - -#-------------------- -# exported functions -#-------------------- -def is_tarfile(name): - """Return True if name points to a tar archive that we - are able to handle, else return False. - """ - try: - t = open(name) - t.close() - return True - except TarError: - return False - -bltn_open = open -open = TarFile.open diff --git a/env/Lib/site-packages/pip/_vendor/distlib/compat.py b/env/Lib/site-packages/pip/_vendor/distlib/compat.py index c316fd97..1fe3d225 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/compat.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/compat.py @@ -22,7 +22,6 @@ if sys.version_info[0] < 3: # pragma: no cover from types import FileType as file_type import __builtin__ as builtins import ConfigParser as configparser - from ._backport import shutil from urlparse import urlparse, urlunparse, urljoin, urlsplit, urlunsplit from urllib import (urlretrieve, quote as _quote, unquote, url2pathname, pathname2url, ContentTooShortError, splittype) @@ -48,17 +47,18 @@ if sys.version_info[0] < 3: # pragma: no cover from itertools import ifilter as filter from itertools import ifilterfalse as filterfalse - _userprog = None - def splituser(host): - """splituser('user[:passwd]@host[:port]') --> 'user[:passwd]', 'host[:port]'.""" - global _userprog - if _userprog is None: - import re - _userprog = re.compile('^(.*)@(.*)$') + # Leaving this around for now, in case it needs resurrecting in some way + # _userprog = None + # def splituser(host): + # """splituser('user[:passwd]@host[:port]') --> 'user[:passwd]', 'host[:port]'.""" + # global _userprog + # if _userprog is None: + # import re + # _userprog = re.compile('^(.*)@(.*)$') - match = _userprog.match(host) - if match: return match.group(1, 2) - return None, host + # match = _userprog.match(host) + # if match: return match.group(1, 2) + # return None, host else: # pragma: no cover from io import StringIO @@ -68,7 +68,7 @@ else: # pragma: no cover import builtins import configparser import shutil - from urllib.parse import (urlparse, urlunparse, urljoin, splituser, quote, + from urllib.parse import (urlparse, urlunparse, urljoin, quote, unquote, urlsplit, urlunsplit, splittype) from urllib.request import (urlopen, urlretrieve, Request, url2pathname, pathname2url, @@ -88,6 +88,7 @@ else: # pragma: no cover from itertools import filterfalse filter = filter + try: from ssl import match_hostname, CertificateError except ImportError: # pragma: no cover @@ -311,10 +312,8 @@ except ImportError: # pragma: no cover return 'IronPython' return 'CPython' -try: - import sysconfig -except ImportError: # pragma: no cover - from ._backport import sysconfig +import shutil +import sysconfig try: callable = callable @@ -616,18 +615,15 @@ except ImportError: # pragma: no cover try: from importlib.util import cache_from_source # Python >= 3.4 except ImportError: # pragma: no cover - try: - from imp import cache_from_source - except ImportError: # pragma: no cover - def cache_from_source(path, debug_override=None): - assert path.endswith('.py') - if debug_override is None: - debug_override = __debug__ - if debug_override: - suffix = 'c' - else: - suffix = 'o' - return path + suffix + def cache_from_source(path, debug_override=None): + assert path.endswith('.py') + if debug_override is None: + debug_override = __debug__ + if debug_override: + suffix = 'c' + else: + suffix = 'o' + return path + suffix try: from collections import OrderedDict diff --git a/env/Lib/site-packages/pip/_vendor/distlib/database.py b/env/Lib/site-packages/pip/_vendor/distlib/database.py index 0a90c300..5db5d7f5 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/database.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/database.py @@ -132,29 +132,35 @@ class DistributionPath(object): r = finder.find(entry) if not r or r.path in seen: continue - if self._include_dist and entry.endswith(DISTINFO_EXT): - possible_filenames = [METADATA_FILENAME, - WHEEL_METADATA_FILENAME, - LEGACY_METADATA_FILENAME] - for metadata_filename in possible_filenames: - metadata_path = posixpath.join(entry, metadata_filename) - pydist = finder.find(metadata_path) - if pydist: - break - else: - continue + try: + if self._include_dist and entry.endswith(DISTINFO_EXT): + possible_filenames = [METADATA_FILENAME, + WHEEL_METADATA_FILENAME, + LEGACY_METADATA_FILENAME] + for metadata_filename in possible_filenames: + metadata_path = posixpath.join(entry, metadata_filename) + pydist = finder.find(metadata_path) + if pydist: + break + else: + continue - with contextlib.closing(pydist.as_stream()) as stream: - metadata = Metadata(fileobj=stream, scheme='legacy') - logger.debug('Found %s', r.path) - seen.add(r.path) - yield new_dist_class(r.path, metadata=metadata, - env=self) - elif self._include_egg and entry.endswith(('.egg-info', - '.egg')): - logger.debug('Found %s', r.path) - seen.add(r.path) - yield old_dist_class(r.path, self) + with contextlib.closing(pydist.as_stream()) as stream: + metadata = Metadata(fileobj=stream, scheme='legacy') + logger.debug('Found %s', r.path) + seen.add(r.path) + yield new_dist_class(r.path, metadata=metadata, + env=self) + elif self._include_egg and entry.endswith(('.egg-info', + '.egg')): + logger.debug('Found %s', r.path) + seen.add(r.path) + yield old_dist_class(r.path, self) + except Exception as e: + msg = 'Unable to read distribution at %s, perhaps due to bad metadata: %s' + logger.warning(msg, r.path, e) + import warnings + warnings.warn(msg % (r.path, e), stacklevel=2) def _generate_cache(self): """ @@ -379,8 +385,9 @@ class Distribution(object): def _get_requirements(self, req_attr): md = self.metadata - logger.debug('Getting requirements from metadata %r', md.todict()) reqts = getattr(md, req_attr) + logger.debug('%s: got requirements %r from metadata: %r', self.name, req_attr, + reqts) return set(md.get_requirements(reqts, extras=self.extras, env=self.context)) @@ -1308,22 +1315,26 @@ def get_required_dists(dists, dist): :param dists: a list of distributions :param dist: a distribution, member of *dists* for which we are interested + in finding the dependencies. """ if dist not in dists: raise DistlibException('given distribution %r is not a member ' 'of the list' % dist.name) graph = make_graph(dists) - req = [] # required distributions + req = set() # required distributions todo = graph.adjacency_list[dist] # list of nodes we should inspect + seen = set(t[0] for t in todo) # already added to todo while todo: d = todo.pop()[0] - req.append(d) - for pred in graph.adjacency_list[d]: - if pred not in req: + req.add(d) + pred_list = graph.adjacency_list[d] + for pred in pred_list: + d = pred[0] + if d not in req and d not in seen: + seen.add(d) todo.append(pred) - return req diff --git a/env/Lib/site-packages/pip/_vendor/distlib/index.py b/env/Lib/site-packages/pip/_vendor/distlib/index.py index 7a87cdcf..9b6d129e 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/index.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/index.py @@ -12,13 +12,13 @@ import subprocess import tempfile try: from threading import Thread -except ImportError: +except ImportError: # pragma: no cover from dummy_threading import Thread from . import DistlibException from .compat import (HTTPBasicAuthHandler, Request, HTTPPasswordMgr, urlparse, build_opener, string_types) -from .util import cached_property, zip_dir, ServerProxy +from .util import zip_dir, ServerProxy logger = logging.getLogger(__name__) @@ -67,21 +67,17 @@ class PackageIndex(object): Get the distutils command for interacting with PyPI configurations. :return: the command. """ - from distutils.core import Distribution - from distutils.config import PyPIRCCommand - d = Distribution() - return PyPIRCCommand(d) + from .util import _get_pypirc_command as cmd + return cmd() def read_configuration(self): """ - Read the PyPI access configuration as supported by distutils, getting - PyPI to do the actual work. This populates ``username``, ``password``, - ``realm`` and ``url`` attributes from the configuration. + Read the PyPI access configuration as supported by distutils. This populates + ``username``, ``password``, ``realm`` and ``url`` attributes from the + configuration. """ - # get distutils to do the work - c = self._get_pypirc_command() - c.repository = self.url - cfg = c._read_pypirc() + from .util import _load_pypirc + cfg = _load_pypirc(self) self.username = cfg.get('username') self.password = cfg.get('password') self.realm = cfg.get('realm', 'pypi') @@ -91,13 +87,10 @@ class PackageIndex(object): """ Save the PyPI access configuration. You must have set ``username`` and ``password`` attributes before calling this method. - - Again, distutils is used to do the actual work. """ self.check_credentials() - # get distutils to do the work - c = self._get_pypirc_command() - c._store_pypirc(self.username, self.password) + from .util import _store_pypirc + _store_pypirc(self) def check_credentials(self): """ @@ -111,7 +104,7 @@ class PackageIndex(object): pm.add_password(self.realm, netloc, self.username, self.password) self.password_handler = HTTPBasicAuthHandler(pm) - def register(self, metadata): + def register(self, metadata): # pragma: no cover """ Register a distribution on PyPI, using the provided metadata. @@ -149,8 +142,7 @@ class PackageIndex(object): logger.debug('%s: %s' % (name, s)) stream.close() - def get_sign_command(self, filename, signer, sign_password, - keystore=None): + def get_sign_command(self, filename, signer, sign_password, keystore=None): # pragma: no cover """ Return a suitable command for signing a file. @@ -213,7 +205,7 @@ class PackageIndex(object): t2.join() return p.returncode, stdout, stderr - def sign_file(self, filename, signer, sign_password, keystore=None): + def sign_file(self, filename, signer, sign_password, keystore=None): # pragma: no cover """ Sign a file. @@ -293,7 +285,7 @@ class PackageIndex(object): request = self.encode_request(d.items(), files) return self.send_request(request) - def upload_documentation(self, metadata, doc_dir): + def upload_documentation(self, metadata, doc_dir): # pragma: no cover """ Upload documentation to the index. @@ -506,7 +498,7 @@ class PackageIndex(object): } return Request(self.url, body, headers) - def search(self, terms, operator=None): + def search(self, terms, operator=None): # pragma: no cover if isinstance(terms, string_types): terms = {'name': terms} rpc_proxy = ServerProxy(self.url, timeout=3.0) diff --git a/env/Lib/site-packages/pip/_vendor/distlib/locators.py b/env/Lib/site-packages/pip/_vendor/distlib/locators.py index 12a1d063..966ebc0e 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/locators.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/locators.py @@ -20,14 +20,14 @@ import zlib from . import DistlibException from .compat import (urljoin, urlparse, urlunparse, url2pathname, pathname2url, - queue, quote, unescape, string_types, build_opener, + queue, quote, unescape, build_opener, HTTPRedirectHandler as BaseRedirectHandler, text_type, Request, HTTPError, URLError) from .database import Distribution, DistributionPath, make_dist from .metadata import Metadata, MetadataInvalidError -from .util import (cached_property, parse_credentials, ensure_slash, - split_filename, get_project_data, parse_requirement, - parse_name_and_version, ServerProxy, normalize_name) +from .util import (cached_property, ensure_slash, split_filename, get_project_data, + parse_requirement, parse_name_and_version, ServerProxy, + normalize_name) from .version import get_scheme, UnsupportedVersionError from .wheel import Wheel, is_compatible @@ -378,13 +378,13 @@ class Locator(object): continue try: if not matcher.match(k): - logger.debug('%s did not match %r', matcher, k) + pass # logger.debug('%s did not match %r', matcher, k) else: if prereleases or not vcls(k).is_prerelease: slist.append(k) - else: - logger.debug('skipping pre-release ' - 'version %s of %s', k, matcher.name) + # else: + # logger.debug('skipping pre-release ' + # 'version %s of %s', k, matcher.name) except Exception: # pragma: no cover logger.warning('error matching %s with %r', matcher, k) pass # slist.append(k) @@ -593,7 +593,7 @@ class SimpleScrapingLocator(Locator): # These are used to deal with various Content-Encoding schemes. decoders = { 'deflate': zlib.decompress, - 'gzip': lambda b: gzip.GzipFile(fileobj=BytesIO(d)).read(), + 'gzip': lambda b: gzip.GzipFile(fileobj=BytesIO(b)).read(), 'none': lambda b: b, } @@ -633,7 +633,7 @@ class SimpleScrapingLocator(Locator): self._threads = [] for i in range(self.num_workers): t = threading.Thread(target=self._fetch) - t.setDaemon(True) + t.daemon = True t.start() self._threads.append(t) @@ -1053,17 +1053,15 @@ class AggregatingLocator(Locator): # We use a legacy scheme simply because most of the dists on PyPI use legacy -# versions which don't conform to PEP 426 / PEP 440. +# versions which don't conform to PEP 440. default_locator = AggregatingLocator( - JSONLocator(), + # JSONLocator(), # don't use as PEP 426 is withdrawn SimpleScrapingLocator('https://pypi.org/simple/', timeout=3.0), scheme='legacy') locate = default_locator.locate -NAME_VERSION_RE = re.compile(r'(?P<name>[\w-]+)\s*' - r'\(\s*(==\s*)?(?P<ver>[^)]+)\)$') class DependencyFinder(object): """ diff --git a/env/Lib/site-packages/pip/_vendor/distlib/markers.py b/env/Lib/site-packages/pip/_vendor/distlib/markers.py index ee1f3e23..9dc68410 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/markers.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/markers.py @@ -13,20 +13,29 @@ Parser for the environment markers micro-language defined in PEP 508. # as ~= and === which aren't in Python, necessitating a different approach. import os +import re import sys import platform -import re -from .compat import python_implementation, urlparse, string_types +from .compat import string_types from .util import in_venv, parse_marker +from .version import NormalizedVersion as NV __all__ = ['interpret'] +_VERSION_PATTERN = re.compile(r'((\d+(\.\d+)*\w*)|\'(\d+(\.\d+)*\w*)\'|\"(\d+(\.\d+)*\w*)\")') + def _is_literal(o): if not isinstance(o, string_types) or not o: return False return o[0] in '\'"' +def _get_versions(s): + result = [] + for m in _VERSION_PATTERN.finditer(s): + result.append(NV(m.groups()[0])) + return set(result) + class Evaluator(object): """ This class is used to evaluate marker expessions. @@ -71,9 +80,18 @@ class Evaluator(object): lhs = self.evaluate(elhs, context) rhs = self.evaluate(erhs, context) + if ((elhs == 'python_version' or erhs == 'python_version') and + op in ('<', '<=', '>', '>=', '===', '==', '!=', '~=')): + lhs = NV(lhs) + rhs = NV(rhs) + elif elhs == 'python_version' and op in ('in', 'not in'): + lhs = NV(lhs) + rhs = _get_versions(rhs) result = self.operations[op](lhs, rhs) return result +_DIGITS = re.compile(r'\d+\.\d+') + def default_context(): def format_full_version(info): version = '%s.%s.%s' % (info.major, info.minor, info.micro) @@ -89,6 +107,9 @@ def default_context(): implementation_version = '0' implementation_name = '' + ppv = platform.python_version() + m = _DIGITS.match(ppv) + pv = m.group(0) result = { 'implementation_name': implementation_name, 'implementation_version': implementation_version, @@ -99,8 +120,8 @@ def default_context(): 'platform_system': platform.system(), 'platform_version': platform.version(), 'platform_in_venv': str(in_venv()), - 'python_full_version': platform.python_version(), - 'python_version': platform.python_version()[:3], + 'python_full_version': ppv, + 'python_version': pv, 'sys_platform': sys.platform, } return result diff --git a/env/Lib/site-packages/pip/_vendor/distlib/metadata.py b/env/Lib/site-packages/pip/_vendor/distlib/metadata.py index 6d5e2360..c329e197 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/metadata.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/metadata.py @@ -5,7 +5,7 @@ # """Implementation of the Metadata for Python packages PEPs. -Supports all metadata formats (1.0, 1.1, 1.2, 1.3/2.1 and withdrawn 2.0). +Supports all metadata formats (1.0, 1.1, 1.2, 1.3/2.1 and 2.2). """ from __future__ import unicode_literals @@ -94,17 +94,23 @@ _426_MARKERS = ('Private-Version', 'Provides-Extra', 'Obsoleted-By', # See issue #106: Sometimes 'Requires' and 'Provides' occur wrongly in # the metadata. Include them in the tuple literal below to allow them # (for now). +# Ditto for Obsoletes - see issue #140. _566_FIELDS = _426_FIELDS + ('Description-Content-Type', - 'Requires', 'Provides') + 'Requires', 'Provides', 'Obsoletes') _566_MARKERS = ('Description-Content-Type',) +_643_MARKERS = ('Dynamic', 'License-File') + +_643_FIELDS = _566_FIELDS + _643_MARKERS + _ALL_FIELDS = set() _ALL_FIELDS.update(_241_FIELDS) _ALL_FIELDS.update(_314_FIELDS) _ALL_FIELDS.update(_345_FIELDS) _ALL_FIELDS.update(_426_FIELDS) _ALL_FIELDS.update(_566_FIELDS) +_ALL_FIELDS.update(_643_FIELDS) EXTRA_RE = re.compile(r'''extra\s*==\s*("([^"]+)"|'([^']+)')''') @@ -117,9 +123,13 @@ def _version2fieldlist(version): elif version == '1.2': return _345_FIELDS elif version in ('1.3', '2.1'): - return _345_FIELDS + _566_FIELDS + # avoid adding field names if already there + return _345_FIELDS + tuple(f for f in _566_FIELDS if f not in _345_FIELDS) elif version == '2.0': - return _426_FIELDS + raise ValueError('Metadata 2.0 is withdrawn and not supported') + # return _426_FIELDS + elif version == '2.2': + return _643_FIELDS raise MetadataUnrecognizedVersionError(version) @@ -137,7 +147,7 @@ def _best_version(fields): continue keys.append(key) - possible_versions = ['1.0', '1.1', '1.2', '1.3', '2.0', '2.1'] + possible_versions = ['1.0', '1.1', '1.2', '1.3', '2.1', '2.2'] # 2.0 removed # first let's try to see if a field is not part of one of the version for key in keys: @@ -157,9 +167,12 @@ def _best_version(fields): if key != 'Description': # In 2.1, description allowed after headers possible_versions.remove('2.1') logger.debug('Removed 2.1 due to %s', key) - if key not in _426_FIELDS and '2.0' in possible_versions: - possible_versions.remove('2.0') - logger.debug('Removed 2.0 due to %s', key) + if key not in _643_FIELDS and '2.2' in possible_versions: + possible_versions.remove('2.2') + logger.debug('Removed 2.2 due to %s', key) + # if key not in _426_FIELDS and '2.0' in possible_versions: + # possible_versions.remove('2.0') + # logger.debug('Removed 2.0 due to %s', key) # possible_version contains qualified versions if len(possible_versions) == 1: @@ -172,16 +185,18 @@ def _best_version(fields): is_1_1 = '1.1' in possible_versions and _has_marker(keys, _314_MARKERS) is_1_2 = '1.2' in possible_versions and _has_marker(keys, _345_MARKERS) is_2_1 = '2.1' in possible_versions and _has_marker(keys, _566_MARKERS) - is_2_0 = '2.0' in possible_versions and _has_marker(keys, _426_MARKERS) - if int(is_1_1) + int(is_1_2) + int(is_2_1) + int(is_2_0) > 1: - raise MetadataConflictError('You used incompatible 1.1/1.2/2.0/2.1 fields') + # is_2_0 = '2.0' in possible_versions and _has_marker(keys, _426_MARKERS) + is_2_2 = '2.2' in possible_versions and _has_marker(keys, _643_MARKERS) + if int(is_1_1) + int(is_1_2) + int(is_2_1) + int(is_2_2) > 1: + raise MetadataConflictError('You used incompatible 1.1/1.2/2.1/2.2 fields') - # we have the choice, 1.0, or 1.2, or 2.0 + # we have the choice, 1.0, or 1.2, 2.1 or 2.2 # - 1.0 has a broken Summary field but works with all tools # - 1.1 is to avoid # - 1.2 fixes Summary but has little adoption - # - 2.0 adds more features and is very new - if not is_1_1 and not is_1_2 and not is_2_1 and not is_2_0: + # - 2.1 adds more features + # - 2.2 is the latest + if not is_1_1 and not is_1_2 and not is_2_1 and not is_2_2: # we couldn't find any specific marker if PKG_INFO_PREFERRED_VERSION in possible_versions: return PKG_INFO_PREFERRED_VERSION @@ -191,8 +206,10 @@ def _best_version(fields): return '1.2' if is_2_1: return '2.1' + # if is_2_2: + # return '2.2' - return '2.0' + return '2.2' # This follows the rules about transforming keys as described in # https://www.python.org/dev/peps/pep-0566/#id17 @@ -208,7 +225,7 @@ _LISTFIELDS = ('Platform', 'Classifier', 'Obsoletes', 'Requires', 'Provides', 'Obsoletes-Dist', 'Provides-Dist', 'Requires-Dist', 'Requires-External', 'Project-URL', 'Supported-Platform', 'Setup-Requires-Dist', - 'Provides-Extra', 'Extension') + 'Provides-Extra', 'Extension', 'License-File') _LISTTUPLEFIELDS = ('Project-URL',) _ELEMENTSFIELD = ('Keywords',) @@ -600,7 +617,7 @@ LEGACY_METADATA_FILENAME = 'METADATA' class Metadata(object): """ - The metadata of a release. This implementation uses 2.0 (JSON) + The metadata of a release. This implementation uses 2.1 metadata where possible. If not possible, it wraps a LegacyMetadata instance which handles the key-value metadata format. """ @@ -609,6 +626,8 @@ class Metadata(object): NAME_MATCHER = re.compile('^[0-9A-Z]([0-9A-Z_.-]*[0-9A-Z])?$', re.I) + FIELDNAME_MATCHER = re.compile('^[A-Z]([0-9A-Z-]*[0-9A-Z])?$', re.I) + VERSION_MATCHER = PEP440_VERSION_RE SUMMARY_MATCHER = re.compile('.{1,2047}') @@ -636,6 +655,7 @@ class Metadata(object): 'name': (NAME_MATCHER, ('legacy',)), 'version': (VERSION_MATCHER, ('legacy',)), 'summary': (SUMMARY_MATCHER, ('legacy',)), + 'dynamic': (FIELDNAME_MATCHER, ('legacy',)), } __slots__ = ('_legacy', '_data', 'scheme') diff --git a/env/Lib/site-packages/pip/_vendor/distlib/resources.py b/env/Lib/site-packages/pip/_vendor/distlib/resources.py index 18840167..fef52aa1 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/resources.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/resources.py @@ -11,13 +11,12 @@ import io import logging import os import pkgutil -import shutil import sys import types import zipimport from . import DistlibException -from .util import cached_property, get_cache_base, path_to_cache_dir, Cache +from .util import cached_property, get_cache_base, Cache logger = logging.getLogger(__name__) @@ -283,6 +282,7 @@ class ZipResourceFinder(ResourceFinder): result = False return result + _finder_registry = { type(None): ResourceFinder, zipimport.zipimporter: ZipResourceFinder @@ -296,6 +296,8 @@ try: import _frozen_importlib as _fi _finder_registry[_fi.SourceFileLoader] = ResourceFinder _finder_registry[_fi.FileFinder] = ResourceFinder + # See issue #146 + _finder_registry[_fi.SourcelessFileLoader] = ResourceFinder del _fi except (ImportError, AttributeError): pass @@ -304,6 +306,7 @@ except (ImportError, AttributeError): def register_finder(loader, finder_maker): _finder_registry[type(loader)] = finder_maker + _finder_cache = {} diff --git a/env/Lib/site-packages/pip/_vendor/distlib/scripts.py b/env/Lib/site-packages/pip/_vendor/distlib/scripts.py index 03f8f21e..d2706242 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/scripts.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/scripts.py @@ -10,11 +10,13 @@ import os import re import struct import sys +import time +from zipfile import ZipInfo from .compat import sysconfig, detect_encoding, ZipFile from .resources import finder from .util import (FileOperator, get_export_entry, convert_path, - get_executable, in_venv) + get_executable, get_platform, in_venv) logger = logging.getLogger(__name__) @@ -170,6 +172,11 @@ class ScriptMaker(object): sysconfig.get_config_var('BINDIR'), 'python%s%s' % (sysconfig.get_config_var('VERSION'), sysconfig.get_config_var('EXE'))) + if not os.path.isfile(executable): + # for Python builds from source on Windows, no Python executables with + # a version suffix are created, so we use python.exe + executable = os.path.join(sysconfig.get_config_var('BINDIR'), + 'python%s' % (sysconfig.get_config_var('EXE'))) if options: executable = self._get_alternate_executable(executable, options) @@ -244,7 +251,13 @@ class ScriptMaker(object): launcher = self._get_launcher('w') stream = BytesIO() with ZipFile(stream, 'w') as zf: - zf.writestr('__main__.py', script_bytes) + source_date_epoch = os.environ.get('SOURCE_DATE_EPOCH') + if source_date_epoch: + date_time = time.gmtime(int(source_date_epoch))[:6] + zinfo = ZipInfo(filename='__main__.py', date_time=date_time) + zf.writestr(zinfo, script_bytes) + else: + zf.writestr('__main__.py', script_bytes) zip_data = stream.getvalue() script_bytes = launcher + shebang + zip_data for name in names: @@ -282,6 +295,19 @@ class ScriptMaker(object): self._fileop.set_executable_mode([outname]) filenames.append(outname) + variant_separator = '-' + + def get_script_filenames(self, name): + result = set() + if '' in self.variants: + result.add(name) + if 'X' in self.variants: + result.add('%s%s' % (name, self.version_info[0])) + if 'X.Y' in self.variants: + result.add('%s%s%s.%s' % (name, self.variant_separator, + self.version_info[0], self.version_info[1])) + return result + def _make_script(self, entry, filenames, options=None): post_interp = b'' if options: @@ -291,15 +317,7 @@ class ScriptMaker(object): post_interp = args.encode('utf-8') shebang = self._get_shebang('utf-8', post_interp, options=options) script = self._get_script_text(entry).encode('utf-8') - name = entry.name - scriptnames = set() - if '' in self.variants: - scriptnames.add(name) - if 'X' in self.variants: - scriptnames.add('%s%s' % (name, self.version_info[0])) - if 'X.Y' in self.variants: - scriptnames.add('%s-%s.%s' % (name, self.version_info[0], - self.version_info[1])) + scriptnames = self.get_script_filenames(entry.name) if options and options.get('gui', False): ext = 'pyw' else: @@ -326,8 +344,7 @@ class ScriptMaker(object): else: first_line = f.readline() if not first_line: # pragma: no cover - logger.warning('%s: %s is an empty file (skipping)', - self.get_command_name(), script) + logger.warning('%s is an empty file (skipping)', script) return match = FIRST_LINE_RE.match(first_line.replace(b'\r\n', b'\n')) @@ -375,7 +392,8 @@ class ScriptMaker(object): bits = '64' else: bits = '32' - name = '%s%s.exe' % (kind, bits) + platform_suffix = '-arm' if get_platform() == 'win-arm64' else '' + name = '%s%s%s.exe' % (kind, bits, platform_suffix) # Issue 31: don't hardcode an absolute package name, but # determine it relative to the current package distlib_package = __name__.rsplit('.', 1)[0] diff --git a/env/Lib/site-packages/pip/_vendor/distlib/t32.exe b/env/Lib/site-packages/pip/_vendor/distlib/t32.exe index 8932a18e4596952373a38c60b81b7116d4ef9ee8..52154f0be32cc2bdbf98af131d477900667d0abd 100644 GIT binary patch delta 24794 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 delta 23300 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 X;|InJCJH7x+ZUEG#<Ne}@WucD$>4P9 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/t64.exe b/env/Lib/site-packages/pip/_vendor/distlib/t64.exe index 325b8057c08cf7113d4fd889991fa5638d443793..e8bebdba6d8f242244bf397ab067965d47c5093e 100644 GIT binary patch delta 29243 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 E0ItXz`~Uy| delta 28003 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 Q91A5DYHZhC#CVw*0ORfgx&QzG diff --git a/env/Lib/site-packages/pip/_vendor/distlib/util.py b/env/Lib/site-packages/pip/_vendor/distlib/util.py index 01324eae..dd01849d 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/util.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/util.py @@ -1,5 +1,5 @@ # -# Copyright (C) 2012-2017 The Python Software Foundation. +# Copyright (C) 2012-2021 The Python Software Foundation. # See LICENSE.txt and CONTRIBUTORS.txt. # import codecs @@ -215,6 +215,10 @@ def parse_requirement(req): if not ver_remaining or ver_remaining[0] != ',': break ver_remaining = ver_remaining[1:].lstrip() + # Some packages have a trailing comma which would break things + # See issue #148 + if not ver_remaining: + break m = COMPARE_OP.match(ver_remaining) if not m: raise SyntaxError('invalid constraint: %s' % ver_remaining) @@ -309,7 +313,9 @@ def get_executable(): # else: # result = sys.executable # return result - result = os.path.normcase(sys.executable) + # Avoid normcasing: see issue #143 + # result = os.path.normcase(sys.executable) + result = sys.executable if not isinstance(result, text_type): result = fsdecode(result) return result @@ -1426,29 +1432,19 @@ if ssl: self.sock = sock self._tunnel() - if not hasattr(ssl, 'SSLContext'): - # For 2.x - if self.ca_certs: - cert_reqs = ssl.CERT_REQUIRED - else: - cert_reqs = ssl.CERT_NONE - self.sock = ssl.wrap_socket(sock, self.key_file, self.cert_file, - cert_reqs=cert_reqs, - ssl_version=ssl.PROTOCOL_SSLv23, - ca_certs=self.ca_certs) - else: # pragma: no cover - context = ssl.SSLContext(ssl.PROTOCOL_SSLv23) - if hasattr(ssl, 'OP_NO_SSLv2'): - context.options |= ssl.OP_NO_SSLv2 - if self.cert_file: - context.load_cert_chain(self.cert_file, self.key_file) - kwargs = {} - if self.ca_certs: - context.verify_mode = ssl.CERT_REQUIRED - context.load_verify_locations(cafile=self.ca_certs) - if getattr(ssl, 'HAS_SNI', False): - kwargs['server_hostname'] = self.host - self.sock = context.wrap_socket(sock, **kwargs) + context = ssl.SSLContext(ssl.PROTOCOL_SSLv23) + if hasattr(ssl, 'OP_NO_SSLv2'): + context.options |= ssl.OP_NO_SSLv2 + if self.cert_file: + context.load_cert_chain(self.cert_file, self.key_file) + kwargs = {} + if self.ca_certs: + context.verify_mode = ssl.CERT_REQUIRED + context.load_verify_locations(cafile=self.ca_certs) + if getattr(ssl, 'HAS_SNI', False): + kwargs['server_hostname'] = self.host + + self.sock = context.wrap_socket(sock, **kwargs) if self.ca_certs and self.check_domain: try: match_hostname(self.sock.getpeercert(), self.host) @@ -1507,25 +1503,6 @@ if ssl: # # XML-RPC with timeouts # - -_ver_info = sys.version_info[:2] - -if _ver_info == (2, 6): - class HTTP(httplib.HTTP): - def __init__(self, host='', port=None, **kwargs): - if port == 0: # 0 means use port 0, not the default port - port = None - self._setup(self._connection_class(host, port, **kwargs)) - - - if ssl: - class HTTPS(httplib.HTTPS): - def __init__(self, host='', port=None, **kwargs): - if port == 0: # 0 means use port 0, not the default port - port = None - self._setup(self._connection_class(host, port, **kwargs)) - - class Transport(xmlrpclib.Transport): def __init__(self, timeout, use_datetime=0): self.timeout = timeout @@ -1533,14 +1510,10 @@ class Transport(xmlrpclib.Transport): def make_connection(self, host): h, eh, x509 = self.get_host_info(host) - if _ver_info == (2, 6): - result = HTTP(h, timeout=self.timeout) - else: - if not self._connection or host != self._connection[0]: - self._extra_headers = eh - self._connection = host, httplib.HTTPConnection(h) - result = self._connection[1] - return result + if not self._connection or host != self._connection[0]: + self._extra_headers = eh + self._connection = host, httplib.HTTPConnection(h) + return self._connection[1] if ssl: class SafeTransport(xmlrpclib.SafeTransport): @@ -1553,15 +1526,11 @@ if ssl: if not kwargs: kwargs = {} kwargs['timeout'] = self.timeout - if _ver_info == (2, 6): - result = HTTPS(host, None, **kwargs) - else: - if not self._connection or host != self._connection[0]: - self._extra_headers = eh - self._connection = host, httplib.HTTPSConnection(h, None, - **kwargs) - result = self._connection[1] - return result + if not self._connection or host != self._connection[0]: + self._extra_headers = eh + self._connection = host, httplib.HTTPSConnection(h, None, + **kwargs) + return self._connection[1] class ServerProxy(xmlrpclib.ServerProxy): @@ -1570,7 +1539,8 @@ class ServerProxy(xmlrpclib.ServerProxy): # The above classes only come into play if a timeout # is specified if timeout is not None: - scheme, _ = splittype(uri) + # scheme = splittype(uri) # deprecated as of Python 3.8 + scheme = urlparse(uri)[0] use_datetime = kwargs.get('use_datetime', 0) if scheme == 'https': tcls = SafeTransport @@ -1759,3 +1729,204 @@ def normalize_name(name): """Normalize a python package name a la PEP 503""" # https://www.python.org/dev/peps/pep-0503/#normalized-names return re.sub('[-_.]+', '-', name).lower() + +# def _get_pypirc_command(): + # """ + # Get the distutils command for interacting with PyPI configurations. + # :return: the command. + # """ + # from distutils.core import Distribution + # from distutils.config import PyPIRCCommand + # d = Distribution() + # return PyPIRCCommand(d) + +class PyPIRCFile(object): + + DEFAULT_REPOSITORY = 'https://upload.pypi.org/legacy/' + DEFAULT_REALM = 'pypi' + + def __init__(self, fn=None, url=None): + if fn is None: + fn = os.path.join(os.path.expanduser('~'), '.pypirc') + self.filename = fn + self.url = url + + def read(self): + result = {} + + if os.path.exists(self.filename): + repository = self.url or self.DEFAULT_REPOSITORY + + config = configparser.RawConfigParser() + config.read(self.filename) + sections = config.sections() + if 'distutils' in sections: + # let's get the list of servers + index_servers = config.get('distutils', 'index-servers') + _servers = [server.strip() for server in + index_servers.split('\n') + if server.strip() != ''] + if _servers == []: + # nothing set, let's try to get the default pypi + if 'pypi' in sections: + _servers = ['pypi'] + else: + for server in _servers: + result = {'server': server} + result['username'] = config.get(server, 'username') + + # optional params + for key, default in (('repository', self.DEFAULT_REPOSITORY), + ('realm', self.DEFAULT_REALM), + ('password', None)): + if config.has_option(server, key): + result[key] = config.get(server, key) + else: + result[key] = default + + # work around people having "repository" for the "pypi" + # section of their config set to the HTTP (rather than + # HTTPS) URL + if (server == 'pypi' and + repository in (self.DEFAULT_REPOSITORY, 'pypi')): + result['repository'] = self.DEFAULT_REPOSITORY + elif (result['server'] != repository and + result['repository'] != repository): + result = {} + elif 'server-login' in sections: + # old format + server = 'server-login' + if config.has_option(server, 'repository'): + repository = config.get(server, 'repository') + else: + repository = self.DEFAULT_REPOSITORY + result = { + 'username': config.get(server, 'username'), + 'password': config.get(server, 'password'), + 'repository': repository, + 'server': server, + 'realm': self.DEFAULT_REALM + } + return result + + def update(self, username, password): + # import pdb; pdb.set_trace() + config = configparser.RawConfigParser() + fn = self.filename + config.read(fn) + if not config.has_section('pypi'): + config.add_section('pypi') + config.set('pypi', 'username', username) + config.set('pypi', 'password', password) + with open(fn, 'w') as f: + config.write(f) + +def _load_pypirc(index): + """ + Read the PyPI access configuration as supported by distutils. + """ + return PyPIRCFile(url=index.url).read() + +def _store_pypirc(index): + PyPIRCFile().update(index.username, index.password) + +# +# get_platform()/get_host_platform() copied from Python 3.10.a0 source, with some minor +# tweaks +# + +def get_host_platform(): + """Return a string that identifies the current platform. This is used mainly to + distinguish platform-specific build directories and platform-specific built + distributions. Typically includes the OS name and version and the + architecture (as supplied by 'os.uname()'), although the exact information + included depends on the OS; eg. on Linux, the kernel version isn't + particularly important. + + Examples of returned values: + linux-i586 + linux-alpha (?) + solaris-2.6-sun4u + + Windows will return one of: + win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc) + win32 (all others - specifically, sys.platform is returned) + + For other non-POSIX platforms, currently just returns 'sys.platform'. + + """ + if os.name == 'nt': + if 'amd64' in sys.version.lower(): + return 'win-amd64' + if '(arm)' in sys.version.lower(): + return 'win-arm32' + if '(arm64)' in sys.version.lower(): + return 'win-arm64' + return sys.platform + + # Set for cross builds explicitly + if "_PYTHON_HOST_PLATFORM" in os.environ: + return os.environ["_PYTHON_HOST_PLATFORM"] + + if os.name != 'posix' or not hasattr(os, 'uname'): + # XXX what about the architecture? NT is Intel or Alpha, + # Mac OS is M68k or PPC, etc. + return sys.platform + + # Try to distinguish various flavours of Unix + + (osname, host, release, version, machine) = os.uname() + + # Convert the OS name to lowercase, remove '/' characters, and translate + # spaces (for "Power Macintosh") + osname = osname.lower().replace('/', '') + machine = machine.replace(' ', '_').replace('/', '-') + + if osname[:5] == 'linux': + # At least on Linux/Intel, 'machine' is the processor -- + # i386, etc. + # XXX what about Alpha, SPARC, etc? + return "%s-%s" % (osname, machine) + + elif osname[:5] == 'sunos': + if release[0] >= '5': # SunOS 5 == Solaris 2 + osname = 'solaris' + release = '%d.%s' % (int(release[0]) - 3, release[2:]) + # We can't use 'platform.architecture()[0]' because a + # bootstrap problem. We use a dict to get an error + # if some suspicious happens. + bitness = {2147483647:'32bit', 9223372036854775807:'64bit'} + machine += '.%s' % bitness[sys.maxsize] + # fall through to standard osname-release-machine representation + elif osname[:3] == 'aix': + from _aix_support import aix_platform + return aix_platform() + elif osname[:6] == 'cygwin': + osname = 'cygwin' + rel_re = re.compile (r'[\d.]+', re.ASCII) + m = rel_re.match(release) + if m: + release = m.group() + elif osname[:6] == 'darwin': + import _osx_support, distutils.sysconfig + osname, release, machine = _osx_support.get_platform_osx( + distutils.sysconfig.get_config_vars(), + osname, release, machine) + + return '%s-%s-%s' % (osname, release, machine) + + +_TARGET_TO_PLAT = { + 'x86' : 'win32', + 'x64' : 'win-amd64', + 'arm' : 'win-arm32', +} + + +def get_platform(): + if os.name != 'nt': + return get_host_platform() + cross_compilation_target = os.environ.get('VSCMD_ARG_TGT_ARCH') + if cross_compilation_target not in _TARGET_TO_PLAT: + return get_host_platform() + return _TARGET_TO_PLAT[cross_compilation_target] diff --git a/env/Lib/site-packages/pip/_vendor/distlib/version.py b/env/Lib/site-packages/pip/_vendor/distlib/version.py index 3eebe18e..c7c8bb6f 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/version.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/version.py @@ -194,7 +194,7 @@ def _pep_440_key(s): if not groups[0]: epoch = 0 else: - epoch = int(groups[0]) + epoch = int(groups[0][:-1]) pre = groups[4:6] post = groups[7:9] dev = groups[10:12] @@ -710,6 +710,9 @@ class VersionScheme(object): """ Used for processing some metadata fields """ + # See issue #140. Be tolerant of a single trailing comma. + if s.endswith(','): + s = s[:-1] return self.is_valid_matcher('dummy_name (%s)' % s) def suggest(self, s): diff --git a/env/Lib/site-packages/pip/_vendor/distlib/w32.exe b/env/Lib/site-packages/pip/_vendor/distlib/w32.exe index e6439e9e45897365d5ac6a85a46864c158a225fd..4ee2d3a31b59e8b50f433ecdf0be9e496e8cc3b8 100644 GIT binary patch delta 25715 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∋mh% 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 delta 24157 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 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/w64.exe b/env/Lib/site-packages/pip/_vendor/distlib/w64.exe index 46139dbf9400b7bc0b64e6756ce17b4eb5fd7436..5763076d2878093971a0ef9870e1cde7f556b18b 100644 GIT binary patch delta 30933 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 delta 29256 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 OPgp!-dtx`^d?o;n1Xor7 diff --git a/env/Lib/site-packages/pip/_vendor/distlib/wheel.py b/env/Lib/site-packages/pip/_vendor/distlib/wheel.py index 1e2c7a02..028c2d99 100644 --- a/env/Lib/site-packages/pip/_vendor/distlib/wheel.py +++ b/env/Lib/site-packages/pip/_vendor/distlib/wheel.py @@ -1,6 +1,6 @@ # -*- coding: utf-8 -*- # -# Copyright (C) 2013-2017 Vinay Sajip. +# Copyright (C) 2013-2020 Vinay Sajip. # Licensed to the Python Software Foundation under a contributor agreement. # See LICENSE.txt and CONTRIBUTORS.txt. # @@ -9,10 +9,8 @@ from __future__ import unicode_literals import base64 import codecs import datetime -import distutils.util from email import message_from_file import hashlib -import imp import json import logging import os @@ -29,7 +27,8 @@ from .database import InstalledDistribution from .metadata import (Metadata, METADATA_FILENAME, WHEEL_METADATA_FILENAME, LEGACY_METADATA_FILENAME) from .util import (FileOperator, convert_path, CSVReader, CSVWriter, Cache, - cached_property, get_cache_base, read_exports, tempdir) + cached_property, get_cache_base, read_exports, tempdir, + get_platform) from .version import NormalizedVersion, UnsupportedVersionError logger = logging.getLogger(__name__) @@ -51,20 +50,28 @@ if not VER_SUFFIX: # pragma: no cover PYVER = 'py' + VER_SUFFIX IMPVER = IMP_PREFIX + VER_SUFFIX -ARCH = distutils.util.get_platform().replace('-', '_').replace('.', '_') +ARCH = get_platform().replace('-', '_').replace('.', '_') ABI = sysconfig.get_config_var('SOABI') if ABI and ABI.startswith('cpython-'): - ABI = ABI.replace('cpython-', 'cp') + ABI = ABI.replace('cpython-', 'cp').split('-')[0] else: def _derive_abi(): parts = ['cp', VER_SUFFIX] if sysconfig.get_config_var('Py_DEBUG'): parts.append('d') - if sysconfig.get_config_var('WITH_PYMALLOC'): - parts.append('m') - if sysconfig.get_config_var('Py_UNICODE_SIZE') == 4: - parts.append('u') + if IMP_PREFIX == 'cp': + vi = sys.version_info[:2] + if vi < (3, 8): + wpm = sysconfig.get_config_var('WITH_PYMALLOC') + if wpm is None: + wpm = True + if wpm: + parts.append('m') + if vi < (3, 3): + us = sysconfig.get_config_var('Py_UNICODE_SIZE') + if us == 4 or (us is None and sys.maxunicode == 0x10FFFF): + parts.append('u') return ''.join(parts) ABI = _derive_abi() del _derive_abi @@ -95,6 +102,29 @@ if os.sep == '/': else: to_posix = lambda o: o.replace(os.sep, '/') +if sys.version_info[0] < 3: + import imp +else: + imp = None + import importlib.machinery + import importlib.util + +def _get_suffixes(): + if imp: + return [s[0] for s in imp.get_suffixes()] + else: + return importlib.machinery.EXTENSION_SUFFIXES + +def _load_dynamic(name, path): + # https://docs.python.org/3/library/importlib.html#importing-a-source-file-directly + if imp: + return imp.load_dynamic(name, path) + else: + spec = importlib.util.spec_from_file_location(name, path) + module = importlib.util.module_from_spec(spec) + sys.modules[name] = module + spec.loader.exec_module(module) + return module class Mounter(object): def __init__(self): @@ -124,7 +154,7 @@ class Mounter(object): else: if fullname not in self.libs: raise ImportError('unable to find extension for %s' % fullname) - result = imp.load_dynamic(fullname, self.libs[fullname]) + result = _load_dynamic(fullname, self.libs[fullname]) result.__loader__ = self parts = fullname.rsplit('.', 1) if len(parts) > 1: @@ -301,10 +331,9 @@ class Wheel(object): result = base64.urlsafe_b64encode(result).rstrip(b'=').decode('ascii') return hash_kind, result - def write_record(self, records, record_path, base): + def write_record(self, records, record_path, archive_record_path): records = list(records) # make a copy, as mutated - p = to_posix(os.path.relpath(record_path, base)) - records.append((p, '', '')) + records.append((archive_record_path, '', '')) with CSVWriter(record_path) as writer: for row in records: writer.writerow(row) @@ -321,8 +350,8 @@ class Wheel(object): records.append((ap, digest, size)) p = os.path.join(distinfo, 'RECORD') - self.write_record(records, p, libdir) ap = to_posix(os.path.join(info_dir, 'RECORD')) + self.write_record(records, p, ap) archive_paths.append((ap, p)) def build_zip(self, pathname, archive_paths): @@ -576,6 +605,13 @@ class Wheel(object): if not is_script: with zf.open(arcname) as bf: fileop.copy_stream(bf, outfile) + # Issue #147: permission bits aren't preserved. Using + # zf.extract(zinfo, libdir) should have worked, but didn't, + # see https://www.thetopsites.net/article/53834422.shtml + # So ... manually preserve permission bits as given in zinfo + if os.name == 'posix': + # just set the normal permission bits + os.chmod(outfile, (zinfo.external_attr >> 16) & 0x1FF) outfiles.append(outfile) # Double check the digest of the written file if not dry_run and row[1]: @@ -938,6 +974,16 @@ class Wheel(object): shutil.copyfile(newpath, pathname) return modified +def _get_glibc_version(): + import platform + ver = platform.libc_ver() + result = [] + if ver[0] == 'glibc': + for s in ver[1].split('.'): + result.append(int(s) if s.isdigit() else 0) + result = tuple(result) + return result + def compatible_tags(): """ Return (pyver, abi, arch) tuples compatible with this Python. @@ -948,7 +994,7 @@ def compatible_tags(): versions.append(''.join([major, str(minor)])) abis = [] - for suffix, _, _ in imp.get_suffixes(): + for suffix in _get_suffixes(): if suffix.startswith('.abi'): abis.append(suffix.split('.', 2)[1]) abis.sort() @@ -985,6 +1031,23 @@ def compatible_tags(): for abi in abis: for arch in arches: result.append((''.join((IMP_PREFIX, versions[0])), abi, arch)) + # manylinux + if abi != 'none' and sys.platform.startswith('linux'): + arch = arch.replace('linux_', '') + parts = _get_glibc_version() + if len(parts) == 2: + if parts >= (2, 5): + result.append((''.join((IMP_PREFIX, versions[0])), abi, + 'manylinux1_%s' % arch)) + if parts >= (2, 12): + result.append((''.join((IMP_PREFIX, versions[0])), abi, + 'manylinux2010_%s' % arch)) + if parts >= (2, 17): + result.append((''.join((IMP_PREFIX, versions[0])), abi, + 'manylinux2014_%s' % arch)) + result.append((''.join((IMP_PREFIX, versions[0])), abi, + 'manylinux_%s_%s_%s' % (parts[0], parts[1], + arch))) # where no ABI / arch dependency, but IMP_PREFIX dependency for i, version in enumerate(versions): @@ -997,6 +1060,7 @@ def compatible_tags(): result.append((''.join(('py', version)), 'none', 'any')) if i == 0: result.append((''.join(('py', version[0])), 'none', 'any')) + return set(result) diff --git a/env/Lib/site-packages/pip/_vendor/distro.py b/env/Lib/site-packages/pip/_vendor/distro.py deleted file mode 100644 index 0611b62a..00000000 --- a/env/Lib/site-packages/pip/_vendor/distro.py +++ /dev/null @@ -1,1230 +0,0 @@ -# Copyright 2015,2016,2017 Nir Cohen -# -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. - -""" -The ``distro`` package (``distro`` stands for Linux Distribution) provides -information about the Linux distribution it runs on, such as a reliable -machine-readable distro ID, or version information. - -It is the recommended replacement for Python's original -:py:func:`platform.linux_distribution` function, but it provides much more -functionality. An alternative implementation became necessary because Python -3.5 deprecated this function, and Python 3.8 will remove it altogether. -Its predecessor function :py:func:`platform.dist` was already -deprecated since Python 2.6 and will also be removed in Python 3.8. -Still, there are many cases in which access to OS distribution information -is needed. See `Python issue 1322 <https://bugs.python.org/issue1322>`_ for -more information. -""" - -import os -import re -import sys -import json -import shlex -import logging -import argparse -import subprocess - - -_UNIXCONFDIR = os.environ.get('UNIXCONFDIR', '/etc') -_OS_RELEASE_BASENAME = 'os-release' - -#: Translation table for normalizing the "ID" attribute defined in os-release -#: files, for use by the :func:`distro.id` method. -#: -#: * Key: Value as defined in the os-release file, translated to lower case, -#: with blanks translated to underscores. -#: -#: * Value: Normalized value. -NORMALIZED_OS_ID = { - 'ol': 'oracle', # Oracle Linux -} - -#: Translation table for normalizing the "Distributor ID" attribute returned by -#: the lsb_release command, for use by the :func:`distro.id` method. -#: -#: * Key: Value as returned by the lsb_release command, translated to lower -#: case, with blanks translated to underscores. -#: -#: * Value: Normalized value. -NORMALIZED_LSB_ID = { - 'enterpriseenterpriseas': 'oracle', # Oracle Enterprise Linux 4 - 'enterpriseenterpriseserver': 'oracle', # Oracle Linux 5 - 'redhatenterpriseworkstation': 'rhel', # RHEL 6, 7 Workstation - 'redhatenterpriseserver': 'rhel', # RHEL 6, 7 Server - 'redhatenterprisecomputenode': 'rhel', # RHEL 6 ComputeNode -} - -#: Translation table for normalizing the distro ID derived from the file name -#: of distro release files, for use by the :func:`distro.id` method. -#: -#: * Key: Value as derived from the file name of a distro release file, -#: translated to lower case, with blanks translated to underscores. -#: -#: * Value: Normalized value. -NORMALIZED_DISTRO_ID = { - 'redhat': 'rhel', # RHEL 6.x, 7.x -} - -# Pattern for content of distro release file (reversed) -_DISTRO_RELEASE_CONTENT_REVERSED_PATTERN = re.compile( - r'(?:[^)]*\)(.*)\()? *(?:STL )?([\d.+\-a-z]*\d) *(?:esaeler *)?(.+)') - -# Pattern for base file name of distro release file -_DISTRO_RELEASE_BASENAME_PATTERN = re.compile( - r'(\w+)[-_](release|version)$') - -# Base file names to be ignored when searching for distro release file -_DISTRO_RELEASE_IGNORE_BASENAMES = ( - 'debian_version', - 'lsb-release', - 'oem-release', - _OS_RELEASE_BASENAME, - 'system-release', - 'plesk-release', -) - - -def linux_distribution(full_distribution_name=True): - """ - Return information about the current OS distribution as a tuple - ``(id_name, version, codename)`` with items as follows: - - * ``id_name``: If *full_distribution_name* is false, the result of - :func:`distro.id`. Otherwise, the result of :func:`distro.name`. - - * ``version``: The result of :func:`distro.version`. - - * ``codename``: The result of :func:`distro.codename`. - - The interface of this function is compatible with the original - :py:func:`platform.linux_distribution` function, supporting a subset of - its parameters. - - The data it returns may not exactly be the same, because it uses more data - sources than the original function, and that may lead to different data if - the OS distribution is not consistent across multiple data sources it - provides (there are indeed such distributions ...). - - Another reason for differences is the fact that the :func:`distro.id` - method normalizes the distro ID string to a reliable machine-readable value - for a number of popular OS distributions. - """ - return _distro.linux_distribution(full_distribution_name) - - -def id(): - """ - Return the distro ID of the current distribution, as a - machine-readable string. - - For a number of OS distributions, the returned distro ID value is - *reliable*, in the sense that it is documented and that it does not change - across releases of the distribution. - - This package maintains the following reliable distro ID values: - - ============== ========================================= - Distro ID Distribution - ============== ========================================= - "ubuntu" Ubuntu - "debian" Debian - "rhel" RedHat Enterprise Linux - "centos" CentOS - "fedora" Fedora - "sles" SUSE Linux Enterprise Server - "opensuse" openSUSE - "amazon" Amazon Linux - "arch" Arch Linux - "cloudlinux" CloudLinux OS - "exherbo" Exherbo Linux - "gentoo" GenToo Linux - "ibm_powerkvm" IBM PowerKVM - "kvmibm" KVM for IBM z Systems - "linuxmint" Linux Mint - "mageia" Mageia - "mandriva" Mandriva Linux - "parallels" Parallels - "pidora" Pidora - "raspbian" Raspbian - "oracle" Oracle Linux (and Oracle Enterprise Linux) - "scientific" Scientific Linux - "slackware" Slackware - "xenserver" XenServer - "openbsd" OpenBSD - "netbsd" NetBSD - "freebsd" FreeBSD - "midnightbsd" MidnightBSD - ============== ========================================= - - If you have a need to get distros for reliable IDs added into this set, - or if you find that the :func:`distro.id` function returns a different - distro ID for one of the listed distros, please create an issue in the - `distro issue tracker`_. - - **Lookup hierarchy and transformations:** - - First, the ID is obtained from the following sources, in the specified - order. The first available and non-empty value is used: - - * the value of the "ID" attribute of the os-release file, - - * the value of the "Distributor ID" attribute returned by the lsb_release - command, - - * the first part of the file name of the distro release file, - - The so determined ID value then passes the following transformations, - before it is returned by this method: - - * it is translated to lower case, - - * blanks (which should not be there anyway) are translated to underscores, - - * a normalization of the ID is performed, based upon - `normalization tables`_. The purpose of this normalization is to ensure - that the ID is as reliable as possible, even across incompatible changes - in the OS distributions. A common reason for an incompatible change is - the addition of an os-release file, or the addition of the lsb_release - command, with ID values that differ from what was previously determined - from the distro release file name. - """ - return _distro.id() - - -def name(pretty=False): - """ - Return the name of the current OS distribution, as a human-readable - string. - - If *pretty* is false, the name is returned without version or codename. - (e.g. "CentOS Linux") - - If *pretty* is true, the version and codename are appended. - (e.g. "CentOS Linux 7.1.1503 (Core)") - - **Lookup hierarchy:** - - The name is obtained from the following sources, in the specified order. - The first available and non-empty value is used: - - * If *pretty* is false: - - - the value of the "NAME" attribute of the os-release file, - - - the value of the "Distributor ID" attribute returned by the lsb_release - command, - - - the value of the "<name>" field of the distro release file. - - * If *pretty* is true: - - - the value of the "PRETTY_NAME" attribute of the os-release file, - - - the value of the "Description" attribute returned by the lsb_release - command, - - - the value of the "<name>" field of the distro release file, appended - with the value of the pretty version ("<version_id>" and "<codename>" - fields) of the distro release file, if available. - """ - return _distro.name(pretty) - - -def version(pretty=False, best=False): - """ - Return the version of the current OS distribution, as a human-readable - string. - - If *pretty* is false, the version is returned without codename (e.g. - "7.0"). - - If *pretty* is true, the codename in parenthesis is appended, if the - codename is non-empty (e.g. "7.0 (Maipo)"). - - Some distributions provide version numbers with different precisions in - the different sources of distribution information. Examining the different - sources in a fixed priority order does not always yield the most precise - version (e.g. for Debian 8.2, or CentOS 7.1). - - The *best* parameter can be used to control the approach for the returned - version: - - If *best* is false, the first non-empty version number in priority order of - the examined sources is returned. - - If *best* is true, the most precise version number out of all examined - sources is returned. - - **Lookup hierarchy:** - - In all cases, the version number is obtained from the following sources. - If *best* is false, this order represents the priority order: - - * the value of the "VERSION_ID" attribute of the os-release file, - * the value of the "Release" attribute returned by the lsb_release - command, - * the version number parsed from the "<version_id>" field of the first line - of the distro release file, - * the version number parsed from the "PRETTY_NAME" attribute of the - os-release file, if it follows the format of the distro release files. - * the version number parsed from the "Description" attribute returned by - the lsb_release command, if it follows the format of the distro release - files. - """ - return _distro.version(pretty, best) - - -def version_parts(best=False): - """ - Return the version of the current OS distribution as a tuple - ``(major, minor, build_number)`` with items as follows: - - * ``major``: The result of :func:`distro.major_version`. - - * ``minor``: The result of :func:`distro.minor_version`. - - * ``build_number``: The result of :func:`distro.build_number`. - - For a description of the *best* parameter, see the :func:`distro.version` - method. - """ - return _distro.version_parts(best) - - -def major_version(best=False): - """ - Return the major version of the current OS distribution, as a string, - if provided. - Otherwise, the empty string is returned. The major version is the first - part of the dot-separated version string. - - For a description of the *best* parameter, see the :func:`distro.version` - method. - """ - return _distro.major_version(best) - - -def minor_version(best=False): - """ - Return the minor version of the current OS distribution, as a string, - if provided. - Otherwise, the empty string is returned. The minor version is the second - part of the dot-separated version string. - - For a description of the *best* parameter, see the :func:`distro.version` - method. - """ - return _distro.minor_version(best) - - -def build_number(best=False): - """ - Return the build number of the current OS distribution, as a string, - if provided. - Otherwise, the empty string is returned. The build number is the third part - of the dot-separated version string. - - For a description of the *best* parameter, see the :func:`distro.version` - method. - """ - return _distro.build_number(best) - - -def like(): - """ - Return a space-separated list of distro IDs of distributions that are - closely related to the current OS distribution in regards to packaging - and programming interfaces, for example distributions the current - distribution is a derivative from. - - **Lookup hierarchy:** - - This information item is only provided by the os-release file. - For details, see the description of the "ID_LIKE" attribute in the - `os-release man page - <http://www.freedesktop.org/software/systemd/man/os-release.html>`_. - """ - return _distro.like() - - -def codename(): - """ - Return the codename for the release of the current OS distribution, - as a string. - - If the distribution does not have a codename, an empty string is returned. - - Note that the returned codename is not always really a codename. For - example, openSUSE returns "x86_64". This function does not handle such - cases in any special way and just returns the string it finds, if any. - - **Lookup hierarchy:** - - * the codename within the "VERSION" attribute of the os-release file, if - provided, - - * the value of the "Codename" attribute returned by the lsb_release - command, - - * the value of the "<codename>" field of the distro release file. - """ - return _distro.codename() - - -def info(pretty=False, best=False): - """ - Return certain machine-readable information items about the current OS - distribution in a dictionary, as shown in the following example: - - .. sourcecode:: python - - { - 'id': 'rhel', - 'version': '7.0', - 'version_parts': { - 'major': '7', - 'minor': '0', - 'build_number': '' - }, - 'like': 'fedora', - 'codename': 'Maipo' - } - - The dictionary structure and keys are always the same, regardless of which - information items are available in the underlying data sources. The values - for the various keys are as follows: - - * ``id``: The result of :func:`distro.id`. - - * ``version``: The result of :func:`distro.version`. - - * ``version_parts -> major``: The result of :func:`distro.major_version`. - - * ``version_parts -> minor``: The result of :func:`distro.minor_version`. - - * ``version_parts -> build_number``: The result of - :func:`distro.build_number`. - - * ``like``: The result of :func:`distro.like`. - - * ``codename``: The result of :func:`distro.codename`. - - For a description of the *pretty* and *best* parameters, see the - :func:`distro.version` method. - """ - return _distro.info(pretty, best) - - -def os_release_info(): - """ - Return a dictionary containing key-value pairs for the information items - from the os-release file data source of the current OS distribution. - - See `os-release file`_ for details about these information items. - """ - return _distro.os_release_info() - - -def lsb_release_info(): - """ - Return a dictionary containing key-value pairs for the information items - from the lsb_release command data source of the current OS distribution. - - See `lsb_release command output`_ for details about these information - items. - """ - return _distro.lsb_release_info() - - -def distro_release_info(): - """ - Return a dictionary containing key-value pairs for the information items - from the distro release file data source of the current OS distribution. - - See `distro release file`_ for details about these information items. - """ - return _distro.distro_release_info() - - -def uname_info(): - """ - Return a dictionary containing key-value pairs for the information items - from the distro release file data source of the current OS distribution. - """ - return _distro.uname_info() - - -def os_release_attr(attribute): - """ - Return a single named information item from the os-release file data source - of the current OS distribution. - - Parameters: - - * ``attribute`` (string): Key of the information item. - - Returns: - - * (string): Value of the information item, if the item exists. - The empty string, if the item does not exist. - - See `os-release file`_ for details about these information items. - """ - return _distro.os_release_attr(attribute) - - -def lsb_release_attr(attribute): - """ - Return a single named information item from the lsb_release command output - data source of the current OS distribution. - - Parameters: - - * ``attribute`` (string): Key of the information item. - - Returns: - - * (string): Value of the information item, if the item exists. - The empty string, if the item does not exist. - - See `lsb_release command output`_ for details about these information - items. - """ - return _distro.lsb_release_attr(attribute) - - -def distro_release_attr(attribute): - """ - Return a single named information item from the distro release file - data source of the current OS distribution. - - Parameters: - - * ``attribute`` (string): Key of the information item. - - Returns: - - * (string): Value of the information item, if the item exists. - The empty string, if the item does not exist. - - See `distro release file`_ for details about these information items. - """ - return _distro.distro_release_attr(attribute) - - -def uname_attr(attribute): - """ - Return a single named information item from the distro release file - data source of the current OS distribution. - - Parameters: - - * ``attribute`` (string): Key of the information item. - - Returns: - - * (string): Value of the information item, if the item exists. - The empty string, if the item does not exist. - """ - return _distro.uname_attr(attribute) - - -class cached_property(object): - """A version of @property which caches the value. On access, it calls the - underlying function and sets the value in `__dict__` so future accesses - will not re-call the property. - """ - def __init__(self, f): - self._fname = f.__name__ - self._f = f - - def __get__(self, obj, owner): - assert obj is not None, 'call {} on an instance'.format(self._fname) - ret = obj.__dict__[self._fname] = self._f(obj) - return ret - - -class LinuxDistribution(object): - """ - Provides information about a OS distribution. - - This package creates a private module-global instance of this class with - default initialization arguments, that is used by the - `consolidated accessor functions`_ and `single source accessor functions`_. - By using default initialization arguments, that module-global instance - returns data about the current OS distribution (i.e. the distro this - package runs on). - - Normally, it is not necessary to create additional instances of this class. - However, in situations where control is needed over the exact data sources - that are used, instances of this class can be created with a specific - distro release file, or a specific os-release file, or without invoking the - lsb_release command. - """ - - def __init__(self, - include_lsb=True, - os_release_file='', - distro_release_file='', - include_uname=True): - """ - The initialization method of this class gathers information from the - available data sources, and stores that in private instance attributes. - Subsequent access to the information items uses these private instance - attributes, so that the data sources are read only once. - - Parameters: - - * ``include_lsb`` (bool): Controls whether the - `lsb_release command output`_ is included as a data source. - - If the lsb_release command is not available in the program execution - path, the data source for the lsb_release command will be empty. - - * ``os_release_file`` (string): The path name of the - `os-release file`_ that is to be used as a data source. - - An empty string (the default) will cause the default path name to - be used (see `os-release file`_ for details). - - If the specified or defaulted os-release file does not exist, the - data source for the os-release file will be empty. - - * ``distro_release_file`` (string): The path name of the - `distro release file`_ that is to be used as a data source. - - An empty string (the default) will cause a default search algorithm - to be used (see `distro release file`_ for details). - - If the specified distro release file does not exist, or if no default - distro release file can be found, the data source for the distro - release file will be empty. - - * ``include_uname`` (bool): Controls whether uname command output is - included as a data source. If the uname command is not available in - the program execution path the data source for the uname command will - be empty. - - Public instance attributes: - - * ``os_release_file`` (string): The path name of the - `os-release file`_ that is actually used as a data source. The - empty string if no distro release file is used as a data source. - - * ``distro_release_file`` (string): The path name of the - `distro release file`_ that is actually used as a data source. The - empty string if no distro release file is used as a data source. - - * ``include_lsb`` (bool): The result of the ``include_lsb`` parameter. - This controls whether the lsb information will be loaded. - - * ``include_uname`` (bool): The result of the ``include_uname`` - parameter. This controls whether the uname information will - be loaded. - - Raises: - - * :py:exc:`IOError`: Some I/O issue with an os-release file or distro - release file. - - * :py:exc:`subprocess.CalledProcessError`: The lsb_release command had - some issue (other than not being available in the program execution - path). - - * :py:exc:`UnicodeError`: A data source has unexpected characters or - uses an unexpected encoding. - """ - self.os_release_file = os_release_file or \ - os.path.join(_UNIXCONFDIR, _OS_RELEASE_BASENAME) - self.distro_release_file = distro_release_file or '' # updated later - self.include_lsb = include_lsb - self.include_uname = include_uname - - def __repr__(self): - """Return repr of all info - """ - return \ - "LinuxDistribution(" \ - "os_release_file={self.os_release_file!r}, " \ - "distro_release_file={self.distro_release_file!r}, " \ - "include_lsb={self.include_lsb!r}, " \ - "include_uname={self.include_uname!r}, " \ - "_os_release_info={self._os_release_info!r}, " \ - "_lsb_release_info={self._lsb_release_info!r}, " \ - "_distro_release_info={self._distro_release_info!r}, " \ - "_uname_info={self._uname_info!r})".format( - self=self) - - def linux_distribution(self, full_distribution_name=True): - """ - Return information about the OS distribution that is compatible - with Python's :func:`platform.linux_distribution`, supporting a subset - of its parameters. - - For details, see :func:`distro.linux_distribution`. - """ - return ( - self.name() if full_distribution_name else self.id(), - self.version(), - self.codename() - ) - - def id(self): - """Return the distro ID of the OS distribution, as a string. - - For details, see :func:`distro.id`. - """ - def normalize(distro_id, table): - distro_id = distro_id.lower().replace(' ', '_') - return table.get(distro_id, distro_id) - - distro_id = self.os_release_attr('id') - if distro_id: - return normalize(distro_id, NORMALIZED_OS_ID) - - distro_id = self.lsb_release_attr('distributor_id') - if distro_id: - return normalize(distro_id, NORMALIZED_LSB_ID) - - distro_id = self.distro_release_attr('id') - if distro_id: - return normalize(distro_id, NORMALIZED_DISTRO_ID) - - distro_id = self.uname_attr('id') - if distro_id: - return normalize(distro_id, NORMALIZED_DISTRO_ID) - - return '' - - def name(self, pretty=False): - """ - Return the name of the OS distribution, as a string. - - For details, see :func:`distro.name`. - """ - name = self.os_release_attr('name') \ - or self.lsb_release_attr('distributor_id') \ - or self.distro_release_attr('name') \ - or self.uname_attr('name') - if pretty: - name = self.os_release_attr('pretty_name') \ - or self.lsb_release_attr('description') - if not name: - name = self.distro_release_attr('name') \ - or self.uname_attr('name') - version = self.version(pretty=True) - if version: - name = name + ' ' + version - return name or '' - - def version(self, pretty=False, best=False): - """ - Return the version of the OS distribution, as a string. - - For details, see :func:`distro.version`. - """ - versions = [ - self.os_release_attr('version_id'), - self.lsb_release_attr('release'), - self.distro_release_attr('version_id'), - self._parse_distro_release_content( - self.os_release_attr('pretty_name')).get('version_id', ''), - self._parse_distro_release_content( - self.lsb_release_attr('description')).get('version_id', ''), - self.uname_attr('release') - ] - version = '' - if best: - # This algorithm uses the last version in priority order that has - # the best precision. If the versions are not in conflict, that - # does not matter; otherwise, using the last one instead of the - # first one might be considered a surprise. - for v in versions: - if v.count(".") > version.count(".") or version == '': - version = v - else: - for v in versions: - if v != '': - version = v - break - if pretty and version and self.codename(): - version = '{0} ({1})'.format(version, self.codename()) - return version - - def version_parts(self, best=False): - """ - Return the version of the OS distribution, as a tuple of version - numbers. - - For details, see :func:`distro.version_parts`. - """ - version_str = self.version(best=best) - if version_str: - version_regex = re.compile(r'(\d+)\.?(\d+)?\.?(\d+)?') - matches = version_regex.match(version_str) - if matches: - major, minor, build_number = matches.groups() - return major, minor or '', build_number or '' - return '', '', '' - - def major_version(self, best=False): - """ - Return the major version number of the current distribution. - - For details, see :func:`distro.major_version`. - """ - return self.version_parts(best)[0] - - def minor_version(self, best=False): - """ - Return the minor version number of the current distribution. - - For details, see :func:`distro.minor_version`. - """ - return self.version_parts(best)[1] - - def build_number(self, best=False): - """ - Return the build number of the current distribution. - - For details, see :func:`distro.build_number`. - """ - return self.version_parts(best)[2] - - def like(self): - """ - Return the IDs of distributions that are like the OS distribution. - - For details, see :func:`distro.like`. - """ - return self.os_release_attr('id_like') or '' - - def codename(self): - """ - Return the codename of the OS distribution. - - For details, see :func:`distro.codename`. - """ - try: - # Handle os_release specially since distros might purposefully set - # this to empty string to have no codename - return self._os_release_info['codename'] - except KeyError: - return self.lsb_release_attr('codename') \ - or self.distro_release_attr('codename') \ - or '' - - def info(self, pretty=False, best=False): - """ - Return certain machine-readable information about the OS - distribution. - - For details, see :func:`distro.info`. - """ - return dict( - id=self.id(), - version=self.version(pretty, best), - version_parts=dict( - major=self.major_version(best), - minor=self.minor_version(best), - build_number=self.build_number(best) - ), - like=self.like(), - codename=self.codename(), - ) - - def os_release_info(self): - """ - Return a dictionary containing key-value pairs for the information - items from the os-release file data source of the OS distribution. - - For details, see :func:`distro.os_release_info`. - """ - return self._os_release_info - - def lsb_release_info(self): - """ - Return a dictionary containing key-value pairs for the information - items from the lsb_release command data source of the OS - distribution. - - For details, see :func:`distro.lsb_release_info`. - """ - return self._lsb_release_info - - def distro_release_info(self): - """ - Return a dictionary containing key-value pairs for the information - items from the distro release file data source of the OS - distribution. - - For details, see :func:`distro.distro_release_info`. - """ - return self._distro_release_info - - def uname_info(self): - """ - Return a dictionary containing key-value pairs for the information - items from the uname command data source of the OS distribution. - - For details, see :func:`distro.uname_info`. - """ - return self._uname_info - - def os_release_attr(self, attribute): - """ - Return a single named information item from the os-release file data - source of the OS distribution. - - For details, see :func:`distro.os_release_attr`. - """ - return self._os_release_info.get(attribute, '') - - def lsb_release_attr(self, attribute): - """ - Return a single named information item from the lsb_release command - output data source of the OS distribution. - - For details, see :func:`distro.lsb_release_attr`. - """ - return self._lsb_release_info.get(attribute, '') - - def distro_release_attr(self, attribute): - """ - Return a single named information item from the distro release file - data source of the OS distribution. - - For details, see :func:`distro.distro_release_attr`. - """ - return self._distro_release_info.get(attribute, '') - - def uname_attr(self, attribute): - """ - Return a single named information item from the uname command - output data source of the OS distribution. - - For details, see :func:`distro.uname_release_attr`. - """ - return self._uname_info.get(attribute, '') - - @cached_property - def _os_release_info(self): - """ - Get the information items from the specified os-release file. - - Returns: - A dictionary containing all information items. - """ - if os.path.isfile(self.os_release_file): - with open(self.os_release_file) as release_file: - return self._parse_os_release_content(release_file) - return {} - - @staticmethod - def _parse_os_release_content(lines): - """ - Parse the lines of an os-release file. - - Parameters: - - * lines: Iterable through the lines in the os-release file. - Each line must be a unicode string or a UTF-8 encoded byte - string. - - Returns: - A dictionary containing all information items. - """ - props = {} - lexer = shlex.shlex(lines, posix=True) - lexer.whitespace_split = True - - # The shlex module defines its `wordchars` variable using literals, - # making it dependent on the encoding of the Python source file. - # In Python 2.6 and 2.7, the shlex source file is encoded in - # 'iso-8859-1', and the `wordchars` variable is defined as a byte - # string. This causes a UnicodeDecodeError to be raised when the - # parsed content is a unicode object. The following fix resolves that - # (... but it should be fixed in shlex...): - if sys.version_info[0] == 2 and isinstance(lexer.wordchars, bytes): - lexer.wordchars = lexer.wordchars.decode('iso-8859-1') - - tokens = list(lexer) - for token in tokens: - # At this point, all shell-like parsing has been done (i.e. - # comments processed, quotes and backslash escape sequences - # processed, multi-line values assembled, trailing newlines - # stripped, etc.), so the tokens are now either: - # * variable assignments: var=value - # * commands or their arguments (not allowed in os-release) - if '=' in token: - k, v = token.split('=', 1) - props[k.lower()] = v - else: - # Ignore any tokens that are not variable assignments - pass - - if 'version_codename' in props: - # os-release added a version_codename field. Use that in - # preference to anything else Note that some distros purposefully - # do not have code names. They should be setting - # version_codename="" - props['codename'] = props['version_codename'] - elif 'ubuntu_codename' in props: - # Same as above but a non-standard field name used on older Ubuntus - props['codename'] = props['ubuntu_codename'] - elif 'version' in props: - # If there is no version_codename, parse it from the version - codename = re.search(r'(\(\D+\))|,(\s+)?\D+', props['version']) - if codename: - codename = codename.group() - codename = codename.strip('()') - codename = codename.strip(',') - codename = codename.strip() - # codename appears within paranthese. - props['codename'] = codename - - return props - - @cached_property - def _lsb_release_info(self): - """ - Get the information items from the lsb_release command output. - - Returns: - A dictionary containing all information items. - """ - if not self.include_lsb: - return {} - with open(os.devnull, 'w') as devnull: - try: - cmd = ('lsb_release', '-a') - stdout = subprocess.check_output(cmd, stderr=devnull) - except OSError: # Command not found - return {} - content = self._to_str(stdout).splitlines() - return self._parse_lsb_release_content(content) - - @staticmethod - def _parse_lsb_release_content(lines): - """ - Parse the output of the lsb_release command. - - Parameters: - - * lines: Iterable through the lines of the lsb_release output. - Each line must be a unicode string or a UTF-8 encoded byte - string. - - Returns: - A dictionary containing all information items. - """ - props = {} - for line in lines: - kv = line.strip('\n').split(':', 1) - if len(kv) != 2: - # Ignore lines without colon. - continue - k, v = kv - props.update({k.replace(' ', '_').lower(): v.strip()}) - return props - - @cached_property - def _uname_info(self): - with open(os.devnull, 'w') as devnull: - try: - cmd = ('uname', '-rs') - stdout = subprocess.check_output(cmd, stderr=devnull) - except OSError: - return {} - content = self._to_str(stdout).splitlines() - return self._parse_uname_content(content) - - @staticmethod - def _parse_uname_content(lines): - props = {} - match = re.search(r'^([^\s]+)\s+([\d\.]+)', lines[0].strip()) - if match: - name, version = match.groups() - - # This is to prevent the Linux kernel version from - # appearing as the 'best' version on otherwise - # identifiable distributions. - if name == 'Linux': - return {} - props['id'] = name.lower() - props['name'] = name - props['release'] = version - return props - - @staticmethod - def _to_str(text): - encoding = sys.getfilesystemencoding() - encoding = 'utf-8' if encoding == 'ascii' else encoding - - if sys.version_info[0] >= 3: - if isinstance(text, bytes): - return text.decode(encoding) - else: - if isinstance(text, unicode): # noqa - return text.encode(encoding) - - return text - - @cached_property - def _distro_release_info(self): - """ - Get the information items from the specified distro release file. - - Returns: - A dictionary containing all information items. - """ - if self.distro_release_file: - # If it was specified, we use it and parse what we can, even if - # its file name or content does not match the expected pattern. - distro_info = self._parse_distro_release_file( - self.distro_release_file) - basename = os.path.basename(self.distro_release_file) - # The file name pattern for user-specified distro release files - # is somewhat more tolerant (compared to when searching for the - # file), because we want to use what was specified as best as - # possible. - match = _DISTRO_RELEASE_BASENAME_PATTERN.match(basename) - if 'name' in distro_info \ - and 'cloudlinux' in distro_info['name'].lower(): - distro_info['id'] = 'cloudlinux' - elif match: - distro_info['id'] = match.group(1) - return distro_info - else: - try: - basenames = os.listdir(_UNIXCONFDIR) - # We sort for repeatability in cases where there are multiple - # distro specific files; e.g. CentOS, Oracle, Enterprise all - # containing `redhat-release` on top of their own. - basenames.sort() - except OSError: - # This may occur when /etc is not readable but we can't be - # sure about the *-release files. Check common entries of - # /etc for information. If they turn out to not be there the - # error is handled in `_parse_distro_release_file()`. - basenames = ['SuSE-release', - 'arch-release', - 'base-release', - 'centos-release', - 'fedora-release', - 'gentoo-release', - 'mageia-release', - 'mandrake-release', - 'mandriva-release', - 'mandrivalinux-release', - 'manjaro-release', - 'oracle-release', - 'redhat-release', - 'sl-release', - 'slackware-version'] - for basename in basenames: - if basename in _DISTRO_RELEASE_IGNORE_BASENAMES: - continue - match = _DISTRO_RELEASE_BASENAME_PATTERN.match(basename) - if match: - filepath = os.path.join(_UNIXCONFDIR, basename) - distro_info = self._parse_distro_release_file(filepath) - if 'name' in distro_info: - # The name is always present if the pattern matches - self.distro_release_file = filepath - distro_info['id'] = match.group(1) - if 'cloudlinux' in distro_info['name'].lower(): - distro_info['id'] = 'cloudlinux' - return distro_info - return {} - - def _parse_distro_release_file(self, filepath): - """ - Parse a distro release file. - - Parameters: - - * filepath: Path name of the distro release file. - - Returns: - A dictionary containing all information items. - """ - try: - with open(filepath) as fp: - # Only parse the first line. For instance, on SLES there - # are multiple lines. We don't want them... - return self._parse_distro_release_content(fp.readline()) - except (OSError, IOError): - # Ignore not being able to read a specific, seemingly version - # related file. - # See https://github.com/nir0s/distro/issues/162 - return {} - - @staticmethod - def _parse_distro_release_content(line): - """ - Parse a line from a distro release file. - - Parameters: - * line: Line from the distro release file. Must be a unicode string - or a UTF-8 encoded byte string. - - Returns: - A dictionary containing all information items. - """ - matches = _DISTRO_RELEASE_CONTENT_REVERSED_PATTERN.match( - line.strip()[::-1]) - distro_info = {} - if matches: - # regexp ensures non-None - distro_info['name'] = matches.group(3)[::-1] - if matches.group(2): - distro_info['version_id'] = matches.group(2)[::-1] - if matches.group(1): - distro_info['codename'] = matches.group(1)[::-1] - elif line: - distro_info['name'] = line.strip() - return distro_info - - -_distro = LinuxDistribution() - - -def main(): - logger = logging.getLogger(__name__) - logger.setLevel(logging.DEBUG) - logger.addHandler(logging.StreamHandler(sys.stdout)) - - parser = argparse.ArgumentParser(description="OS distro info tool") - parser.add_argument( - '--json', - '-j', - help="Output in machine readable format", - action="store_true") - args = parser.parse_args() - - if args.json: - logger.info(json.dumps(info(), indent=4, sort_keys=True)) - else: - logger.info('Name: %s', name(pretty=True)) - distribution_version = version(pretty=True) - logger.info('Version: %s', distribution_version) - distribution_codename = codename() - logger.info('Codename: %s', distribution_codename) - - -if __name__ == '__main__': - main() diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/__init__.py deleted file mode 100644 index d1d82f15..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/__init__.py +++ /dev/null @@ -1,35 +0,0 @@ -""" -HTML parsing library based on the `WHATWG HTML specification -<https://whatwg.org/html>`_. The parser is designed to be compatible with -existing HTML found in the wild and implements well-defined error recovery that -is largely compatible with modern desktop web browsers. - -Example usage:: - - from pip._vendor import html5lib - with open("my_document.html", "rb") as f: - tree = html5lib.parse(f) - -For convenience, this module re-exports the following names: - -* :func:`~.html5parser.parse` -* :func:`~.html5parser.parseFragment` -* :class:`~.html5parser.HTMLParser` -* :func:`~.treebuilders.getTreeBuilder` -* :func:`~.treewalkers.getTreeWalker` -* :func:`~.serializer.serialize` -""" - -from __future__ import absolute_import, division, unicode_literals - -from .html5parser import HTMLParser, parse, parseFragment -from .treebuilders import getTreeBuilder -from .treewalkers import getTreeWalker -from .serializer import serialize - -__all__ = ["HTMLParser", "parse", "parseFragment", "getTreeBuilder", - "getTreeWalker", "serialize"] - -# this has to be at the top level, see how setup.py parses this -#: Distribution version number. -__version__ = "1.1" diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 2530cbe0ccc8bd73244b78c78f2dcf36e74eeb85..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1330 zcmYe~<>g{vU|^UdaWJ)mg@NHQh=Yuo7#J8F7#J9e6Brm6QW&BbQW#U1au{=&qL^}- zqnLA9qF5LiQkYX%a#(ZOqS$iTqu6sfqBy`}tT~*yTv1$LHd_vNE>9E>n9ZKUo68r) z$H<V*kixNuF^WHhGfE(ZE0{r(J8=yY0|S>wh_8=AL1IyHW?s5NPG(Y3Vo{|+Qetsx zib8&#LP<udLPEHQV@SBW0$62nL27blT4r)$NoIZ?mrX`VNkOrdzJ7T|Vo7<rUVc%! zenv@dj$J~$o<c}QD%jxEB8ALig_P9d%=Em}6ory}g``x4<ow)%#FEUUoK%JK%#sYQ z)QZgF5|9(Xwxs2k=A|fPLhLWk%t=v51o3kVa#C|s^Gb>p%2RW4bW>8(GC?M$78T_e zDHNq9=a;1xRVtKZB$jYx7Axc=7Nw`=RH9p@kei>9T9gNJP<BavfkJs|l0s5ZetB_f zQL!Eumup2L$Qp&x;>7e+D=RK81qB6#w4(f6g@Viiz4)@!yp;SRh0NT7{Gt*CkY7!6 zGLyiHK>kq3FG$VPP|B^0PsvX%1-VrZq((_cL8&N7NmC)QSRu^{tQur&Nl|L5f-T$> zJy0~HYNTm$ak=FeDJ19Tm8IrorsgH5>L`?CWEO*5UYe7tP?V~hS^=`Z7#u%o`8hfH z<)E<3OUz9zw&LQ_Qm{%Z%}cgQr~}(>3O2V0VtfK#S+}CZbdamTs*-aOi;K|>0mV;1 zVo`Bw5m*h(9*|d(N;7j(K%tnPS`t!}n(74MW2h@n%*jSl77pg3s47k^%1q43tV%7? zgEJGjUV<`<Ci5-+#H8Z<oYIoict|wd;z-FX%Ph{!&$}g1nwOcJpOPA%lUb5ll$cZe zl97RdL6i9wIGsb>eTx+w9=CYG6wJq(jJNnu-L1)Zix(;aaiS*UEl#*|G}(&S7#J9e z*g*sbh~NYfpd4Pr&A`A=#cZf&=%*=oi#;Bc7UJV?amB}{m6ntirN+k>fwFoLGe`pq z0|Ub?ZcrkDMiZK`w|J0)wg_a&EpCtyG!%<KHs0cbyQ>InJIL0=oSgXhTio&SWvNA= zz=@Av$xtK$vJ*u7YIL@W2?ZtknADt<%%T|oyi}K>%(7GkU4>9T&oI}ZV9yZ8U<FS< z7k@w3U{A-GU{_z);1Jg!1+$od0H2sd6WyHrbWpC%j!Dfci}A@!iYd-4N!2Y#OwLYB zPc4oq$Slx@W*Bg(0Lm%)@$s2?nI-Y@dIgoYIBatBQ%ZAE?Ld)K%*VjMz#=BXB*Mr8 If=nE&0DiWj;{X5v diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-39.pyc deleted file mode 100644 index 8b19e80b849505c197723be209619848dc28f768..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13799 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�}J}GB$8?js3-}P@`~*QSTR{?k&dnDnaE6 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 diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-39.pyc deleted file mode 100644 index 8fc47691b155fb6d6c129941004b4f0e9aec2a9f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21658 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 QfqDi{fh2)?23rAj06)h(F#rGn diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-39.pyc deleted file mode 100644 index c5eed21d6961fc3bf8743904ab24f7a38a99ddf6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 39753 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 H#KH^!(SPf$ diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-39.pyc deleted file mode 100644 index e3679b47f3241fbcae1d374b2e221839729b2740..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4830 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 Ghb#a|ms7I< diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-39.pyc deleted file mode 100644 index 5970137cbf6ec86e81124cc85908aa737c6ae27b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 66368 zcmYe~<>g{vU|^UdaWIv`jgjFoh=YuGa4;}9FfcF_*Xc4aq%fo~<}l<kMlt3xMKR?v zM=>*k#F%neqF7RxqF7UyQ&>`1Q`l12Q#evMQ@B#NQ+QH%Q}|N&Qv^~3Q-o54Q$$ik zQ^ZolQzTL(Q>0R)Q)E(PQ{+<QQxsAZQ<PGaQ&dt^Q`Az_Q#4XEQ?ydFQ*=^vQ}j~w zQ*=^vQVdcIQ;brKQ%q7!Q_ND#Q!G*}Q>;>~Q*2UfQ|wagQyfwpQ=C$qQ(RJ9Q`}PA zQ#?{UQ@m2VQ+!f<Q~Xl=Qvy-~Q-V^0Q$kWgQ^HchQzB9#Q=(F$Q({tLQ{qzMQxZ}V zQ<74WQ&Lh=Q_@n>Q!-LAQ?gRBQ*u&rQ}R;sQwmZFQ;JfGQ%X`wQ_51xQz}v_Q>s#` zQ)*IbQ|eOcQyNklQ<_qm=QKsJrL?59rnIHBr*x!rrgY6=i(*gZNM%pymSjljNn?Vt zdf}{YII9oN>W8x?z*!UFtVv+jWJ!jUDR9<QIBOc5H66~H0cXtwvt~&$q|Ao1=D=BV z)0ol)n;D}x;VzyBmIJwcKAg1x&RPg(ErPQa!&yt<tfg?)GB|5FoV5bZS_x;Zg0ohq zF{Sf0Ge&X2-LwWShX~KLaItl8)_OQ=1Dv%H&e{ZLZHBY9z*$@2tZi@>BF?tM#dg41 zJK?NdaMo@(YY&{Y7tY!TXYGfx4!~Il;jBY&)?qm72%L2k&N>EX9fz|{z*#5ZtW$8- zX*lZ)oOKq?ItOQ+hqErgS%`Fd5iWKK&bka|U4gT%!dchgtm|;r4LA#t4{pN6Zoyf% z;jBAw)?GO39-M{9L-*lg58$kaaMmL@>oJ`51kQR2XFY?np2Jy)-1!17hRCNc;bO1g zEJ)r3<)_zhvAJ;88#wDNob?XQdJkqn^KQCdGh-AtI8T5|0>b&4rI|5`2d<ukk|Uk9 znK6nt<wMHHlus$2Q@*5pP5GAcJ>^Hr&y-&&zf=CC{7w0n@_zzj3d01(6vhdRDNGX> zQ<x_(rm#$4OkthCn8G%JF@=2sV+zLv#uUy8j450b7*n_>FsATKU`*kiz?i}}fiZ=D z0%MB61jZD>35+R16Btv3CoranOkhkAoxqqPHi0okd;(*N#016^$q9@pQWF?cq$e<@ z$V^~Nk)6PpA~%6CMScQfioyiO6vYXQDM}L<Q<Nt#rl?F{Oi`V{n4&g;F-3g>V~WNE z#uUv7j44_Z7*n(-FsA5CU`)}Sz?h;p$1V!w2K@<)DF&I0Q6RS%PGC$iN(H&vP?8}H z<QtHPF@}f<hKMPKh#9I#%3M_b1jZC|6cLM*4Pd?n)Mkqbj475FB31|yaEM!j`PNW9 z))N?03{gaE=I}&;LfCc!V~Sl1L#n_6!G#Pi49$#DLa7|-pt!SN#MsOjB@E>`fO#UR z9H}f>qRos^VqlhdGh>tlm?hcF7$pT}NjEb_NrPE3&5Ti?7;%K!!IC8owgD7FPEqnu zlbyjPE2MIy%uRWj&eY5pr3jUA0m~?*f>Mg>1jZCMkSv(zp3d0J2xfV}S)LOZQ@r3R zP<h@H7*l-Ua=vgqeiIl|{2}6CKL>zp1e+TOR}%zh`A=X>2}V*K0#}VB12S;}V@fEJ zx-f`3unpl5HdGbVv<ZwU5g=P8Fs4M#5sm_-)~F~IXedO3bVPwtZp;M66cCP`z?cHU zaT6F*KsbH^V@d)PCr)5YNt(czk_^Qu6BtucCora@O<+t(pTL-sF@Z59a{^;Z78GYs zU`)xGz?hN?#d#ALQ$RR>0%J<S1jdxY35+R46Btv9CorazOkhkYoxqq<Hi0pvd;()i z1yrnZ0%J<m1jdwVD6W~nm{L1|F{N$-V@mx5#*~H$j46#!+%$nPrFjBlO3MVsl-3E1 zDQ!?S?GqSNIwmltbWUJQ>6*Zp(mjDOrDp<TO78^5l)ed!Dg6@|QzlGcOqn==F=f&O z#+1nu7*nQ9U`&}hfiY#;1jdx<6BtuwOkhlzIe{@{7S!(96BtwGOkhlzJApA}-UP;! z`4bpZ7EEAFSvY|)Wzhu2l*JPmQ<h9%Oj$aCF=g2V#+2m~7*keEU`$y#fiY#(1jdxr z6Btw0Okhk|JApA}-2}#z^%EFVHcVhl*$8z5h`(t9W6I_Uj44~7=5C$9n6hmGW6Jgk zj43-NFsAIBz?iaY0%OYV35+RwCNQS#oxqr~Zvtb={t1jJ2PQD49Gt+Ia%ci$%Hau& zDMuzSrW~EXm~w0aW6JRfj43B3Fs7WGz?cHE<J1Jkl+zO!Q_f6aOgRh1=O!?wfbjVV zj42nO_~Hb{luHvBQ!Y<nOt}KZS0^y0T${j{a(x10%8dz(DK{rDrresqm~wjpW6GTg zj45{~Fs9s_z?gD>0%OX935+QZCorZwg5t*$7*n21U`%;BfidOT1jdx-6BtuoOkhlT zIe{_d)da?r*HHXs0%OWsD1JAAG3EUP#*_~e7*jq@U`+WmfidOt1jdvv6BtvzPGC&= zHi0qa`vk_69}^f;eokOa`89zt<@W@}ls^*~Q~pk1O!+r~G3EaRrWA$=Oeu^Lm{OP~ zFr_e0U`k<`z?8x|fhmP;0#ge61f~=YC>vCZR8C+@;hMmd!aad0g=Yd&3hxA_6h0{C zpTLv?!U7YRQUoV3r3g)6N)d))5L;vd6S!vCF@Y&XYywk?_yndDi3v<8k`tIxq$V(> zNKar&k(t1hB0GU8MQ#F9iu?qo6om;)DT+|6G=V8ac>+_4$^@nq)d@@~Y7>}J)F&{d zXiQ*A(VW1PqBVgjMSB8Mip~V46x|6-DS8u_QuHS<r5H?LN-><klwt(M#uJ!QOeQd; zm`-3yF`K}YVm^T>#bN?eisb~R6srkLDb^F1QfwwLrPxkjO0k>3lwv=DDaBy|Q;OpR zrWB_MOexM2m{MFOFr~OoU`lbDz?9-Xfhomf0#l0T1f~?P2}~*86PQwbCNQP=PGCy$ zo4}OfKY=MFU;<N0-~^_WAb2`vN(r98loB$5DJ66QQ%cwbrj+mrOeql)m{KAqFr`FI zU`mOez?2d*fhi?+0#i!d1f~>F`GZLJOeqNym{JlaFr_3x{gFI@DJ5kBQ%dRtrj)b^ zOeyITm{Kw(Fr{QpU`olFz?70bfhi>i%Fms^l#(}rDJ6dbQ%b=Erj)`7OesYZm{N+- zFeq(+%qy9|lu|l@DWz-zQ%d;+rj&{aOevtWP&I)mrFsHWO3ehOl-dbQDRmQ=QtBr# zr8G=nN@<+Hl+rYTDW!P=Q%cJOrj*tROet*>m{Qs&Fr{=%U`pwnz?9N8fhnbX0#i!Q z1g4bU2}~({6PQx^CorW<n81`WaRO7yqzOzZlP55xOqsxxGIat|%CregDbpt~rOcSX zlrnPyQ_8FfOewP`Fs00yz?3p~0#nMo2}~*TCorWfn81{>Z~{}xq6thXizhIpESbQR zvUCDd%CZSeDa$7?rL361l(KRHQ_89dOew1;Fr}=Sz?8Cf0#nL5C|*B-DP_Y1rj(6P zylDbc3J7nWz?8CO0#nM?2}~*5pm_TPrW8<`-Z_COW!D6zl-(1UQua(>O4&PsDP`XT zrj-3qd|(1o3J4#Zz?5<biVsg<N;xutDdp${rj%n7m{N{UU`jbLfhpzW1g4Zz6PQv? zPhd(p1I>?TCorX)o4}NEegad<g$Yb47bh^KT$;d?a(Mz1xC{b?+tmq7Dc2@2rCguD zlyU=#Z%$xJxix_)<@N-olsglcQtm?Wy$MVy_a`u=Jea_g@^AuE%A*NPDUT;Gr97Fy zl=5@}Q_8amOexPNFr~bJ@?TD1N_jPbDdqJ9rj$1mm{Q(OU`ly6fhpzv1g4Y^6PQvy zPGCy;G=VAQ^8}`pFB6zjzD{6D`8I(m<@*GtlphnAQhrWgO8GT`DdqPBrj$Pum{R^u zU`qKnfeGA--7$eVg<%473gZOk6s8HxDa;d?Q&=W2r?5_7PGOtCoWeeVIfY{aa|-7K z<`k|8%qiRxm{WKrFsJZNU{2wizzlB5g2Ee=Z(mPfP7#>EoFX`ZIYnp!bBgc;<`j_$ z%qgN1m{Y_iFsF!5U`~;kz?>pEfjLEL0&|M=1m+Z(3Ct<76PQ!vpjdtabBe+Q<`l&V z%qdC}n8D@FvkA;8DifGfR3|W}s7+u_QHQcMCNQUfu;v8j6s-x&DcTd5Q*<UUr|3># zPSKmdoT5L0ImKWCbBf^v<`km|%qhkbm{Uw9FsGPKU`{ccz?@<}fjPxu0&|Mx1m+a0 z3Ct<h6PQzMCNQViPGC;4gJSy$%qb2Nm{S}lFsC?8U`}y{VwVZbDXtTkQ`{ynr?^A0 z#{}jS&k4*aUK5y8yeBZH_)K6<@twe&;x~ag#eV{GN&qx`0w*x11WjO037){55;B1~ zC3FIFN*KHzWljm7z?>2>fjK2|0&_~#1m=|J3Ct-m6PQzCCorePL2>*9=9Gj9%qfWz zm{XD_FsCF>U`|Pyz?_l_#c30mQ_?3er({fEPRX3WoRT$xIVF1nb4tzx=9JtC%qe*j zm{am6FsBquU`{EVz?@PvfjOmk0&_~q1m={|3Ct;F6PQ!VCorc}Okhr_oWPt?HGw&$ z8j5QsFsIZ`U{0x<z?@P)fjOmN0&_~^1m={c3Ct<Y6PQz4CNQV8PGAO?IUqCJCordU zOkhswoWPvYHGw&$8;W}-FsJlRU{2|qz?{-QfjMOY7(?1A%O^0WOq{@+G6{@9Z93+Z z$rG4Ura<x33Ct-VJZ%DV%Jd1$;I>gLxZTK{GIIiR%B%^@DYGXqr_7naoHBO;bIQC4 z%qjDs^nwY@DGMhsr!1PloU(WVbIOtl%qdGJFsCe=z?=fIcf|zel$8^hQ&vr2PFX#H z8Qew!h2Po<%qi<8FsH1CrkM>Bm{T@RU{2XIfjMRK1m=`2P;n4{>jdT$5Z*R{Ib}Oo z9Mo=OP66dN5Z*a~8QgXPxqsIL=9JwNm{aylU{2XPfjMR01m=|e6PQyDOkhqqIDt9k z5EO&b)M2Q)BNLdxZ7EQ@6%@wDz<NP#Smu=D6PQy@OkhqqIe{5mmVxrzX=qwJGl4nf z>;&eNa}$_T&QD-YxiEn_<>Cb9luHwsQ!Yc(5GYMtnZTR^YFE9Oz?^bz0&~js3Ct-s zCNQVmoWPuNYXWo1?Fq~&cP22W+?~Lja&H22%KZt<DGw$vr#zg%obm{ora|fY@dW0S zCli=co=#v+0p;W86PQy#X1<)jobqY{a|)=;cr$@H<?RIKly?)DQ{GQtPWdo_IpyO7 z=9Etpm{UGaU{3imfjQ;t1m=`)6PQ!JPhd{@F@ZVd=LF`IUlW*9eotTqmua9f>hA>R zlz$VLQ~pn2Nnx14lEOHFC534MOA7M@mK2r=EGeuLSW?&~u%xh0U`gSaz>>l_fhC1& z0!s?_1eO$@2`nkR6Ij4y8mRqRF@Yt8ABqJguz<@nNSv^w2u)x~5uU)3A~Jy`MHGw~ zQz|F0fZJA}HX6uG@d+#`5))WbBqy+>NKIf#k)FVkA~S&{MRo#9irfSia2pHcHiZc+ zDT)(VQk0-rc>+s{$^@1a)d?&qpq@Oa579b-B}IJ#ONs^<gZdOKDVh^lQnV(pq-aC2 z&IFbe-3crydJ|Yu^e3>S7))SEF`U2xZhPIGz>;D-fhEOc0!xbN1eO#tsJ!_EmK2K# zEGd=~SW>K@7}S#n^_Oxcu%y^bU`er^zydA{L4LLa_enryCQFJvxR1h;;sEWVK>9{3 zDUK6ZQk*8Rq&QDtNpYFLlHxjnCB<z5ON#phmK2W(EGeE7SW>(uu%viTU`g?rz>?xS zfhEOn0!xbj1eTP52`njr6IfD$Ca|OgPhd$2nZS|~I)No6YywM4_ym@e2qZm`6IfEB zCa|PLLovt<kQ#_MsBguR5;K7X+>hKefh8qw0!vE#1Qu{Va_<BdaQhA9CQx5;<ph?L z<OwV(puQxiFEoDwOG@elmXx#!EGg+woH2nVC36BxO4bAxaC;8a9tE}iLH(yS6IfC} z;ROn}^%Gc9awo8)<V|2n$w$Hk6IfC}xNrhXO3?(Cl;R02DJ2tF!2L~7pKRj<mXxvy zEGgv^SW-Y~57g%b^-V!;1+@bq_JP_FEGbnJSW>Ddu%y&XU`eT+z>-oofhDDW0!vE6 z1Qu{P4C)7g+CDEPu%t9iU`c77z>?Ae^$*AnP<jI4wh1gL?Gsp1Iwr8BbV7001eTQU z2`u2g>5~a8DZLX|Qu-#ar1Vc<Ntpn}6DP2wOq#%wGI;_^%9IH#DN`q~q)eN@k}`b) zOUjH1EGaXQ@T>_eDYGZAq|BMXk}`J!OUk?nEGeMyT`++qW#I&tltmL*QWj5ONm&BL zOQG%o^^rm87GxL5>}3;J!2MScf5ilr6i}S4n!u8>dIAf$d<OMdLF(5|U`bgA#h|zV z;SCd5z<pX!Uk}s=g!v1UE;dhKN!c=iC1vXbmXvK1SW>o6U`g3AfhA?<1eTOt6IfDq zPhd&eGl3-q6c3<s;nf6|l>HM}QVvXDNjW%yCFKwlAD+OHas-NxPGCtnHi0GO_ym@e z6BAfcPEKG+IR(Y1C$OZPnZS~Ab^=Svxd|*O=O?hFT$sR;a&ZDn%B2Y`;C}6|2`njB zCa|PjoxqZE4Vs>=Phd&8F@YuJ<^-0MTN7BoeOp-n5=4Xgn4rGp-w7-!cP6l;fWqS5 z1eTQh6IfCnOkhcQIDrM+&IFBoeVf3N@^}IZxZnF{0!zx%2`nkkCa|PDpTLp=N;5Af zu%v)6$gdy_5_>&?B?Z(628B7OAN+3uOUk<mEZ}}Hi2rs1OUj1{EGZu+u%vvNz>@NL z0!zx52`nifcYg(of%?KAe?j`eApIbBfcnaydJ~kdKy7nS`3!2eg365_6IfDyPGCs^ zg~#s+EGZzjf-uOBApQR*u%<9fU`=71z?#A|fi;DB0&5D(1lAPR39Kn>6IfH&C$NIc z`Ck)QQ#dEEg3J2E39KpHU<~U2vZnA%fMDJUtSNjGSX21H7&P9&nj$cPHAN7NLH%de z6rl;MDZ&$2Q$!}Prie~pO%a>G3hqmT`q-d;Ge}-y0&9xo1Xl2<?bQjaDbf>IQ)DKv zrpQiU1^2ndC$NIsx}9K}HAQ{`Yl^}I))d7FtSL$pSW}cIu%@U$#Z)J-rhqW09srr8 zK7lnwV*+c6<^)#os4l3_AvJ+DMSB8kip~Vq6kRCRo4}f)KY=yHU;=B3;RMzcqY11j z#uHdmOeV0Vm`-3#F`K}eVm^U2#bN?$isb~>6srlWDb^EMQ*0)%rr1tkO|hH63hsMH zgZs>^DGn1@!F}+M39Knj6IfH6C$OftOkf4~!$D?&`r;t{p#C_B_L#t$;t9sE{yb}n z*96uSZ)p7ZOkhp%oxqynH-R<9e*$Ytzy#KmzzM7=K@(V0f+w)1fb0pKz?u>^fi)$3 z0&7ad1lE+u39Knm6IfHCC$NJ1=Jrte*a@uQK02uVbaVo1O8f-Yl!OVaDWG@;_0K_m z0*zjR`g<TdKz()4_yK5q0hHc<PGAN1-9h$()Pu$aK;r=*ds8Q{rld_^O-Y}?nvyYr zH6?QbYf9Dx))bKcKz(|U9#FXq8b<)R5!A;Ag$t;U4{|?foDpVk{sh*Pf(fkP{yxZD zP<>N0fi(q$izl$AluTevDTU&)39KpQP+T#AH3fu0VwDqEQ>rGgg8TiTaS_P)1S@z9 z0OW5_xYkZ!O{tr}no>W3HKkz!Yf9q;R&cu<6d%nKSi$XcP+Dr4zzQB0u$us?PeA=m z)|9phtSRjiSW`MCu%>|0CuocS6kZ^|bx&YT=>f+FsE^H>(mR0_JZ1nH+hI-VpTL?j zVFGJPHaI+4QzlMeO_?--HD&Sy)|4p|Sixfmp#IQ}39Kp8Ca|VVpTL?j1Bz!(U`?3? z#j_`{rpy6jNIw=do(AfZgZfsW^e}e<Ys$O{tSR#+u%>|8@e3xfrYxMmnzCpDYsz9U zW=;Y1eYQ_v1&@7##$Q4H0@W*^_8=%+mrY<zSw4XU+z$r1cf|x&@R$UM4Qlg){I+@m zYswlZUORymJU#&mv-J~LQ#MRsP1!hs6+A8h^7G~itSMV2u%>{<h?Y!XP1!bqH3c*_ z0WxF91lE+D6Ij9H6CnQX39R683eY$XXgmjmA!9PEDSIZcrtF=-3Ld*yHGwr{{{+^Q z0~1(N4o+ZA0hNuQcs)FUH3ii62lWp@@d6sZ0Hq1g7zS+o2Ndt1@eI)T4`>_+gh6c3 z7!U}9#(_X%M4+?*^2><{tl)8vXA@XcPEBA1k9~mHXC|<wfc$%Q0&B{-39R7pk3J|H zG*$v)gT_Wc<3%708b<<+8-Zw0+5wF%fx_^@1lE*`U<?|oVokX;ffYP<0!ph_Ca|V} z%CQ;Xu_e}&YZF+(V<@0;t(pm}DWLRna{?=P90fEE1sa0_jYWajpmYQZ``Z&(Q|?S) zO}RUP6+G4g8lM7<O@YRsK;uuKbO9Q30gW|*%v}K;g9431!NfpgSfDg@e*!CbTn03T z1sThN@IhvQ%y~G06<m*k#<Cz|S`dEg1lE+tU<?^YgZUrg7S@y}6IfH8PGC&|h3oSP ztSK)hu%^76z?$-E0&B|a39Kn^Ca|Wwoxqy%ZUSq{`w6TmA11J-e4N0V@@WEV%I68J zDPJbArhJ{in(}P|E4U8?8Y2LeQJ^{!RJMc4F;HCzY2&k|fa*LD2GyIOGWyR1R`A#} zC~yCpz?$-Z0$U2h1hy2$32Z4$6WCIip_pX?8+Z&FG`0_F-x*F|OJSS91|E+-Jb^8R zV**<W=LEJCt_f@@+!NTqvzna~*iv{Wu%+-#U;~c_bxmMP0ri=TCa|RlPGCzBf@0wb zY$+ftGJ!1xgheN?rHD;nOA(*ImLdUFBRPRB1%#z0u%$?YF=I;i1hy2J32Z5{Pz;)1 z+cSYJMIMY9Q$TEm32fl;>f;mGQj{jJr6^BeOHrA?1|BmCoxql&Hi0cgeF9sG#ssz$ z%?Y5fS+*3d32fm0)BXu;DWLw-uL*46J`{-7o4^L{M}fiy)R(H5z?K3E3s89n8W%h> zfi1;&0vmWd8^ku9z?Nb*fi1-xj6q|CY$+BK*uZ1kpz%V`xZ!yeK3j^_1hy3G32fjo z?@JTdz~kO$p<*C8(3skl32Z5L6WCJhC$NFX!a;cjghA>ZC$ObBO<+rLp1_vkGJ!3{ zbpoi3!j|GTfi1;-0vmX2oP7dYisuA2aGwj5W+7vfps_y2lpPb;!2PhK32Z4o6WCIG zC$NFXsz7lA8asbAfh{Fq0vmYz9K;Tqz?KpO9*1NDkD<Srz?Kp+fh`3TzM!%h)b6UC zz?Kp|fh{Fs0$WPt1h$l@32Z6R6WG9YHfY=c<e%6HY$<UQ*izyru%#qSU`t7yz?K4X zL-GVRa9#WkDxW%mEhTLN8+cw1G*8w$fek#a4jM}U&6j{^P#Ok}vqQ#K*}&uNpC_=T zfad)`W#YdHY$-Vt*iv#Quz|<jUxVGn2p;nVje&yNuJ<OerQ}21S}=hv1=L3ajZeem ziYBn76hm>z1h$mY32fl;`1cdoQpzW=rGU~#<pj2rstIf<)f3oKY9_FyfWiS}X59of z@E92=UxDTkKy!V46WCHf_B2dj1CP~%#xibBU`uJ5z?RZHfi0zF0$U2GJOPc3fzox` z1h$m+32fjoG|-r+;smx7P@V(jGf>{>nZT9;3LDTk8YtcOPhbQ0)j)2VIDrjZ4}<0t zK<yh)I8UCymIA_4Ca{6$7eRBOAh%ANzy|KafzsBD32Z4dC$NFX(bB+kdu%DQCqVF= z32Z5I!5B1-$_5@=1C6DE(*FDjY$*#Su%#@Vz?QOT0$a-B32Z4#Ca{6$0Bj~Og2Q>) z1UB$E8z^p9Okhh{Ie{%@)daSb)f3oK)=XeaSv!F(W!(g}l=TzXQZ`IrOW6p<pnMJ* zM`i<$w}HwA(3l%+Oc_SQ#+G3;XzW=OI;RI3PY1<6Xf6}vU(h%os7wKk(}DV6OTlFW zs4c>lvTXue%JvCt;PE<8IkR&DTgt8pY$>}Zuz|~)y%X3{_Duk(V+NN)Ahn=!2qX_G zPYz6A1CQN-;tw?b35z#ST!G>Y6t~LYac#DgLlf9iKxHckADO_G0>Vcpu%#RYk9V`B z9Gk$F0xH))V|t)6?BoQtlv5MfQch1`O97QVpfcm!1hy1V`2rfxgN%_w^nt`cau+AC zrGVn~@&vXNP@M~!cLdF0f%4wf32Z6Xp!oU(Ht_rf$bL|oyfuLhJk|#)r|wK(1CRHC z#?nD$J1F1WpTGtl`vZ-kgT~ZBW9tw$Tgrn8APkykW=nZE0fa$gacn7%Ca{6)N>E=4 zG#7kg0$a+H32Z4(C$ObFo4}Ux9GouMz~h9P6WG9gQBYe2ROf@rDNtDiYQOxPz?K4v zPY@qe7QLOomI5j}K>6~+1h$lq6WCHdO<+p_l?R|PL{K{tH0KDK0|v$A*9mMX-@uqT zMPLG3%J&IuDL*E#rGU%@VbJ&@sLTV6F@nmuKNHwe{!U;^0hKABvIA5`g2et$U{7Iy zV#W#VDNGaC!7GA5^XKa)u&1z0U<c2qfaXR(bB_>xpm_my@El9z1Q5-h!ajjLg#(H? zC$Oh*O<+&qp1_{MGl4yYcLF=Oeg%!2UYh_>%RhlV1%yHCTy{@jPZ6BJ4qi>Pa{@bf zd~zwcp9dO`0o8e+I*uvjDtO)jR2G8rFnfx~1ojls3G69i6WGD^Flb&1G?)5)0z0_B z`UPB<v!_T-U{8^nzz&|X0nIC<Phbbn8H3b<+DXeMu!HB1L3I;IuN>4|kon?J^W`V7 zrzlKd2hZ)yoWP!<G=V)uc>;Ti$^`ZlRWKVeSCKh^Jq0w!j680AaRPe^XjKzv?k{cv zdkScE6KF0F)c>oQz@7q{13EK-9Xt;N8Q%u2Q2@=|vV-S^Kx5sY@omsJH)x)uU;=xJ z4ixK7U{BGTz@DN%fjz|liVY{Qrx;COPcfdro?<eAJ;ihadx{wpn@?a*v6#S~VmW~w zJa5!7fjz}~0(*+h1ojl$3G69$6WCMiC$OhDOkhuOoWP#qG=V+Ec>>3r?NMqI*i&34 zu!BcMH%wqpahm|@Nr6U}K%@Df9tmiak`X*YrVnksfJQ4oGqxc0pqZwY3G68z6WGDC z-k=p1pqbm<;FTnx(P&Ul0n{@B<vQjRQ10oNzy|ISf>Nm$*yYSAjT6{YyyqxIse{w4 z&jj`q-wEs~eiPVJ{3o!d1WaI037o*55;TE5C3p@;ltwB?s>THNln_Y<FdYh|!z3Bf znVT7-G$*j9ghSUrvBTF{X-!~HiAdE-X|-W+2jvb>DvxRbv7%D7o0+3@z@pI;*i&M_ zqA{tu&CF4HDNMl(8nNsQ3@<^8vo)D-@h2t~=jW7`q{e6F7UUO|+~P>dEXyp;%+I?e zP@0#SoS%{!pOaaVT9lYm>{n&#SDKTfkercNl$czSTBMMfr;wRfP+Fo;TvC*pn5&~u zlv<FJn4FrTP@Y+mp%AL==H}+2S0&?_SC*KQnW6wPt{^`%uLPtMqDQYvEjT|XGo`dx zK|^0tAu}&Izo;lRxg@7j0cuoco<d1tx?Yu@CrnPkIY=QdwLB*?FI6EmuOzdi65VDW zH@zxLSFn^qX)(+_nK?PB>4`ZCd8N5YsYMDJ<(YXY`Q^pBhDN4F3Pq`DsYR)I$*G!p zRRMmbxv52&$xzc3lJiS*Qu5SG6p~UElJoP*Qj1DbQxr<_k%B@4;kQt2RSi%WITm~7 zm1r7RRA}l|IiZ<Ylv+@fTAZ3!Qml}ervP&p+zcxP3`6v)l+nyc$ppJ8H4hrx>elLd zRfcGaQY#8llS@)l^c39lOB6tA^V1a4GILTDGV_W{QWI13s?>34QAjE+QOL{BOI1kA zFU?EQt5Wn!%uP*!1qxQ{6;PC*S`IQwuS(rDF9j5#pnxn%%*-oRD9wYZQ%Ec+DauSL zElDlbtJ1@#usAg*O*c6wzc@25T_G(8ls=SQp<V@>o|l-L3h}eLojSs=!MGIJBNQoU zc!c=+D5T`47K7rvxU>M2GZYGn@{?1G!4`souBbG*Br`v+SWmM`7l)z6`MIej86X#? z<`lyNyvhu&9OeN~`Ub}jvRf5A)ARC+K)Tg!^zGF3kgP$`7m5fzr0CVFvcYZ*l5$WY zg=A!PRgILyl0?m7by!@hBdJ3&7L;*IGExyiTxEe>p`HTVdU&KNfFcDE7n<00f~-K* zqF1F1FF}yY9#mCT$}UCu1qG=o3Mr)pIho0cC8>z?q>v9SMGUc9isW2dh5RB|Mgc`k z6=5w1hm<Ael&0!cX<_j^L<%FCtCWyjWDD|qX<lJzKB$0!8(XD?qy`adnRyCCt4&M; z71(eS!BL@CrH$2GbhQwdSLq=sMoSV1bHQpAG?X;;NK&t^sfXf8{O0Rb;YmB7I71{p zyDEJoXCuN6;zxZ@c%y4jgGZjauC6*LHK@DzJBLIDxT@<Z_~n<tvWNnb!HNnH19f#l zCMM_S=BDPARH-1TC@x4$PQ|K92vM;?HR_=x3be3*t5HQV9lII@4P8x?I9AtHhdKf5 zHE_9(<Y2ujJlP&<uY!iIuBKj<8j|IRP|eI!fGGo;tyiVtm#={Ab!cM()M5Y^ZSasq zNiKGXniVN$Le)akE{^1gQ#~H9p&E>wA<@DWs!*>=6`n>Qp35&%P`6WuRygp&v`Pvo zl%PhzjX+L5C?N<}As7)6p^%xEms$j_kX-%Us$`H1gsFp66sakCRjL^!xj71Xsi`T& zpw>xJssgC2PRlGR1~t(Vi%LM{HfrVpRkF|)0cObQRSCHk73Jrp=9d;Lz^tn>LUKc1 zex5EQ1mIpM#%2z(p5hXyOB6IzH9%E@X0awVJqAejfC8^1F`a-8d%QZJDIXLh8kxBT zIhm;`nhHhvpk`4{Dk#6|Rhgg}fEhAa9D<??;kk^|#1v58O0CE&E&-)=kboW{ve45b zy7$1<KPXnMksO6E9uam5B^ik&3dxCipyp|2o&v-k-~2L=X5>_cO|xE=v~MP)RfElI zGH8;;$T3jmjLT(Un?OxL&0<XjNLUwx>r|*GQ}a@wvU*hxxD3fJ%1qD9OU!|(R0t_b zO$67A#R{q#d8y?P3B4*EtR}$HmY#x3KByg63TlFtD54Z`V0VHt1<1g}+*HkCqzH0F zG8QRp((_9o7HjG$poI=7aA0j&n3^gpP!@yw8=Be`ic?eb6iV{*6;cz6aw?G$e|||u zDx~!Rs+FqT2s;5@5Ft4c!wuR*xB;Ht0<kDA%goP7EJ-a^C@x7YP%zX{C`c?yOfO0- z$WSm;$WH^8Gl?nr1)wIeLSlMqUUH>EVorK~QD#X-u3i<1MjBDyNMouPX@cx=6C#YX z!ybV|CvEkRjLc$%R7m**N?x!Ol#y7hke3h3Q+idFNESgd9H^rP>1iPq6`;;ExcQ!x zld4dVkyxCnSB30GVznmar&Pl9yC7MOtv&!1f+dL{3zPHnN>VF8WfiznUY4JqlAo`T zo1c=ZS7nT33S>|LJcdwGS&*ubk(rW`3L0xrKru(JN)bs@T7FS3hE;l1$gV?VceEfO z=sG7Pi;yxJEH*&FO3)1C(h};A)SMgzoQ{IW6LMg?fx7WXy0JK>JOk9dFG?*e%`5_U z*TJcvSRt_}RUsEr*6URfs477o!e&3B`m#j|5n@wKQGPir(I6)}EPg<-AE6Cly%&=8 z#i==|$w)06a4N`1Re*|vleq$DgbG@DK*gcf>Y?-yAW07qCs2n#wSbM%t3pl<2&E<Y z*{OMmJc`W~NVN-ctqyewLN90_3|yw7*o*MJH<Irmi2+tbAe@7i#1Y{E@)9_)LVe?j z(=dYWLN^L|FaT#!kOAukA*XBP^nmaKT9Cqn1=86<)^CI437E5q*Nxl;K{RAxF_>1A zn44OhS^`bG3eK=Wh+>6I&=?J<orT<3Anbm06XA6)whABW4VWHyAixA5&Qj2T_Y^es zP+De$f&<kYq$G;$C&IBwlre~)!AzczNX2Oka`6fC63K>WU`ZwrdqIf_8iXaeIhs{w zNGh>;9;wj=at*AffT9nZZ*l2E?|PuN7;))B9^62724VmNQapfb-n<gMD)dej%-skL z&>{z}1G(#l-3oY=!SxVfOL9?WK?!&eIF&eerR5i;W~PG%81hO$gDVChMTwa?ppI2B zbOIqSzeFK1Cnvu=H3c-@2P+a`9f2w%S7<v5CZd3>BQsAS5j5Pb3+_aNy;4zvF(`!^ zEec7gAZICnw18$D2%4Xn2kM>a=H(Y7`M;ush*4CmI`c|Ux=&crDN@40Wr9IyUP@|O zW*(@mP*jv(q@Ym(YIGKtCTD|YCsGuOGeGknpx$L#W<_d>re;$WUtVcWjxM~YtP;$G zO!4T#r!cCdkmho9A#*vp(3q-{hRf+D7wJOha&#ecIaSio=@8v=r1=@RWO8C&i7s>! zMmG;KPXm)wf$4<1LN_hH2wfFu{s%O>1J$JqYG>w`mgp9z=4K}6=j7*ADZ@HYXj*lX zN=tOp^GkG7^V6!taVV;i1GNfMaGNfQ&<L7Ofhw#Lg%6?@>t^QZrsk#SmL#TE$skX4 z=z^v?bn_9i>Tt7464P}-7Q@|Gl$oAUqMKBdn4FzjQiVrhVQFeHsNbfWn^=@xC5T~S zl@?qGI`IH<7!G?B@Tvucn<8Enpd?krpPHWr3Imv*kRk*gNT{9#87vCbg{q`V8J;v@ z)i%gzG)2PjIRjm|OqB}UrJ%^jPXl`!C5%DVB2>Y3>VikX;UNT4r3W_)mnziwQc5i> zP0RtO1lSlq!etQis|*k`XNar_@*GYbYM5aGuKkdV2Klc_3#-ZKO2NLYQpN~&u()nY zerZxpsxEjg1E(U;bQ)Zd0uGb%@*$=aS1BX8%hlga7vdslsRHsjD930bDFP)Y@Dvwz zrBd)%Nl7fuNG;aQFVaoPPX={5t8|czNlMI1hnfKO7DzqFLg;XJl`fKM@PH_O<$_2B zU_NBBfDh_>n2F-3d~ksPvK7T)AOZX~Nue2o<o+r-G&xW*hd92tB(Ws5N*0SeI4B^} zQb>LV1vGMaNPtG6Aw$D(_d&u{8xiJ^kVehPsM!EfSU{r%RWT@M2}2!;te^@Om{38a zA`Ifc{32Zxi$G3?sg*?X7AQpW)8J_Wn~!1I1fcE!H^V^<f+`^-gJ7z7L3K1pRu?q# zTqT1M7|2x&e`#KJUVeEV+<rNn%0b~@T&09l9^4cK6<}3}5*q3zUAUFdDn|<BYf#w> z$zIUjJ;cFka2r4cMG9;V9%M4Yocy#Z#gg)TT~J%6SU0gKRW~ocL^mn5q$IUSw<IGm zPd7g=6(x9}Hlk#3xRZ53wR3)&Zf+&m#3~V_aD^+X;)jlHfHMlH91uVgD6Ue$rcoE- zzhbyPd913S;|IEl#Z`PMpw%0o31(;&ja37*Ylu{f<maWrEP;nrVjg(Nw@MHi0=gyn z`MTgy;VN+qA#mbPsglH$fLSIC8-&$`48rOf>KRsH5j4UkXpAXnqGwVii{w4H&5)sZ zP-t-F<->f15`B<h1+{~~p#;id;J!$e29kNW6zPJxV<_<jO5pIQ0vn_Y89%H-T0o); z87b5SkK!O~lt8i(G)#z)L9Q#{NeR0(>PUvbf&t?EVqFyXAct3SYEBN^Hi)Ohk<0;0 zLk&am2UHAAE3y+HR$~UQZc%=D6><{BFbbqV8p#om4j;%W2&)RYl!J#PR89_ABWNNI zobxmDbfNMxNb*QFLuE~oWFcV&?WE}<1wPCykc+^Is*G`J!>|IO3E3Cm!~-eKzzGXE zd=NGxDL{@xm>o#c$iW9TJ2Oug)(b|7M}*<XDv(nhOdH7INbJ1SB2X<+g&f{6haek; zEDv@G#Fa3UP;w-~F=&buk-`^d37Qh*q=%{m6rj3@N>37AL4fK*Sk(e@S{0)9LY9KN z3aK(gmWSF_#RC$|%!A~$DqbiLny_F!2DrarttUu78x*(@R+R`;BdFh=nVzSclbDxM zT%`u8mdo-pQ*>bo64WcyErAX(z&ozU4P#LJz?FmI1TsJY>YRcHD3GHD>Iq%Qcma5b z0VQhD`sSca1$QZ^7KM)(REdIu667CLVd02~2;EXxM_xA-)RC`}$tWo)u+rBrFE7_C zH`dE9O4m2Ew6xT(06D!%39GDyzHeel2AJ^msglA}V`N}ppkG{;j@$H{%)IO>6-=EG zzCIxPE%ZT62XH&AN)}TU*!+szoV;RvO}1MsAgA79%S|lF$j!OMTwIoZi?sq|!7b*B z+?-piV1-4j3=9mn*b)m0a#Blfu_q^j=OJ&g=Oz{vmZqlOV#`m;N=+`g#R@J?ZZVal z++r%pC}IQYV#>|D#gv<Wizzqn7E^BVE!JGn6jc>pVqRW;Ng}vkT#=ho#12x+3r#fs z5aU=<Qj3#sv6f_(<fPtWOuWUIbc;DDGyN6|X!zk4Q)=!lmbCo5l3R?Kw^;J>lZtLJ z7T;nm&P~k8xy4poQk0pU3a0b((r+=9l-y!0y~UoGl2VjfTzrcqu_!h17JFh*NoI0R z>Mhp9;>?uPTP#V5#i_SAKqS~;_N4S;(9+CXTuC|k$=Tqp)-4uLhP=g;RCJ3iskEdd zKkpV>a%x^lYSAs`<oujl9Lf1P=|%aa1-IBiJ&nY?lv_+GDYw{DQcDsubBb><r(_m^ zh_YKuDLJ>8Qc7;IrsgK4rrhF4%S_ElDNZf9#g>+tURsoTi!CibA7m~Is7}4b3eJ1C zIKUK08B>PgEv5{kTTB_ox0o_aZZTz;-eSryyTt-ZxwqIrWNOhZri`LnY?)w9w^%cC z6Vp>~F=ytc-(m&VJh#|0i!<|5QY&sT<z(Js0Y^N04rD>aEtcHWyiyQZl6Z?bFR|<v zdtN@&t$F!i6N_(gz=qmxG3DpnVl24D3Yxjjy~SCOlb8vfjl9KN0P+i@c(}!0oC;po zd5aBFvfN@VE~x~?KnXZlIY5a695<{bAm86&EdlxC7E?*lEvC|(Tg>H2MWB>faElk- z&j+mpK;ni}7Np+d1;wEoXpRmvRep;b#0@CQ2QAFK#gUwtlkA(Hl6s3bIVZCqAh9GP zG%vHH_?94eP%^J17(8|eHb(#^1ac%;gg+%SEv>XT)j2<}xFj*J<Q7M2N_r~TILXwC zlGLKS#GIhi;{4L0<kaFI=p^AS&a}*&lGLK0)Z$y*5GKS*j`W<$f{dWlv|EDdMTsey zsd*(KMTvRE;27tH2|?8IWTzJ8rRMl1mK0@H+!BEBKvF)bdFdq?w>Yy?D+55Qzl(2i zWv5mK7l0OU7vJK@POS{d%uOx6#ghY8=$MjKT3m8VFefuN6SQ!~IX^GeF)uwQ^%f6k zgetYjBNa5Xb&DIq1KCgv<Ai6Xlw{lz$W1KHcFqTn6GNmqK_U<)S6*qZe{xA;S!(eu zu7bpp45;&j3lc&7lROlC0#HGOr+J_v5W_gZ%h`(^OCoN;nUM%))Gc1{I`5*gRL7ix zjKo{QaBeYZU3L(tfVst2Pz3gBSt`U(mZH?Oh+7~s@)mbdYC&pZiF1BwUdb&^2*;(g z=#~&D?SSTYT`Njb^FRysi*E_Q#N1L7OG=AUi*E^lY$?r2EP|&7xQJ^-L4ICpUdb(< z;)0^o#1!Aul8pS6TioF4*gq`|l!JMSOHy1?%Q8W(%mYbfmLz9{Wafb4s<^Z$EipMY zI5{yV^%h@oWpPPru1{iKdMPLebAt=oFwkPy;#=$`iACwDB@r-2<Si~xE`kO-ds${` zxl?|{EiMov1g!LyK!tNgVqRWqPB3_CH^1nXKqa~eS5<y~u47(GKw_Sz9a8=RRW3+e z&{z&6yQP7GCp9m*5|Z5tkh2?T4FV*)fl@>%N_K;k3}AC$*$rGKfJI>0Eg2=dfsKP_ zw<1_}133T`XRz!BiXv!sgIEd4Zbiu1tpqc>LDWLCTP{j=14%)05jeX+QYSdO6(eQ0 z66EZbh?d=w^Yc;@k+WL{N_GR;0MBmai0lR}h#=D7>;_?ivRgiKc7r+(mfcYF!Ll2| z)3EFYF$|i=5=$yzc`UJ{62YuOWVb}r?3M`12qi_Jgp8EkAclf6S_L?}Rl>4cGIDlH zLC$WVA{0HlrD0?@cxn&;*$c{msc6{^v@-yn-SQFHEd@Qhm7rv|V&v?WgPPsI!>;h` zRsqXym5}TP4R&yLOM+!LNY1<^P>~GDZjd?;oZZkxz}YP^FQp(c?-nn3z9<vaI4Uj5 zLFR@A`4n-0no8`6$t9(UC8?k`Omb0vPU<a|3{bjefv}4+^2=|rfO1d~CrCL9$S=28 z!HvQq&{YzeJXO5lcAgc~AUL-OY+Mx=L>6Qyj14jx#s*nX#SKvdZlJ*=Kz3GfROIGZ zf$Cfc3uJi}CrAw8fGTcq)6xoTL^302zZ4XM8k->O47$%kfq{V`lc9zoRw9O}mNAC8 zmZ_GxmZgTJhB=L?hH)}eAxkjBN`|6O3=9mKthbo-3~sR&f=ej2f}+&4%!*sAIr+(n zIk%YdiouG&#IGi2tC-N@)S}{;)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0 ze?Qk?Psf;GS6|oQ5Z53DvzUMYpO{1w-JJY%P%|kzCN-}t#wRl=rZ}@CRkt89IXf{u zwK%3Avp_$-EHy7Bzepd{#5T>zOwvz=7GlME1(mnBY*I3lOOo?*3+%X<7#Kc-d|&hv z?2liJoVOUcelha=VpRCW$g9a(#LvLMP?Q29(m+Hyh{#}IU_c2tCI$uuP@5YZaB{GK z6RTw`VW?qj29paI7cw+MgAE)MnoPHt^NUhI!Bn1Fq{&nSa>p&kWUwTJ_yMvE<S=C> z28N<vAQ!R~xqt*+L4+HKa0d|{Ai@(Q&tIeiVw*8AFjVoRmZj#E=t5dVMZqBPFc9Gb zA`C%<KZvje5wRdb6GWJRhyYO1WrOIv#adF7n4GQ2UX%=yN&perAi@_!M1Y7$5D^8^ z!<AW7l$w)T25O&iW|pMp7ANNyfO-QUD&-byW^ry}!7Yx&(vtjwoWx2{qdl*rC_kt8 z7HbM<pV}?f#Nx`l<XbHH1*v(rIC4vKN-_&_QbD`-ia|?zQZ!j^u|dYdiuf5B7;dpA zXQU=)r-Ix0X^EvdC7`x)aYkZF>MbsiEybltxtS%mI6y6d{Jfk>O=hsZB2kcL4oI<( znsSR1q&6)-xwKf54Os!KVk;77WMC)~1Q8sJ3=Enq2t^PnKB#$#xjCuD#hSvm7$Cs~ z3gTO=iKQu-`L|fhGE-9Xi@+gh0SYY+(B7o<qRf;cP=pnMBPJ9SmUbXnHpr^eTO9cX zCE$)tkr7A^6gNdl5Cx?r1*IiLpoq{^$Xuhq!0__#e+Gt3DFp_G%t?$444HBumKumq z01=8H;usSHL#6?Ul>ky=31S6-e5MHE*1}jtV6Fs6RuV+WfCyO-p#&m?L4*j1xC1gz zNs)meGZAEf6-X=?W=duqNUQ=BW~{%Mb4sj#F{hVU|6)nZEwKK@npluuZ2gNB)W5U- z3d%)?+kP>sL0FBYAb}%I5MC3QcVR*)3j+hghq+T)Ai@n`;d2wg)RBf#W(Ed^M=K{o zxGgZnJ0RkX3n7|Xq2iO~K*T$zK*XCNR0~A3V;Y2By&OXKw1G{%FcHG-*b1Rr)_{f2 zO@bOa1!nq`onVR6Ga%|Z`@q}_%fXf$S_$SIX@f|1PlC{`tq{6pEkwEptoU#{gx3L) z?AQR|c7Y`i?SN3*!Gh<Yj_sNWQQHOeMAuX(e>#Nj*aV>)=0a(x`i|`o{>m*7x^p3f z?pP0{*For(CJ5az0ZMO%&@0wMgJIG<h(Pyb2;JEWp_f3S>H;)ATfwfr&<~MpfZEmu zrB^QjOCNy--4uwb4oGmEn*z0JN;@P3wty9%o(ZAm{$fmku%NNr4UN~<HkiKM5Pd5k z#x_IMbwa(=4t04uj1RSbJ~TDW-v!Y(e<y@)hsI$S)Vy|RLTQHveaBLWx;Ch}OQ3Z7 zR<JYAK$S0rTDKG$fNgsr+Ll6Na_M{szr7JcFNMZv*AfW7Z8_9?ljeiXJu(4I9fhQp z!xO-MKHLcwJTeQy>jLvGKoi|Gr~y+tAhNJz*8x^_1nSM{yCL>XTMZGO0n@by%s&V9 z^-5?q>4YYj_8y3~mJJYk<z|TT=@7fRA)+145V{o-)fbk)4DW=9Pu~Nfr>%lXKtrhm zS_HIg1RHyy`4^)dm~{?PCY+xG<{g;_p%y_Xh~Nc?k|PUXW_Cd=>7EG_*as2lgvMm| zY$zX^=~gX*@?n_>rhYTjfJra~kTAQj3T*x9_Fs%~VAc_69Jas$2^t(N(9AOhQrsO` z2DPUjtn0#5Fm+@Tn7Ysi3CUgv1<g7$z;Z{Rf!;C^BH05GT?H|&6&BHJApDNi5V{*0 zb&ZQ5{6=V~t%Le%D#TUiphZXvB*7h70XF<X8^kJzQ;$IM=mmI)_QK3)gfb>Ag=m8$ zwhJu~9#jzG-gC3Sf=9N2sSC59I;ZqO8B?2}j7iHNDms5L+JIR{AVu;yXuQpbdb|ai zq}!mWVlPDTZZLHLrWl&7+o1Wg9U52d&?3AC8hZ1gk+T$9hP6YJ@=|E<^gvTp8?-oC z+6M{ME@<esLCsw{3n~sRsh2~`$S!EfycAYmEP$wM+Yh0aLhGA0Xck!t^;|d9yiTb5 zI=4a8uY$UBB{T<hZi0s16sU#WPy^ec!49=&J~U&`hbH#<+o1ZULOt9D^>7<he;cIQ zItnefI-!BT1X=|^OW#Il@zw&%GgF}9-7y(vJ|s<?gJxPt*>$uT99c&p<;78`nXt;O zyXX%C0|Qk56llOTE&!*@L(uSRffiV+p{c(UmRHw8!l?rqZXM7fsB=LnsIT;>v*`@9 zLg;{2FrCo4vU4L;#qu*dpsdv}wVgX5A}ja7MYcjjI{V<N`(bk3s~~dA5h5^GLhIvB zXwL40*|Z8~%F4YkQ#!XmOj)%ECbw!KOs=Z|Dz_dc(hUul4rp1_y&9ro`2@I%wGfdm zgsT=oMG$Hhmx4M*kGh&3HA53(7c`@EH9{1x+5k6jAw;Be|Ct?7ZOsU6uyBW^A6RI& zL*l0sD&GOCD<-W3$M0cCgX7#>NCKGz5u6O6rho-6K=S=jc;gbPXcAcVD74gpwAjwg zhbE(`(0tzjO}GuvWWEyCESa<lV#f>!1x;QnwnMnk+Pnc;Mf5{!`#xyy?uVM%0c|J2 zY@GtBqs~D}wsX)Vyb%%vEzlgd3R*RHLR%=SU<ndhBy>V8ZGbk~I-ohdV=mNhlOXle zxfQ<{m7qdXpv6@Sthk*7O@T`wEs8_yAb|x{HXmAdv_VtRl4%fWNIi5E!n**KY=L<e zTHUon>80zzn$AH>sQD`)-fV*=q;_aE+zw3%J<t>|A6gwRg=YVDX#KSm8U;O2<GY|a zybYSOmqJVWE@-eUhn75D(2{N`G?<n`o!bTt#-&g{w?o?=OQ8+B7O4G8p?R|%YJLlp zZi7bKa%iOpNnjVC^(LfSaTHo=uY$CyjxGR)$Wds5g%*JeVQ~aaRBg~C53Nx;U`?~B z(5j~cYUng*z;;0$+y(Vu7qo=zf&~CHz`Ni{8(QjgL-Rm4Od*ut2~B{jpg!+})h*Dv zqXTL|H<a#zRvBH8mi%F8W@v#lG%j?5J$+$W(Qi;G4(b)2gLDjzLMf=aMX+#yHi<hR z0efx+q%dim|EK{P0u9il(gDj6PzQ8E`(K?MP@|?o(@OJfsK6vhnmoD;l8vDu*#@n( zmO|Rq7a*;!qiZ0FW<%V+7)%}A05xd}v|xbrSB|c_#TXAs-~CX-`k?8qADWK3p^of= znhvX|r$S5UCD3SUhkBw7n%<W}W2+0AU)o?aEV)bvJM289xH|`FYaNBP?j}L2?G+He zK+}E~G=Hy#loS`BR(C<O=xS(|>V_894N$8(7XM<bf%tMRw7l$u=9-2sSh&C%hf`sV z!%5JL(gkTRABC2Y-3>4uurg^XtO+;?7B*8LVSjEORO!@yC}R?&-*EvFofjbOh70Q; zo`lvF&<5sesFo>npp2=oieeHZfgRle4!{eLQtc?Dk$Du-io5^`+@p}j<T+?Kv_Kn^ zE%3@}E5zo7V3UqOW4dD>q(bc2cLrJ}b?k?zgQoZm5Z*GV!=}uG@L}aDq-S{!(ib`c zjf)kqOb9I|S3;A?N@&!sghtFtXxi?8nzjtuFztYr8q1)5SO$&rWzYuQGHB9R2CX2L zK^suZpviC<v^MI1Ci5<6F}e(z%sZgPaxbLFI|3U|nF>u~E1`wTN~k%V&^+DQ{fki@ z;{T=4@R+pi7NZtKXfcF>`e6mM;8_iITPLKBKM!paH$Zb<2ejPkhW5X@p!^<a4(o%a z5NP^rfR<a!AX(-dwB_CcHMMgM)LB!YKA#Tt!3t;=SOJS6Xoa-`TAa>+S~m@9{WNG| zSOKm0mO!1i92)Y|pc!NuG-Rhk&6@^os7`=Z4AY<?It>~c)1dXhG)U=Z`>1&-q~z>e z2x5ZA)_P!Re=1aQH?%o76<X*{h1P~sp-CO4ZYs2nm<lZ#rb3g=RA`h;T@EQ1rb3g! zRA};>3Qd+%p^clVP{&S%Ca<Yb&rF3T)2Yxvm<mlsQ=x&q99ra0g(i1ca)R|Qra(*4 zsnF7KDl~adf!Z?#8mL`R^SYps-37B3TB}cmW}hiA8X6u`pph^YnoXucv(Z$jIa8oj z(G+NSOql~tv4>!JdlIyt)!6@wF$NM;%c1FFJ~Rp%pk7`DX^S0!wv0QVA-xisTvkFu zVkNY0TM1RSvH=p?9V_4OfTqYsXo_6f3n`bNg9^(bJeWDqkXs4u_(P3dwh7_^c&!X+ zyIh3YHV4v@JrCthhw54m>ByaiCjCxms%nEaW!s=Fi^)(gcR@qF3z}NGps8mCG_|dU zX0hea(4V>Z7o*iLMx9@b4v;YHfcbDOG;_kzZwt(3Xjw34I#j_VXf9d}Z7r>aCdkz= zE1|in8*23usQM*PgSw#+-VIGiZP4Oj2{d<iKoiJHs25j4gJLDLoa=(-_LZ&B=voDj zt~O{ISprQ<-O#ax?tVyAK$BJnw7lwpmVQg2NxlJ^lv|)KZh-n|33TuVLS2Angm$QV zRzi9-hoFTXRCXEEj-~sd!8Qe&-e*F(F6W^U)eT7{hoLU-hE&8Cp<&nq4Xd8sUyLeH zgJ2oB6B_OvP}g=qGg=qaq8@1Y_VhqCPJ&d-7oi2fa!BEQ1Zqq-)WOrB)#EaVJ1;^_ znGdaaVR;Ff#h}Tra~e2+4@0A_6EY%q5t?hDDX9}aMF7jE(BW5TNwW%CVy=Rg9IK!u zUO%*CY=M@ztDqiO1!-CwfeLp(OM?bzHgACOAvx+OG=nujdXz`ttt_am-B44PL(9{Z zkXFMvNE_n()?bXakQ~zq4Uv`5a9<8hJ)KZ@EQJPS3#4gv4w5_$Lz^nl(z$8PFGfXh zDRL3&+?kLf=lvQ;+voin7#}{1198~<HI28J(y}0KnF&e3@7F-H_cVy3kHJD3Rw;Eu z)5dCOkgk9fWQU+xt`#yIa0r@hTA@MF3RT?-jpbITDXoy$J_M~^TcPpW3azPHq4C!W zEt6WINxc=Cm>Z!!?tztzlc0s#Do88jI3&o=L2LO{ka?#g(BXVY+w=mY`FaGJ)>lE3 z<tj*^Jz50~k5w&@GNOAnyo^`{>%_q-nij~+(M4$Vt%7E~RnTZ%1uZl>VOBu1{VHhj z)D4?&fK_}gFa^-UXBD&*Sp`kTE1^YsH#FFmK|^~bH1wB3$9_7&)exw+cM)phQmB<} zkXV1z0x6J=KwUZ$N;g1T7+pJ|8Gi~?VhN0fDrkph^$uwGw?Vzw2AfrYwK*E5LQR?k zY1AKqdZiIMW4IQQ`ypk*1!!*o(xN{E@0>$>jL_!93TUO-0rksrXyR#si~<~i#xJCM zbp)EFx*$<?3|f=4Ky!EpG+`}=CbTYS2(N&K@Cryv`XXdl;0SDrZYpFz_uNjf>kq*S z>PgUK-3^`B>W13Z4K3Nbp-zK1^dclL9EN1}Baozf0Uq*@mcohc(D0iI??&&3WPZqa z&_&2N+__y~!Sj%s<OsyG7j{AQPJs-J9DxMyMaU5EMR=bK#+VGv0!yHob_pyQLd(CU zkgn4aXc#Snbm7iHlfW`)ZLq2p5-8B(Y6-N=TLKN?HkddxjFv+4Y8$L%hsi@rkX36T z`Eb=*cs^VLO#pK@-D0f%#TX4K(3U}6xeVI4SO%>^_JKp@2qYpeKpndT+HzP5O^!>U zn%kfqk4|XTZHKn8x}ox`pcT$aX!>6TZ3C@phPbkO7TlGqprt}Lw3b-92NoO9ys`=! zU`wG@-!#bR{6(n8mqG(#IwWe3LL;XS+K20ex?~l!DY**fQfLmH56vy@(1LnCw2Wwj ziZ6qA4xtgV0-BvxKoe^RGz(1c`o*XL4PvO5mO_;_Kodw8G&CAuiFYzASfCBARnRzT zfaIH_ure0v)|Jq-&<*v=QfTa~gvQn~Xb?_^RB(@$!b-JekWlYj0T1<#U69lVZ9&e2 z+B65+KAQ&ZNw0up!3)qpX@HmP(70%Ut~G#W;MLGT?|_!@E1=3&Lvu<Oyd;N>mQ04U z70y8|=z>lzbkBs1&v&kdkI%P5L#e$FGG@^|1FmQlLJ>3wyP!Vnf)trYq19B!0+34Z zw8~1*tN@tR*?k6*<&Q!Gb|%#OE1?Y=$W-CcHi*3|*TSX~Rzh5V0h)Fipz+=gO%h9% zKs0p1Co7h$fF*8ds%?YXv>KYBx}gEl4N1)xXF*L^2D7paTIDyuMj)onhs5L>h|2Dr zu&I~stuQ^^u%<6Gy>!FM-@TA@v3f74^9>G)4)|Qt3TRWLZ8pT<C7WRex6M7X1L}>* z(3IBI0#UTO6=r8wD^#TI3}pGpVMxR2+}>Y|%8+c*0!^+B&@9;n%`Quzan;!iiYxG# zK-U_GOFNf>gg^^)>_7~#+;V8$w4@2DW(i0Nq{arsfJ_c;0WrbKmq3f4uB{*;ux!U3 z5ECrh4t3KKNK^395=a6+ycrzGhapAz1xQ(W6k0H?fHqT?LCVgf&{VJtR^3g3478t~ z4KV{6)61cGe;G9IEQ3bMGH7OA4w>^l3Mrn?Lxz3NK}(Qj@TpK}hFu1Y;$_exq61p& zt%R0ZEnC2rAA-yn9fDR(UC;!v66))f(1g1Z>Qt!5x}f98P?xUQ1~%(3RCCW>F!vCY zyBb<it%fvYF6{rssCtW04-(}K&;p`iBQya`fvgBQ4{3p(hc?t^K*pcXLxSKu)O9U= zzZkV4=B$85&kAU5xB}YlS_uu@70?oM1+?B;0c&1Og)GoI1l7L^>eyA#;9CU^zEx1K zc0+@)0cvg!G`sdd3%DL=TzA2S+$TdC4d<cl$Ogzb*N3@NV1wPTL8C@kXMZxZ^Sxr) zFGhQa@0LJYYD=NzN5|eXkj!%w8a~UQ&Rzy}#<Hc5D1auNrBK%|fhLY6P~}UYIb|ud zRksvcg|$ILqYau^mO#sx4rr9l-F%C&_7`I;#C6M{&5C8vT5TC*Q06FfmI2abya=s^ zmp}t{DYP<ggF0mzG_Nn+3rh&l@_H#Gvz&*l%{vcmmbOC+=59#;<uufR4bZ~A52|c6 zG<xPkO>c+gDcFK6*ihaIsKOOne=%x8y#+1rRzSnF0oE#<3@x6zp|$BWXc}1#_5V_6 z8fk$}nL+EiRnWj)1+7{j<L*ZxeXOI<kX{81;Z@KK*$oY*6_BB;i_kKn8yaCNp~<=( zk|7T*|HWtxas3jg#yPNpVG1;-&4e_YFG9+Xi;x9ZhoHF*QoWsrR{krYwe>1!GFb&p zKC57kg*H(;VJQ~c_*)9i94nx4yBsRs15H+|VCF&#@l|U;%@A<6tLGP^KEwmdVO>^O zsR<jkow)!~tanWY=>nJ6T~k0zPznEGE^L@?2GmhqP|vJ}2H7fT-MkuFQ>}&u>1t?8 zwF?@ntDq(8QfTb1hQ|78XqH<I&FM3tB`CB@0~uR71oio9s3TTE)7@%lKYcaSbMv9e zcr~<~T?);xt6`3YX00x$<5oj+(Q0UMvKpF3S3^t0c4!-T3B*x{p%K&rnI<|9X(%6s zPPaiO2QNac>VcJrQy@jlIY=@+4_&vl4_u%ehPrbFG=HstCaNB2vRw@;#$iL+t6>=v zn)s(dOQKF_i8dYDs$Kz2?<=68y&T%KTLBG_e%QdpWN5mD)DIUSb8SbVrTS9nlnb=2 z1kHcYt}<jg>>?zIABB2g={{I-1Btl9Q2VDr1G)$5&K_vNG93~sM<Jc$qp%f2Qz0XF z=b>q=9U477(2UXpslJXvi?r$R<~}s7bwj$JN1@9{piRDIP+zTvmM5#BS$f$VXa?v4 zrFw7%Sltb0b|ILndqAR~e02euBfFr%*$Iu7Zdffe1@04Ai+nOP$t{C+J)jY{5}Kqs zp((8eHq$?43p6CB!kV;`VWXf^AYJrx&`i+18>Vt4lrb4HHg*`&LbwPSV>t@xj9=^q zr@TY3=Is>780tk>bvYF_axxhb$QS#->JLMD`$r*3;V7hmb^&7KQAoS&9K2|R2w#9E z;&#}Yl&P?3*vZh?Z-A!Ch8~UW91IM%SRGw+GSjQrz?AhZW=G$EDi%lI0P9<9j)}>o zC8<^H5Zbzm-7%>swJg>87OP`&W>In#8<?`LVsT8a1d(Y)AWi8-iDe*7VA{Hh4ZP72 zMCT?Z7lD-JrGR+(>G^rqRjiKr1!>k*e2xVLIhAgudEmXaAPYbjom8<of+&!xVvtsL z$KvA5^gNIyC7C%XAWOis^(_|1(%hUXRuE}j#pRTkoL!ugSe#*9#p;w;RAybp?vz+m zo|<A^#o`2VDu+{Qa$;$5s&y5&Q)*FOerZllW-&-{YDpqUO<EC%19lmk6WGgDtWFRo zIF;rWq!wCNu{wJsS6bg<arO_0tYQU`)>Z7z-~h9(VsTC^u&xqyPAteQNz8G{Oaosf zRFavP<6>RK;hb2RlUi8}QlFeyln?Tcb8>1*W=<75gto3?a|Q)4NNsX{US?hi$i9^P z5|98$VNRlT6_+!36SoUUl*Jk3VixC&OpthHQF2ZySe(Zh%=XR9D=oIJ;)d`7azGrY z6nLYpb(N$uXuo)QCU~20Nq%XOXI@EadQoDIb(NTNPJVH!b7@gdr3?53uRzdcB-T{| z2yv(gn=|OJJdn3QbSlUx`FZI@rKuqIvpYjQA^_S?i(&(-GdQHVobwBc@>5EaORTFD z!24TMi*P%O&ABMQ7!+sD;CNwiE-e7rTv`AQdS(|F>nctcm;92V#EcZ{DpnV-<Vp|~ z456Yx6uV1edU`4-s$CL`ima>HToQ{jK#9c#5-n9ME+AzrE~z;n$<!Qh;&1^4wV+F8 zVscStNoI0ljw2|OSXc2Q34sG&97O<h_8C+qvSxQsX0fh97776+ZR;uym(0Z6d{AED zLrXxcF5vKD0o%gvl3xO5aJuA|xPs1zv#t_@L=;9qb3w$x$^~HT@;t|)qWp5}DyWE0 zYFY_YL=>V1BoYMLVGR}LLkNeYrdn5tK>7K3=^&+0Rg$Qp$Ogd7&Cg3m78Zo)Ko;Uh z5(3)=wL7!`YKss=L1=+XKHMWvv9MIoVF`&jPKia<Ra{8&yl^&HN)XP4n+jG9&G;f9 zX^_9b?g~pyF3B<`dTYhNPy##Q0%iFafwChyd6&VUQxQQAj!k;DQj9)>Q~)5D~Cm z4v;c%Fo3-fl9~z)1+aS)A<@X{0?rWZF2yB9`PtT0EUtd;*0-2lLp-WjTthspZ?U<8 zOQ|Y$2yI=(?g~low^&_4rA`$am;&hpC4W{|aKXdk3NGDU!KHc?JA}5b;(#8ZYF)+V z3Mt<OU2_XcDuY3%S_BuCCKjbySBZj!!cvP+h1p!8b$}~4J#)Ag6ldmuDg`!ZI_3t` z(EPyTT3DKylbKYMS(<BI#p(+7C97+3W-iF3C5hIzSX{xC0Eh&63Utjzv2_(MY-4+7 zVvehI6^k3lQ!H+vTrA`UIv+Fz#jRoxF$~ADx`7?Z?v`KVn3H2&#qE|~T9lbuR8o{? zUB&7Kag95ul)1&^9#X~Z9%5a^=AM|Fn`m9d4yIE;3`hl9#qJI+@IgvIL2g~e;tp~a zt2-pD-9fHnc2BpiVs!^w%j*t4U#kclAl6la$XuUPP&o(_ax2ZrfvVz%s)AD1RXk7@ zM28TR7o3xr2P-*X_CUj&)gA0FX7>{7Ds~UYAaHre=8>433QAZWi6z!mY#vY#c!1o@ z>yeq0lv-3047%LNx{B2U?0SBW{G!aN{JfIH9G}d*RFF8>Ty_s=8s+sU%?0OR5N%z> z1)`vyVD)qbg$$dgS577<JUsnD)h?SSGz~*&>szdzAZJvufhp@M7Eh2SR!>N9dV-U# zCp76oXzMCw&s^&&Hcv>Z<@U@?1YIstROxA5#o-CQ4W<}m4yf+pMAU}7AZ8KtOc3iT ze$PD6?TAS^sm}S}s744tYgRT-Xd?Fn2L-EVKByL9^@Id~C#3yS#pYR>4e}R@CpZa% zNb4##FOZ+Ct5`s(s*1%66u_)r5M#U``n`%%i$FeQ^8)LyV)X{KN~&1B!CKh76AKDJ z>CYRQ+E~0nidnqDCV4|l@&=p4>I2eoi^(UXirFW`x{BQg9Kc{kZc<93brmb<FbC@@ zZl6T(*}af-?*pzl*?k}dNEN#e%pxC<MS`GW6MRyK6KE@JYKe6f7gz{VQt`ss;L=S5 z&IK2b(4vh8B<h?BKG@m1N(jV*6!~x?p<?BENChfCL|u6vr1XSqgb9Ex1iQs8Cm&Rv zgEb)AD*!S9EC4ft10(_|eW5I<6ZxQAm_o3>LW(lMhbCB8flY#O!4`vE3=@H-b8uKe zsxg>3V2z;#NZtaQ99n>;0Kx^E%nfo1gl}C1b{B*LmIV73T1$Za3qJ7@Dj*0d6u@qQ z77Jkg#l=YF2@gmKT$U5W17Yhbeh`IRjBtSjpk)Y)4=A-U`+&+!pPbaR5~zjjKDn9T z?8)bY+Heqt@xh@F4P$<gAhG~h7m{&cT_8TPr@*?91z3H+iJsplzdW@F6jo5<1;7Hx z=Ck^M^973!s29QR11+eSeM+pWSbRaPdlp|%66f(vP01|Hg_d_*zNtAmnR(#6!Qu<@ zHy60=4QX<-`hqQI^#z;E>|1JG#p(yjc2(?tu-xVc%SnE)oa6_xM#L{QJ+UOSEEUB% zVVG!0MrLw0)D1#Nf_YFeF_;*rS_{d@go%s#r52Z@ra<EqN?BL&Lxe$*2*TD?9Db?g zkdm9l59BKjzkH{n)WmG-DnY;eJTNmeFCA(bs~^~#EPkM#39ny%i8G=Xzy;z$+vuWx zpq4ABU5wIF<Mzuhfj25RK^#b<mJh~+rYn$9uFyIjqzCSL0l)kbC<mOLt*b;3B1p+u z2q6kp4)Qr%FU02{M?z(h6F8C`Q0IU|K-Ctgi3Xyrt3X}{v7n9sDFCH7SiZNe686h4 zK^6gLQjmqnf>7NYV6~u%9%L-YZBPk*s07rJ)>S-E0gxK&Dv&2ZEM&*SOn|yv!Y{uB z65&uYpcF(iL<VF82t$kyC`wIEO-U^VM}G;72X&B`Up`z2*;bHCf>O&;i;7d>(JSbe zUjoi_h(H0w6^alzR6vHJh(av`1uCSK8C;rF460y2;fE{&RS2>jCR_k=Ly2{jxL<w= zsu)x;C~3jW1BEYy4V46iZ*XaHa%yS{Gyq^cr~;5%VM53O0P-wM92)cxvtaIlD1h*w zW`WW_R4pj|gPBk%kdMH8q$CYj1D1d!XOzsv>IW)&Zn61++Z|Qx5Zbzm*{{^Pip?K1 z5@dag%^zGERk1^8>sze;poT~l8<?`LVgWV5s@VNgl5!H0L0oY2${*Uig3ut-AT294 z|J>B{MC&RJ|J=-E&}c^$t3SAa5cMxe&BGj5;D-xChZUIpL0xozh{OHC<2qIB5E|rG zs89UCv~?A`Klm^s>su`T;HDIa1X*5|S_Do>T>c<dQDSncbrlbcoefGk0w7*MVo_>d zNk(chXgr8B0Ce6Sc+iF=08|XK1b|9EmH^N=3v&Qyumx1IgNu0UD!zdH%)I18@Rir# zMs5Juo6G@4)>WLaOaf8{%{|a~6oyG5rxiY!AT%P`0*W$oQ?08w0$?K~+yO=TplgUT zK^-Pu1P3%^!x{hztSXj(;!NvXEP<i^Ayup((z=Qz5aa>YK(NbL1HsDJf}B9DxLeFY zuI^PVL9XuBRqR3F6kuJ&8kCp^YIO&JRDgtwib`@o@~~<u2v$u6fx?G5DAl@(A3c`~ z!vv5!aH3Gb&;pcx9ZL|%fh<88`PNlJ;2e+Ie&mLTK^l;J2o5-IMG$;Y5elu_dBLLa zCZsT!i`IsO38FM21)wTnjYjJ#gfgUN6~sx<b|fcQ54e>GaUG(Q&JUA<=(VnbDu6c> z1tAKce6Wuo7Q#wLXo`V^3u;>tq8FvH2r(YfT7)TqSPwRy2W%rm02FbcK^_PXEDiBl zA|$X`gTRS~HwbjVB)o&f6NJ*d3IeAnmLO20i6^KuC)Fi2C$SPV@X8+S0Uj}}Vhsj& zQP_k1-9kWVhCLXX)|i8nt*h9BVJRyZnzGn}L4}WX6$^OijwKkBKKO$(@{3A9RV_4* zAp%H|E&x^m_8wFTFIWUV#KRVxnGWik^MHH*kdaaAD%N1ICs~6Fi$GmoNbO)<B@AJp z_WgJvf{@C=x=IL{3ymp$m>8r`x2_UF6@V(^fry6Yfip8}FgOrdgG)dIS1iG$NuXeX zR&P8I>!2DrVfBf16(5WVl@f;WQHm9qAhcKk>CXts0QKWpf<eP7EWw~*RL<a1n1lIX zOsKK!!KDSDdiEA;h=+fWUlkjevaVta337CC1<{b`WetHuS4d)#brnlUVySf%dk8FQ zL!eR10!{!dA)qMb3du+<0$-j3G9&{$5YLU=uH`~%x3WRq&kd%bPU8o2kZMDSELhaK ziZuirvs@uXpo5XXL!hi7;DBZifi&)Kv4w(DVih}twyt6g1s8jqASypO6Es8|ngs4| zvxh<ka&EDPf>LJ{8<?`LVhIH&=}=hJ7z(Z$L!nh8gto3?3x!mToS=(#Ak`8#gbAsa zc;Osy#Uu#kqSQ=m(6qt@ra_eu$W-V^Lnzp%9Pp&h4P}Azv>=p&lzDg{MF}*Y@S&B+ zY~Vu0x{4c2Lltp^7C?&yp3s7n{PH{~k3Y1a0JUQU7C_F2tf2+PnbuVtAPO?t7Yd!^ z357&QD5NI8#S#jxz(J&S6<Zi+aNfF#H7p67E5bnG%oYZ^?!vl?9Zcs~SFwbF#-rK8 zQj5T<SV3(c>na`)1sbUb2LLaO2kFoV!MMSxpo3t+gS&h%F=*NW@hg#%A4?c0#j=Kh z!<jV<;_R?8h-28oK`FwziY**;&Z>14OE_3@I7D$cSTRckNQ^lm)4GZ^0wNIsmSBwp zPo=R&LdLHmLCNVBTO>4HLTKwMwn&H-ERmp4V2K17#u^DRClYE-X>N{n6>Aivtc?O2 zU|q!?1<isiQ6QbHQQ!_Ze^hEwKKP(iSPw1=oc&m$zy?P_42}XBe2Xm+Y*ZCHgto3? zPlV)zDrRt7Ffkc4#+sO%VttD>5#-7$HZTR|f+iE$!1}GLSQ0_wU95?z;K@fYWnIOb zm<EyoXByCLvY>fH2yI=(k(iU3R$K`hvrEiLEy%F0VgsM)2%;g`i7hcVF(=*n7IR{5 zL6Hh0149){B53}EJuxo@%wSE-OG&Y=;sl-Wos(Yx8i-8HODO|c32x;i=B1~Ci~}8Z z3G!K9dTud9J&2K*2-XT_CLx%~2qu!+RD@_6f|-tBg595&4ytB25<zqs)XbuivLw(@ zabjM2F~pa7>BXR#zr?)sDsXwkmI%%0iQt%F29HK07Px|(TmTAfkcS|?E67Z-E>Z;r z1$$yaK~a7M$N^wRY9S~}Ksm39EfGXnSFt97qPU7B5o8@(VsT||0Vvo(G)OgDA~<7K zu|sI<TP%s-3<@Ga#+JjTD%ldtAybw~;2{9cq{QUx<a|&F^MIJCuwi~K5D#?JEvR7& zVuQ!>!J@^Pxv7QLRqRQLMP=YDodlh~<%BRm@x+>xRFrL9#R;NHz)ZFzh&3!ppw!Kl zlu}rl4>ANi*=t?JkpyOdZA%4BQj}R&u_b|=16Bl@2ez(aO#-KV5S0PeQc|9pnrB_b zk_5^O>`9sF$)ND&05LL)KrI#!3sh@@gz~`|iZdxQJ-+}v&B_I0LV6@sAmQS|WSCme z!MfH}0!f+aCD0}xs35hj;zJSvsRd~(g_s7i9vmJZv2sZH!k(0!2%f*=P0C43&d$lN zN(Col9x%5UIt9ZA=D{qot`b7wLo7xW1C6CwR|%u21Gn`+ftHh)mkp+~4UM3*34}I= z(D})r8G<BGKZqkK4|J+@87OS?Kx0CzN#JzLk_6(gC*_xv<mZB7AiumM6O{jw@+(|? zK&ItaxCB9I&<rd{9Mly|%CGQ%2z$6d=};&QT3G;+2K8o>@+(52#)LwR356OH3N<DS zqAd(+To_b&7*u%}D3d1TSA;>eg%yFFS&;<FM{G&?6)8{+DNqe5P=zT_^P&1Ppw7&I zIukS_4bq-b3QE5D6}gc4d5)y~3P?P2CgoQ^6AegRDb$)$s5PZfYf7QkfYWh)MH$o^ zWl-g1P~~M%XOuy;m4Uqh&3J5(;`<g`Qc+n_Vo?=4ga$<xxHMo(0$qa#=7MJ0*pfh5 z6U@yA8&{m411h+Zit}?aia||P)}&I<{1`ik0(GldlS)D52pfn3H4s5`DkvPG3n|!> zVKo9cV}TCq2N%|y$%zF?Mc~{55`#;^MZj5&H94`M*t&`h)b9q(MnUU0wq%Gndoo1e z7F#m7%~{0`p+P!8wG)^w1)0E+oLpK^Tnw68Oa_^Jixr}Q4NO^AaU?^Fj9V<A)AOrX zL8NsR7l=wN0_mt?Nd^@WtjQVR(kB^oz$Qomhz6ZZZe7Ka3>r9K0k<SslQWB4t*by3 zs1N};22|n+fEYQc;N}!02MQvIK=U6bL<p4XV9a3aDsHGKxcKIQazK=I6^sXIp@8fJ z)lbQpMQM=5CG5$WMY)+NAYWz{6@%T!mYh?XRBT<v38qUk!GQ}}*I`}74!#r-RE$Cx zg`iM`On*VH5CAP#0i6>IR+?LomIrcNer^HeHcU{MfH@VQ5kyu<k<9_3z@f+vt43Ip z!Nml7az1ETh&AXIg@Vc|kZ2{?;DX9xP>Vdd2vR8~L)U{OgOe?5axo||vVka2J)c|* zDoR0IP{qiWTmrU>Be^ssv8X5q<Z&<yY+z|>0hBHVM-Aw><|43?oW!D{0#H1H4C72L z1tm~WZNQ#fS^!O;r3KIgT3P_Mf-SkU05rkG3QArecb7uk%aIIb<bomxw6-R-u%IY4 z8Nn+qO$N0rl0kCdBA*+~gcSO>*pf?&ic<5c*dera6@PMRQ5kZw5kLq)Qw>{kDcB&k z<WlfbD9&U=jhzgsvDuR=bCOFy3uRIqK`UZdQ#?SeZT1xCLK*gy#GKR;(6TB}uvu5J zLJ|}kh$^$L;z)tjMQqRx5PJ$F|5dT1fHDO$sQJZ_0yB;+1!4?GN=kl7F{q8foRXSe z#gdYmZe7Ke0$Fgwkpj(lRqQEgnZ+5P378a6Mq^9KNCZV4m<E-EDVd46AV*|E*Uj*N z1oHDziXo{N!~;#~rhqCLj+D%F$mBd*3g|`&>nfI%%rfg+Y$=(b(`KvKA+&WBAB2&g z2Q80568U)*AirmUyu_Z8lbm0aXI%wi6y<{!A*JN!<bZ;WH3gi2Ss>{kCBFoe!8yS+ zSO~;~75ypsC6J<@3ltR4N}C^YHy@(O!v(6S!DWMW6+eg#!eD-}b(H{!laW|dke{Ci zEjo}ypoxGpr3e;B>?uVsmxGSbE&zE6l6O*yK|W(mDFzks>?x4$aTQw%B-5~_loVxx z;-{o2GYv$SLNZ`VX$HvG94Y0{iBHy)Dv&vxDOH*2kVMax3R;q7UBwDso_32Z6<qXJ zu|sHU5Tm#Rv?7Z=6`F2XQ$eNCEijc_#RlSm@?<Kw<gu<|Nd?)!nhFk2W>8C!Ej10? zxo1fQr4i=Tbn9Depp|T(t^|Yz=}HH!zDrFnhU&|)uHsAuP28mxfl^2+r~+e2%>gUQ zfhb~2g?2K)sS%_e)Pe*Jg;cSFg+L3(Qge$742?nl05MEJ9?dNV6&R_Y)-P*n9*D!1 z3T?ipf|Ca;sNV_FQjl0w460I7AqjyM(lF%!QILKzhy}K#5K^jhq!vPhfi1NV+;-+p zEi4AD=14CovaaHRazF<wgUkm_qk(+{zTefliVfN-;{em(1#_u|WpGy%frF7P6%uo- zso<o+mI?_C)>N>4ETFdXE#}mcj4BpTxp0dm72G8Nks!~P7UhGeie#|AK$CSKXH|f1 zx&WQLpJ!dg3p)otGchOCx{5C?5j26C4$1_e+`^IuieL7$)LgJMds<p1co_&=S{j&U zPfN=IGg#6<(ai>z&H{_FrsaUfw%DMG*wS)J@<3|_)AI5`t9H`B5x}07Uz7-nan`ha zP=|sIM3q@rai$f3hX3<QtZ%WU6(uGc8db4FXlp3L7$#!^6)=Ixn8FxlFop$`VFXGZ zAY+V7p}LKsx<M^xum#32-NrCYCNL3Gn0cl!DRT?!Dv<NQNhhr+zdX;niZu-!S<LC6 zzIeJTXuv)loYSnU*r25zJD3J7h)oAqVCj%%U=>?BByF*zg94rv6cN@{%%JWTOFC#7 zBuhFdT3FLl3k$8QIMbm?%({vt9aNdKrKc8ysx9_(XgcA5F!I4_K}iQxqOhi?f?Nwy zlmpVmk`9VH=Ja%sF(8sHJu??%8EZPYh-FR(4eg|ZS8t_*mcFv2=VXD@=7Abe>3JXz zaDpgE2bU!s)azhP&jY!X4Mc$&DCv3N6w8_pj&nBfh@5p5YdScjSku9hY#<8M0|C)F z*0-3_ONx|1ooCkc5|Fpp(n~<4Q59P{q$FfdFUbi2mwD+W&`iaZUQz_>X|sdaplTGv z0GBi%+0;TvhU88!DM~GbayZgUiXg%uwP43^rI)1^mE?f~nl-%)?AHu%t<0X0m{|lW zNmw%ybJDD<*fSDyGjl-W)ftIJ;Chxd16(9?fGCKIL9BA?D%K3}z!+NwB$nATQWJ|x zimj`-APjIt$({jP!~m+uGE$3@LDNet8K4N_%*ZZIg>*GR%yI~mEh8Un7kfs2ZV9Mz z=F7;>&j!^$;CjiriXX%W*FI1I)(mhIuxI2$N9i)aaloDdp4tO>2U_8<XH+IZ`VtwH z1sSQJb<&yOWL(7#p{=W!Gn1`vv1WpNQ^f|RtgBcu!AUn0R5jdU%}lLG&Z%MpQy{rC z&<Il|c!UX5D}ky72n{kU)4Ga1GcyxBdcg*z*)ucq(lYa`tJpF#!E3kJG9iTvTPCzd z0AEsNUBwBaL01?-nV`}GqziOanROLwW-h4AVav=d08NK5gG^+H%ol<bL9E~eTLta~ zvuEZ(1`}Aou3^v2D@g{;?Qw!GsY(aeQ($HhTr?-KC?ngtiX$_x1l(Y*V$IA4g#=qB zw7$s%hdV3G7hpxV*fPN>w~8G?gB%Ku4pvC3hz&%!f=n$2UA_+L1%O0A^$3^-bv;3h zGEne=l3*rykO<@@@QSosEScaM0Yq9?v1Nf`%DRdLoUd83K*@?N3mQOK5a(rqt!K}I zt!&Ezn^VP>od{XW2BtyPU^cX8#sXS7SH+SIGK@Vty$C#9!<r55g|TLXZDP%an4Jwa zn=Qu?oMc&ZAlWI$5p>g;brl<Esc?~X6*IV`$#DfueC9wJz&YS_XI;galL)Wub3h}L zpoU*gB6Niu=-LpFF^PHUpb<O}7gVXS<RlhY-(t;4EG*5hVgpmwRji=C1XyuVQId5P z2Z)=L1`1aY3(f$=C_6|b2b3W}i~>+^1;hZC5@0#dlq?Ilren`Zg!qLuC$R)nl7T2t z|2QWJ>}9qb&}f-;6?+co9(YhU9LxZX<>Vw4WrO;3Ai6jQ)E9)XKr=Tv(AF4x4m8Z! za*|UsK?BS=$)Ii)OAaWZvF4;CCxW~L9e2wC(V&h~PD&A|tquyll%mpNa5IrLCj~S~ z$P5Y~E~Mgu56*^oL;%ExwrWAmS?emW3aALEAI1+-0m9(&rP#U(EP!0%fXzS%6kAsb zfz*RVpavCNSBb#IiVI6K)4`@e4J*kgN==1!09bNBy%UxkQ0>B+11_F9a}f0)xJF~k zNrlvdIk0*V!T{BSP!_1el9O7T4vLG^VsP!r4XObW!K1UF1d&<{sxYmqxIn_Gh2S<F zSV?Ljgu?-n01Jaz(DVT9BeCbCK~^@h<bW~;a}KC>%>lIt*m6MC1Sp;|5{tmG3!*_S zw498joNQ3i1ZNs%P@9Mi)Rh4(V8{V?bHHu$9Jm2F;GO_`4s<0SdroeCDQNJR8^TCT z&PcVcV#xv5T{)0?8bm?s=^Su9odc<-K@_N-&Vkg^Y&rShl?NaiRE4tT<b#KJ`Ev3> zqx0}pgu*aBI5MGe#tjn8O)Mxb$p=LsX!#jvW*aKYmy@3lnY{u<I9LIc4>ki7Fd#lC z9KfXpdk%Cgmm?=1ng-Z&^2@=)EFcEBMrFy#uL4CHZ1j~iC%+2R#LOuGwGY@q6sU$~ z%YihfIdi~$FHmr@<rIN41Ur}pwa9XcK$9FfMbN-429+Bi*MJKzmK;#FVa)-@HXDcn zXY=CBTySw!T$lv%Krv+GI|oFAM*DIgRq8FKoRT6XaEm4f(xS<MwrFyoEt(u~QU@hU zxK~R+g$>AWur>~RPDv5C*~1Ene>M;Wb_JwI$eB}Glmf}+966;$kZvJY4pMU_2i%-t z%LVraZ?S;t(JEFDX$_)4MFMMXA}G8#KvXJdqZUgpsF}wOi&bt215zSDIgse&gvfwO z2GD(<*`P3H&jnv?X<fyV3o5ACazO(Y)>VADsfop<MX4#!4l7G8D66pKX5?GnVg;{O zs$v6EAdR5mG4|Zd6iB@1W~P7|R=3!4GeLtFRUjE~6ORqrqh|-xps9N>15}<u7@$?3 zxjD(8?sjetXrP!qHxJU|V+Y+52kLaP=7JL*GicnDH5VN1?777ypi5t>m~%mc#^4Kn zz#+nxTMDLG@<7`KSn@zi^;z@WOUkUPxbr{@BA}^W0L%fWaHt4No)4&9od;Ud%9`f` z(!rAlo~eZ@V9$e2y0YhiCs?hk*zyvSKn-yAJZOE$ng`CMEa1G&ng^bQV#`YeO*?@U zgI&y#2P@Oq@<7)RT32y^X>e->$||<L#gdm)Tu{XdB0&~`hKa4K*z-Vis&y4>9%OtC zw7?3~BxTQo)kJxqkwfb$PB0CQ0@gh65FAS$IIi;`am@@WY}oQZJ7z$}ra~G^Y<ZwD zGmwiwG-wwTTOMREfgLt!!Jd~2YW9NM1nKm$=cPh=vK$ZwXv827oN)3$#VZSV_JuVM z+)-i!QH9o3Tp$|UH3xYGT-vkcfqEI%RV;bwpz+c?a6!(N2WjH7<$)UPAUiX_1qgFq zCP*b{Q5tJrCTLQUB`*^+qml<Ms@d`&O&OLvP}7Ai50Yb9^T6qgB@dLLxWQvW(3lkf zbC44QYaX~lV*^oO_adq^kQAs1kq4@7Ku!V`Iw048GALUfDD#6t6hwm~3Ota^ng>e4 zx0v(tOR8AFvp#Hj`6b{+FPL@(#TZBc9Ag|{u`<vqK?n=fB7(4zK{n=>fcy_qm6r)q zm6r*cF@=gHgMt+tQe1hUY5bfVQ2&t~#0GUW*+2}?9BN)cK4_Q+<a*E;FMD1=QF1BR z)dir9N^E(ML0Aqj4XWYU@`}KXM7BIg!Oae)K|@erM!9trPabkOvgJXGZ7>b0{qn$r z$a%%dP>YH|D-T)oz`2?$uNbtD2^?bl5H`Z~tk9YeM1fjrU>a0K<`siAu;mqleaw+p zTv%M11Zum1S)c)K);!4YH;4jFx`1ei0_Zv-E|5rZDtJhe8_tH94jy^t$ODZ)gMt8L zRskp$ic3Lr%xrnZr64On3cyQ&sz7FeSRln9vmk8H9@)H-^c?G3Y<b{5K@~fM21Qi~ zs5!!y2b+(Cl-vR+e2{7Ua1n4ATUQC93V_rw=aqt@6SR7XJ+Cx36*T0;mRAZMcVo{h zgDe|i&nxo)H-K65%E0wV9(1(^YhD>>a05hv(?=P&2L?*dWsoeznpXzOJ|GIB0GiI( z^U5G8gCnmD6y>1$FRu(zE9aGi(+qoFIjoc^2V2eo5&+NDvgeh9N*?Pf=KNsmTWtB@ z;<Sn#LR(j{=7Vb)R`8;uTVN`=iVegAt+$2r>hdAw8hbu;sGT(*G=N>j3h6bn=YvLX zLDQl6pcNL@Rc!fbpbD#sB_C8&v4XpVx7hN*;~-V+5ZbzmB_C86vE@UC30U$oK=Was zD|$f&KuQ(1{2Z`B9QirWDHk?So&qKHd~k`752?u6@}cW~^TAapXjm#AoNn3k!4)CM zm!LADiWSn@V#_Z`1x>E7L0enQpji{Pd`Pxq$u9!?r6>hdopa=a==?P6TOjeYD%Sj> z6euSb%mGa&=NDzBgL>So`9&a;IP!~%A!|NZ@<BVoS@S_T@D^J>c+{ba9YTW~1se6f z#g-3Evk=<4iXGPW<Ag90K~+{hxNi$0LE!_MKeeu60cFZtATqHEe7Cf96(=H7vxCN0 z!4s(<2B-%G875#U0997(1*t{JpdDu*MrJ;!6Iqa2lnd@@K|+V4AhoC@6*T$IQUHob zmIBa}B5Oegs5W3P$jHqF4|o=2<b&!v<^s?f<pR(xy`Vu&kmDfgauV}E6Z9MfU`B>@ z6+4KP4XRNfZ4pio1zAhN24aE=WDpIGdUg;i1+=sR%m7WcgBYpSx4>$1^FYRx7U$+! zS8;$Oz_|j<Dk;ymu3|381%(MHS%JqkSPMYu;1+8EXk}>?8<+yA0v#4mPy`y|D<}eG zS~h55%>pi~Ss_I=H;95YFnB;5@H`o)WMBvJKn$=jycNO;5{8VcL6}hI6{RMFS!~dm zadt2b8ZIs<0`*|n3W~tZ9QJ}DP*H4M#R?ulsp14(9GnQA@c}cTLqH%=(4EK-b)epR zK~a7Is7Jz9Pz1J!y`ZSH2vkq87J$-X6$^M_9D6}&UNUHOkEIY4!K{UlFe(IvQ5Ab3 z*iqJ1tc74LJcXb;Rf|9iM~khiI6yqGayIaw4p;=V!>7>t77OUIz#=tJ+n=onI{pDE zz}Smm;~$`<h@gIH5qQvp6|xwSy$D=5Sy!=v?)wJKNfyD!Kv;{w%|A8}1<Icw8dOz* z=p4{F5k;WB3rHupKf(&h%<Lcv9HAfvC}n|Z(3l4shy|)$K{QAJtQI^70uliaf`Ay{ zK@boF5|AJkXb=Rfz1+Hry$CuC!d3*DXRxl~0@HbkIiQ9NXxI@n!CM3!3n_w)g@75L zv5+F@SO|!QjD<j0px$y3Y%HV*)&ebpj)fFK#zMdgL|Kc#V<8+xDLIg#54IxEXb8w@ zAQ~LX-~kZUqEt{r7<ADlG~s{*AcX=OhzUx7MXAXp*0-38K$D|Ipy3DhB3L)S2-eLn z0;Lu<P+t-p6QDjl$TkoSYUUS#R@Ac=W#of82H@Hh+7{$Ta3CWtf?xsYxCo?!1yKVP z0`;r}z-mC%HrN!<hzeW;stmL_1}p|9V9FpGkq1~HBH(T(w9Cl~S&qhA1R7Wb%|L*r zhO5|$p!H7?X!yapilrzARLmE_h8!Ra$dChDQ69LeVJm`;A{0Reso9DkqX=w8kUEF8 z2$HLcpmh#M5u|Xpu3{|$72{RxAPQ6^auyZ9nvQHmpyUP$TUgJ$2%HyLioiYdB1jj! z2-NikD=I7n)j#Y-U@wA1;NApx@Y!Ik2M`TfD+r=NjSTB5j-t{WNbi}ssKUC6y%?4g zi<7|li5b+iWGPMt6_Lfspd7_s3{9PE(Do(^xVgz*3`?t^#T}r=a&a=aNGnc;6lulD zkRpw<I2rEEVn}hw0+|ekj7715D9{K4hz2!zilH4UP!|c5P1!&U(3l^X&M&vV#RA$a zUBwC_twB^SXpp@)wYVHKFv3}!S^{kiuz{GMRzh)V1!#`H7?hsbi=k6mY@qQ3P$62J z0a;(eS_~fG<wP`~`M^wgReOuMIHR(Pr8uL~x{9qBve=&;OoOIOzzopJPe=h$oS6&m zh_FIdH?e^zPy-e+tODYKx^^I0&^TFfW-hp&Rh*d%s%1HfGjl=JoOKn51xXxi#gNp> zR}4A`0pvBv8ZY+Z+{EIH0_!Ty;#|<gFQ|9I3T@99=VpSMnk>b+pblYiE_eVJM1e+y zi}TY;KurV|Q1hgU6|(G#9Yle`k+m3-kc$fv!Ta*KAPn$)4(JkXP;pmW2u&g&8dMHK z*CMimX^22EXf&4{)}P=6Gr)7)+%P7nK4k-Oz>!f1=?j1rf|~u-RbYi6CP*PmaUrP4 zge^j32Qxs!V#S4}prr%FkicRs24^7lVo*4NM%0U;LBU=OS|kb90NxD22IUGAmlP#} zhV(#F;^4_~9+(KYJ;YXAQUsdlWdZw#wYW41v^ci7Gzl8Xklqrg(*zda0Nr+63U0g> zmnK0nMk!?NVsU8_ENV-WAg*OEhW4R2Aq<d5xnN9C-x<ON4{LJ6*`U>|AP%VQ2Q~o` z(xpk@g-NWS&K4-}N<j<PAmgJvATdN^2E+qd1r|m$W<bKw#tfJVPR|@5CYZ%i4C)xM z7MJFwgR)|2fngPEacO}egkuEe7(qD3V2-hM6${Kspza=fF?1ml2Z#X+PjCki6!)<3 zE64z+OOPVSGC&Xuk_A94(0COn8<rM8L$?5uaY_pyp$oDFoX$9l!TU=<9_4~DAz=zi zQ?M|FvLRtw0QM-@1ZbERfIYxg4DE)2iW*4S1nq`_1R&k8;&M=z%=#8<aTRzSI+(Jq zVlPQ7N(U`oWGMmdTw#SQFJ>=+7Ow0i(BhN@oF!SIW2YslIp8H+EG6Kgs|2*6#l*Ub z3(QE%2M;imKz6opf@$z-c6Knc%({xF1hk7A)|BN0^B`U;$;gDP94X1j2AA?B8QCD2 zTdXA+`9*nEY+%Z|iVfUnvA)F$u3<pjT+sYFJD3Yvr3qnx3Ji!C=wzf4aD$PxBtI2& z^i>IX1yf0W0c3G*Nqzyi#m`y-E?+o66nK#YYe{}F=wyi!XnT~cq$n{3w5Sl)rMIr) zg)t#*2sjtiYOt>2hslDt;OK@46k1pD!PwxogLRbv3Lm7Jy`%_odH`!l5okRZXGu{e zv?Ads0d4UCopHrhQj}Q?YG0Osj%ot!pX4klDoCx$1m}qoaG}Fm0<PcKN+9(KdkJKu zyo#-)JQGw836_-SXQU>kfSd_##8_7eL50AMgNm`1g1h{zrJ$zsEw)l{O<lzfp{=V} zp=+c{q1%T_A<Hdpv6g}+M61}qlywzLDX55N1209iu3|5RcJ0|pA#F(ZQfRA>r4&4Y zT?*~JLul(NHc(>$R6&7gP?28>nb2V`1y9~sS8+lZpguH647^;8trXJOU@Hap+ix+0 z`m`+I?IUcZ;9-I))>269mqMmZtgCoHWdeND4_|2kw9N+!B<m`EI3FBBAa_A>Icq7n zhr<S<K#S`^G`RHUE-iqX4XWx&!E+-Z*Mb=k*Fu-5v6Vs^his*wW)di1!Li6z3eAJ1 zkStKeT3P~Lqz0luHBBiv0&cOCf_%pcBCV@9O5rQj${?{<2HqjW2BJU{+pxi-GVlfs z>niRt(C%L7Aw`^JiACVKXoz@TJ}8%hrt``Yiy)N{hym(<gJ@{ikF^Xu5X26mKn-$` zA>gKnbro+}ViBl<NCmC=u&&}m<`%-Fp#>jI8p;JN#VJcH0v9CKRRSO;bVmUsLIjaS zpi#n722N?vQ7{(p!cg|I)Ku_f7F$_rDmass!B&El!FE)ECULB*Sjs>p99tPQ<&=R2 z5Us1&Ks0DxqYRu}*vdd1UXU;}s>;Ao#a;%jV<8Mscd@J(QZIl+AQeMdRc3lsB4`z8 zIVgizSFx9;ra;^VSpf?c01vUVm#1ce2aZ_EL5^ZA2V2fuUSM6tTn?K1DhC~%1X{CN z4z{1Q0^AH@tAH5HS^=IcV5@+vYGkPZ8NyZp9fq%f48t>5fEGMfKt=@FDj@Y5YXx}X zg|#9t6V!OBfDF8`R)FniuYh(b*ek$Y3hOGi3P^XGtpd`FV66Z<hrI&a{IafMuYhjy zV5<NnTI(v-3P`L}Kzw|QtrA+OKxpeK)=JPGsw%chh)-B5K|89LD^v5TSSrC=Rw_Y$ zVXcI$hp7a+i?tGLD{CdFq`AdX3C<26(z=Sh3T!@z0j=j)!0R_ztH6~!dsS*G_+S&( zD$uIGDwZm+=~dunI0t-*Cu<eNo+_|CELG)M)>W)k<#}0<GkxFh-&^#bfq~&G=tR#$ zjSvcQa^@lEZA;LLQRiwZ6)`d}Fuddi5e*=s5kxeBh-MJc0wP*LL>q``2N4}0q7y`P zfrxGp(E}oSK|~*j=m!xKK*U54F$qLW1`$(0#8eP54Ma=_5i>x<Ob{^(M9c;eb3nvg z5HSx#%m)!*mxBEC5_IDFOBRqA=<NBIY#<gp0|SF5$1Qf3{N$3#g4A1F&KZeCiOD6Y zMa8%H!JF=o1UNt&e@j9V({Hi4=B0pW4)FPDAQroGer|4RUdb)4fJD$i8bw9<MMVxw z3=Bn%Ai{}>fgu^>6b2{&IR@kwX9fm_Vlf5=hD?SUhFHEBrdq~YrW&Ri#>q^DEWr## zpBNY*geG&*X9fm_Ta4Ma7|RgCML$3aeljpHRB$se6#W7zVF9h%NrqYkr$DwlfNT?B zU|>jPh+<4(h+;}%jABk<3TDt`zQym7Sd!?IUtAoXSd^EUmtN%*l$cqZnxasik(#Ga zl98&A3|`t^qEJ$lnyQdltWXM?bWBw!$yX>!EhtJYPR%O;tINzQC@oP)Ni0e9(`32D z5g(tIn420Oe~T+VJ~uz5GzY}yiH`>@dxgrd$H%ASC&$Ml`3vlEu;)CO7#M1}85oK| z;l;to!dL_n!R<dD6#oS?XfoXrj1L0$=~7)Ql2Z#xGV}BNG?|M$K{4Y6BD_Ha*hT~a zw%eD9fuRv(Hz);hFcyLMn))E0q?MMG7Ny3=7lCAoK+#zQa^Edb4<|D({T8#UzuPTF z*IQg5FBXGNT`RuDnN|c^hESYZa*Mw>Ilmw?FWnWg^`iKeP+ERbZemFZvKW7HL25GS zbUc_MnT(R$9MER>bjYw7=wJ)jnLNd}ltA&Gn-h{+QG!#AaAHbUX>mz#n7d<1Nl|7} zX-R7FEis6oZ(>P?uMd*AI7HknzbG{`Jr7BOHM1l&xA>N1X&x>W{9rF5WghX8#H5^5 z&%EN)q7vWylvKFK`4fwiGc)6JKnFi1Cl;sP;sXnS&wT>(p$bYt8<@cY5C!1<%V0h) zSVMeHY6&>s@_@NMP##-KW_o5x@h#4b)Cwe~3q(`^tQKsP5!l9C{Gc`^awPDS<!7eA zUCWycO4o2MUlA%_FeyJjCp8f{tb|kZN-|3_Q;Wkv>-5Tt4UJ5VZgE%S=D0$|Z*jm> z+!6(!QIebrDoK#Sj;ka;J2fw)vLLni7H>&ndI*BcQBahcmRXTne2Y7@IJF3xcfmR2 z7AHKlgVQax%yo;y29hQ1K*d9`oG1f>2onbr3kwqhFf%bDI8YX*2vmY*6wF2h4RRNZ z#{_jFL<}YhqCptqD3BaT9f*ctkT{41qA_s;Lj%Jjwt9wo1{EeoIQ+%N$;8M-2)<_% z!K>;Mn;>3!Lgr(aXC~+_?D{Z8H?Rf6-S>x$9nNOt`VI0wJTwsDg2ZBBq!~QK;mE@* z#0Y}|j6#ec3?{#D@N+S;{byt5<KW|fhXj)dGaDzL5Dya{Hy_xae2gH-#mL9V1LgC8 zMR*uNG}l`W2{vUuW}5kcc40GW@@NQ*hQMeDjE2By2#kinXb6mkz-S1JhQMeDjE2By z2#kinXb2465CDy|;m0SrK;v-uu@4ne`8^IbCe(2H!ND!W$nl?zMU0V)S&S6`yHD<- diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-39.pyc deleted file mode 100644 index 1c6cea33c4a0e43345bd7b91338b40b77075b430..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 91039 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 AVE_OC diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-39.pyc deleted file mode 100644 index a4d75e6ec85c5feaf571585a21b770cd58cb4677..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10841 zcmYe~<>g{vU|^UdaWJ*tmVx0hh=Yt-7#J8F7#J9es~8y=QW#Pga~N_NqZo6UqL^}- zqnH^%VoW(KxvWvFU^a6OTNGOgLkdd{doD*5M=oa+CnG}&YYJNqS1xxHcP>v9PcCm1 zFIbE{hbxyaiZ7Qxia%E%N&qazkt3KZ6eW}^93>1kk26OkS2RkLks*a^fmkZ<LdFzs zafT@IRJH{YDLkp-;tVOg;tUHJqa=|;_`o7knG8|VsWK`2&5S9m*-TNgsdB0O3*;9v zG&8y|#OB2?MJYrnrpgvQN|i}f1gl{wK9wq4`~}Jv$Yv?}Qg|v=F-0(&x#$#JlxYHE zkyxtm0;N>Ng^W>(c^s+AApKE_sfwx6WsDOTiw#m07N{&_C_0s@kSd+3Xv0u=Dn%$o zxP>7~HI*YpBvrMUiIE{iCPgeoyoE7J&7C1dB1N)=Aw@D(y_q>m!<`{TDn+`5Aw@b> zvza+cD}_0jK~wf6C{{F?Z}BH473b%amZZjK<`(1^mE7V;$t=q(&dkrdB~Y4|nVg@J z8lRI{l3J9QQ>@8&i?bxPq9negvLMw@lj#;;QEGZ-aY<@Xd}>iqe$g$7irk#!jKrd% z)U=}1f}F(URER|JOGX9;22JK$JZ1TrDXuxGxv6<2#kT~L^7C_26Z0HPN{TX*N=s6U zZ}ArwBqpaiXCxLSCYPiZ6>Boz;wwr{Ni0c(>*7ewE6FU$Of9~}U6GsP3gu`r-Qq4O zN=+?K%*jqID!#=QUs{q0b~0OPadKio>Me#UHYIgi8@q&GjM2XsV@u;fA;8GQ%)-jX z&cVsW&BM#bFCZu+EFvl<E+Hu;Eh8%@ub`iBXu-o-4G$OeJzUWLsG;FeL*t`{rbi9U zj~ZGYHMBlzXnWMq{-~kjQA6jWhOS2qD;_nheAKZ1QRDo_4GpoSpyd9gfB*iMObiSR zzZlh$LE!+h7lc7Mg_D7S!5Nevq!<|(N*HPwN*GI+(wLe-se&(^p_Vb7p_VCyv6i`n zxrQN&rG_DkwT2;!t(8d<p6+T{YFTTTi(Eje3XN*OYQ!08*-F?KaDer&m2iUe)Uc&6 zi8G`#H8X;AFJvt0D`8*21yKQ!gNWC%r!dzt=W	*RVD-*0R?yE#RqPU&zSFP-s-c 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 HGZ+E@v+?(q diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_ihatexml.py b/env/Lib/site-packages/pip/_vendor/html5lib/_ihatexml.py deleted file mode 100644 index 3ff803c1..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/_ihatexml.py +++ /dev/null @@ -1,289 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -import re -import warnings - -from .constants import DataLossWarning - -baseChar = """ -[#x0041-#x005A] | [#x0061-#x007A] | [#x00C0-#x00D6] | [#x00D8-#x00F6] | -[#x00F8-#x00FF] | [#x0100-#x0131] | [#x0134-#x013E] | [#x0141-#x0148] | -[#x014A-#x017E] | [#x0180-#x01C3] | [#x01CD-#x01F0] | [#x01F4-#x01F5] | -[#x01FA-#x0217] | [#x0250-#x02A8] | [#x02BB-#x02C1] | #x0386 | -[#x0388-#x038A] | #x038C | [#x038E-#x03A1] | [#x03A3-#x03CE] | -[#x03D0-#x03D6] | #x03DA | #x03DC | #x03DE | #x03E0 | [#x03E2-#x03F3] | -[#x0401-#x040C] | [#x040E-#x044F] | [#x0451-#x045C] | [#x045E-#x0481] | -[#x0490-#x04C4] | [#x04C7-#x04C8] | [#x04CB-#x04CC] | [#x04D0-#x04EB] | -[#x04EE-#x04F5] | [#x04F8-#x04F9] | [#x0531-#x0556] | #x0559 | -[#x0561-#x0586] | [#x05D0-#x05EA] | [#x05F0-#x05F2] | [#x0621-#x063A] | -[#x0641-#x064A] | [#x0671-#x06B7] | [#x06BA-#x06BE] | [#x06C0-#x06CE] | -[#x06D0-#x06D3] | #x06D5 | [#x06E5-#x06E6] | [#x0905-#x0939] | #x093D | -[#x0958-#x0961] | [#x0985-#x098C] | [#x098F-#x0990] | [#x0993-#x09A8] | -[#x09AA-#x09B0] | #x09B2 | [#x09B6-#x09B9] | [#x09DC-#x09DD] | -[#x09DF-#x09E1] | [#x09F0-#x09F1] | [#x0A05-#x0A0A] | [#x0A0F-#x0A10] | -[#x0A13-#x0A28] | [#x0A2A-#x0A30] | [#x0A32-#x0A33] | [#x0A35-#x0A36] | -[#x0A38-#x0A39] | [#x0A59-#x0A5C] | #x0A5E | [#x0A72-#x0A74] | -[#x0A85-#x0A8B] | #x0A8D | [#x0A8F-#x0A91] | [#x0A93-#x0AA8] | -[#x0AAA-#x0AB0] | [#x0AB2-#x0AB3] | [#x0AB5-#x0AB9] | #x0ABD | #x0AE0 | -[#x0B05-#x0B0C] | [#x0B0F-#x0B10] | [#x0B13-#x0B28] | [#x0B2A-#x0B30] | -[#x0B32-#x0B33] | [#x0B36-#x0B39] | #x0B3D | [#x0B5C-#x0B5D] | -[#x0B5F-#x0B61] | [#x0B85-#x0B8A] | [#x0B8E-#x0B90] | [#x0B92-#x0B95] | -[#x0B99-#x0B9A] | #x0B9C | [#x0B9E-#x0B9F] | [#x0BA3-#x0BA4] | -[#x0BA8-#x0BAA] | [#x0BAE-#x0BB5] | [#x0BB7-#x0BB9] | [#x0C05-#x0C0C] | -[#x0C0E-#x0C10] | [#x0C12-#x0C28] | [#x0C2A-#x0C33] | [#x0C35-#x0C39] | -[#x0C60-#x0C61] | [#x0C85-#x0C8C] | [#x0C8E-#x0C90] | [#x0C92-#x0CA8] | -[#x0CAA-#x0CB3] | [#x0CB5-#x0CB9] | #x0CDE | [#x0CE0-#x0CE1] | -[#x0D05-#x0D0C] | [#x0D0E-#x0D10] | [#x0D12-#x0D28] | [#x0D2A-#x0D39] | -[#x0D60-#x0D61] | [#x0E01-#x0E2E] | #x0E30 | [#x0E32-#x0E33] | -[#x0E40-#x0E45] | [#x0E81-#x0E82] | #x0E84 | [#x0E87-#x0E88] | #x0E8A | -#x0E8D | [#x0E94-#x0E97] | [#x0E99-#x0E9F] | [#x0EA1-#x0EA3] | #x0EA5 | -#x0EA7 | [#x0EAA-#x0EAB] | [#x0EAD-#x0EAE] | #x0EB0 | [#x0EB2-#x0EB3] | -#x0EBD | [#x0EC0-#x0EC4] | [#x0F40-#x0F47] | [#x0F49-#x0F69] | -[#x10A0-#x10C5] | [#x10D0-#x10F6] | #x1100 | [#x1102-#x1103] | -[#x1105-#x1107] | #x1109 | [#x110B-#x110C] | [#x110E-#x1112] | #x113C | -#x113E | #x1140 | #x114C | #x114E | #x1150 | [#x1154-#x1155] | #x1159 | -[#x115F-#x1161] | #x1163 | #x1165 | #x1167 | #x1169 | [#x116D-#x116E] | -[#x1172-#x1173] | #x1175 | #x119E | #x11A8 | #x11AB | [#x11AE-#x11AF] | -[#x11B7-#x11B8] | #x11BA | [#x11BC-#x11C2] | #x11EB | #x11F0 | #x11F9 | -[#x1E00-#x1E9B] | [#x1EA0-#x1EF9] | [#x1F00-#x1F15] | [#x1F18-#x1F1D] | -[#x1F20-#x1F45] | [#x1F48-#x1F4D] | [#x1F50-#x1F57] | #x1F59 | #x1F5B | -#x1F5D | [#x1F5F-#x1F7D] | [#x1F80-#x1FB4] | [#x1FB6-#x1FBC] | #x1FBE | -[#x1FC2-#x1FC4] | [#x1FC6-#x1FCC] | [#x1FD0-#x1FD3] | [#x1FD6-#x1FDB] | -[#x1FE0-#x1FEC] | [#x1FF2-#x1FF4] | [#x1FF6-#x1FFC] | #x2126 | -[#x212A-#x212B] | #x212E | [#x2180-#x2182] | [#x3041-#x3094] | -[#x30A1-#x30FA] | [#x3105-#x312C] | [#xAC00-#xD7A3]""" - -ideographic = """[#x4E00-#x9FA5] | #x3007 | [#x3021-#x3029]""" - -combiningCharacter = """ -[#x0300-#x0345] | [#x0360-#x0361] | [#x0483-#x0486] | [#x0591-#x05A1] | -[#x05A3-#x05B9] | [#x05BB-#x05BD] | #x05BF | [#x05C1-#x05C2] | #x05C4 | -[#x064B-#x0652] | #x0670 | [#x06D6-#x06DC] | [#x06DD-#x06DF] | -[#x06E0-#x06E4] | [#x06E7-#x06E8] | [#x06EA-#x06ED] | [#x0901-#x0903] | -#x093C | [#x093E-#x094C] | #x094D | [#x0951-#x0954] | [#x0962-#x0963] | -[#x0981-#x0983] | #x09BC | #x09BE | #x09BF | [#x09C0-#x09C4] | -[#x09C7-#x09C8] | [#x09CB-#x09CD] | #x09D7 | [#x09E2-#x09E3] | #x0A02 | -#x0A3C | #x0A3E | #x0A3F | [#x0A40-#x0A42] | [#x0A47-#x0A48] | -[#x0A4B-#x0A4D] | [#x0A70-#x0A71] | [#x0A81-#x0A83] | #x0ABC | -[#x0ABE-#x0AC5] | [#x0AC7-#x0AC9] | [#x0ACB-#x0ACD] | [#x0B01-#x0B03] | -#x0B3C | [#x0B3E-#x0B43] | [#x0B47-#x0B48] | [#x0B4B-#x0B4D] | -[#x0B56-#x0B57] | [#x0B82-#x0B83] | [#x0BBE-#x0BC2] | [#x0BC6-#x0BC8] | -[#x0BCA-#x0BCD] | #x0BD7 | [#x0C01-#x0C03] | [#x0C3E-#x0C44] | -[#x0C46-#x0C48] | [#x0C4A-#x0C4D] | [#x0C55-#x0C56] | [#x0C82-#x0C83] | -[#x0CBE-#x0CC4] | [#x0CC6-#x0CC8] | [#x0CCA-#x0CCD] | [#x0CD5-#x0CD6] | -[#x0D02-#x0D03] | [#x0D3E-#x0D43] | [#x0D46-#x0D48] | [#x0D4A-#x0D4D] | -#x0D57 | #x0E31 | [#x0E34-#x0E3A] | [#x0E47-#x0E4E] | #x0EB1 | -[#x0EB4-#x0EB9] | [#x0EBB-#x0EBC] | [#x0EC8-#x0ECD] | [#x0F18-#x0F19] | -#x0F35 | #x0F37 | #x0F39 | #x0F3E | #x0F3F | [#x0F71-#x0F84] | -[#x0F86-#x0F8B] | [#x0F90-#x0F95] | #x0F97 | [#x0F99-#x0FAD] | -[#x0FB1-#x0FB7] | #x0FB9 | [#x20D0-#x20DC] | #x20E1 | [#x302A-#x302F] | -#x3099 | #x309A""" - -digit = """ -[#x0030-#x0039] | [#x0660-#x0669] | [#x06F0-#x06F9] | [#x0966-#x096F] | -[#x09E6-#x09EF] | [#x0A66-#x0A6F] | [#x0AE6-#x0AEF] | [#x0B66-#x0B6F] | -[#x0BE7-#x0BEF] | [#x0C66-#x0C6F] | [#x0CE6-#x0CEF] | [#x0D66-#x0D6F] | -[#x0E50-#x0E59] | [#x0ED0-#x0ED9] | [#x0F20-#x0F29]""" - -extender = """ -#x00B7 | #x02D0 | #x02D1 | #x0387 | #x0640 | #x0E46 | #x0EC6 | #x3005 | -#[#x3031-#x3035] | [#x309D-#x309E] | [#x30FC-#x30FE]""" - -letter = " | ".join([baseChar, ideographic]) - -# Without the -name = " | ".join([letter, digit, ".", "-", "_", combiningCharacter, - extender]) -nameFirst = " | ".join([letter, "_"]) - -reChar = re.compile(r"#x([\d|A-F]{4,4})") -reCharRange = re.compile(r"\[#x([\d|A-F]{4,4})-#x([\d|A-F]{4,4})\]") - - -def charStringToList(chars): - charRanges = [item.strip() for item in chars.split(" | ")] - rv = [] - for item in charRanges: - foundMatch = False - for regexp in (reChar, reCharRange): - match = regexp.match(item) - if match is not None: - rv.append([hexToInt(item) for item in match.groups()]) - if len(rv[-1]) == 1: - rv[-1] = rv[-1] * 2 - foundMatch = True - break - if not foundMatch: - assert len(item) == 1 - - rv.append([ord(item)] * 2) - rv = normaliseCharList(rv) - return rv - - -def normaliseCharList(charList): - charList = sorted(charList) - for item in charList: - assert item[1] >= item[0] - rv = [] - i = 0 - while i < len(charList): - j = 1 - rv.append(charList[i]) - while i + j < len(charList) and charList[i + j][0] <= rv[-1][1] + 1: - rv[-1][1] = charList[i + j][1] - j += 1 - i += j - return rv - - -# We don't really support characters above the BMP :( -max_unicode = int("FFFF", 16) - - -def missingRanges(charList): - rv = [] - if charList[0] != 0: - rv.append([0, charList[0][0] - 1]) - for i, item in enumerate(charList[:-1]): - rv.append([item[1] + 1, charList[i + 1][0] - 1]) - if charList[-1][1] != max_unicode: - rv.append([charList[-1][1] + 1, max_unicode]) - return rv - - -def listToRegexpStr(charList): - rv = [] - for item in charList: - if item[0] == item[1]: - rv.append(escapeRegexp(chr(item[0]))) - else: - rv.append(escapeRegexp(chr(item[0])) + "-" + - escapeRegexp(chr(item[1]))) - return "[%s]" % "".join(rv) - - -def hexToInt(hex_str): - return int(hex_str, 16) - - -def escapeRegexp(string): - specialCharacters = (".", "^", "$", "*", "+", "?", "{", "}", - "[", "]", "|", "(", ")", "-") - for char in specialCharacters: - string = string.replace(char, "\\" + char) - - return string - -# output from the above -nonXmlNameBMPRegexp = re.compile('[\x00-,/:-@\\[-\\^`\\{-\xb6\xb8-\xbf\xd7\xf7\u0132-\u0133\u013f-\u0140\u0149\u017f\u01c4-\u01cc\u01f1-\u01f3\u01f6-\u01f9\u0218-\u024f\u02a9-\u02ba\u02c2-\u02cf\u02d2-\u02ff\u0346-\u035f\u0362-\u0385\u038b\u038d\u03a2\u03cf\u03d7-\u03d9\u03db\u03dd\u03df\u03e1\u03f4-\u0400\u040d\u0450\u045d\u0482\u0487-\u048f\u04c5-\u04c6\u04c9-\u04ca\u04cd-\u04cf\u04ec-\u04ed\u04f6-\u04f7\u04fa-\u0530\u0557-\u0558\u055a-\u0560\u0587-\u0590\u05a2\u05ba\u05be\u05c0\u05c3\u05c5-\u05cf\u05eb-\u05ef\u05f3-\u0620\u063b-\u063f\u0653-\u065f\u066a-\u066f\u06b8-\u06b9\u06bf\u06cf\u06d4\u06e9\u06ee-\u06ef\u06fa-\u0900\u0904\u093a-\u093b\u094e-\u0950\u0955-\u0957\u0964-\u0965\u0970-\u0980\u0984\u098d-\u098e\u0991-\u0992\u09a9\u09b1\u09b3-\u09b5\u09ba-\u09bb\u09bd\u09c5-\u09c6\u09c9-\u09ca\u09ce-\u09d6\u09d8-\u09db\u09de\u09e4-\u09e5\u09f2-\u0a01\u0a03-\u0a04\u0a0b-\u0a0e\u0a11-\u0a12\u0a29\u0a31\u0a34\u0a37\u0a3a-\u0a3b\u0a3d\u0a43-\u0a46\u0a49-\u0a4a\u0a4e-\u0a58\u0a5d\u0a5f-\u0a65\u0a75-\u0a80\u0a84\u0a8c\u0a8e\u0a92\u0aa9\u0ab1\u0ab4\u0aba-\u0abb\u0ac6\u0aca\u0ace-\u0adf\u0ae1-\u0ae5\u0af0-\u0b00\u0b04\u0b0d-\u0b0e\u0b11-\u0b12\u0b29\u0b31\u0b34-\u0b35\u0b3a-\u0b3b\u0b44-\u0b46\u0b49-\u0b4a\u0b4e-\u0b55\u0b58-\u0b5b\u0b5e\u0b62-\u0b65\u0b70-\u0b81\u0b84\u0b8b-\u0b8d\u0b91\u0b96-\u0b98\u0b9b\u0b9d\u0ba0-\u0ba2\u0ba5-\u0ba7\u0bab-\u0bad\u0bb6\u0bba-\u0bbd\u0bc3-\u0bc5\u0bc9\u0bce-\u0bd6\u0bd8-\u0be6\u0bf0-\u0c00\u0c04\u0c0d\u0c11\u0c29\u0c34\u0c3a-\u0c3d\u0c45\u0c49\u0c4e-\u0c54\u0c57-\u0c5f\u0c62-\u0c65\u0c70-\u0c81\u0c84\u0c8d\u0c91\u0ca9\u0cb4\u0cba-\u0cbd\u0cc5\u0cc9\u0cce-\u0cd4\u0cd7-\u0cdd\u0cdf\u0ce2-\u0ce5\u0cf0-\u0d01\u0d04\u0d0d\u0d11\u0d29\u0d3a-\u0d3d\u0d44-\u0d45\u0d49\u0d4e-\u0d56\u0d58-\u0d5f\u0d62-\u0d65\u0d70-\u0e00\u0e2f\u0e3b-\u0e3f\u0e4f\u0e5a-\u0e80\u0e83\u0e85-\u0e86\u0e89\u0e8b-\u0e8c\u0e8e-\u0e93\u0e98\u0ea0\u0ea4\u0ea6\u0ea8-\u0ea9\u0eac\u0eaf\u0eba\u0ebe-\u0ebf\u0ec5\u0ec7\u0ece-\u0ecf\u0eda-\u0f17\u0f1a-\u0f1f\u0f2a-\u0f34\u0f36\u0f38\u0f3a-\u0f3d\u0f48\u0f6a-\u0f70\u0f85\u0f8c-\u0f8f\u0f96\u0f98\u0fae-\u0fb0\u0fb8\u0fba-\u109f\u10c6-\u10cf\u10f7-\u10ff\u1101\u1104\u1108\u110a\u110d\u1113-\u113b\u113d\u113f\u1141-\u114b\u114d\u114f\u1151-\u1153\u1156-\u1158\u115a-\u115e\u1162\u1164\u1166\u1168\u116a-\u116c\u116f-\u1171\u1174\u1176-\u119d\u119f-\u11a7\u11a9-\u11aa\u11ac-\u11ad\u11b0-\u11b6\u11b9\u11bb\u11c3-\u11ea\u11ec-\u11ef\u11f1-\u11f8\u11fa-\u1dff\u1e9c-\u1e9f\u1efa-\u1eff\u1f16-\u1f17\u1f1e-\u1f1f\u1f46-\u1f47\u1f4e-\u1f4f\u1f58\u1f5a\u1f5c\u1f5e\u1f7e-\u1f7f\u1fb5\u1fbd\u1fbf-\u1fc1\u1fc5\u1fcd-\u1fcf\u1fd4-\u1fd5\u1fdc-\u1fdf\u1fed-\u1ff1\u1ff5\u1ffd-\u20cf\u20dd-\u20e0\u20e2-\u2125\u2127-\u2129\u212c-\u212d\u212f-\u217f\u2183-\u3004\u3006\u3008-\u3020\u3030\u3036-\u3040\u3095-\u3098\u309b-\u309c\u309f-\u30a0\u30fb\u30ff-\u3104\u312d-\u4dff\u9fa6-\uabff\ud7a4-\uffff]') # noqa - -nonXmlNameFirstBMPRegexp = re.compile('[\x00-@\\[-\\^`\\{-\xbf\xd7\xf7\u0132-\u0133\u013f-\u0140\u0149\u017f\u01c4-\u01cc\u01f1-\u01f3\u01f6-\u01f9\u0218-\u024f\u02a9-\u02ba\u02c2-\u0385\u0387\u038b\u038d\u03a2\u03cf\u03d7-\u03d9\u03db\u03dd\u03df\u03e1\u03f4-\u0400\u040d\u0450\u045d\u0482-\u048f\u04c5-\u04c6\u04c9-\u04ca\u04cd-\u04cf\u04ec-\u04ed\u04f6-\u04f7\u04fa-\u0530\u0557-\u0558\u055a-\u0560\u0587-\u05cf\u05eb-\u05ef\u05f3-\u0620\u063b-\u0640\u064b-\u0670\u06b8-\u06b9\u06bf\u06cf\u06d4\u06d6-\u06e4\u06e7-\u0904\u093a-\u093c\u093e-\u0957\u0962-\u0984\u098d-\u098e\u0991-\u0992\u09a9\u09b1\u09b3-\u09b5\u09ba-\u09db\u09de\u09e2-\u09ef\u09f2-\u0a04\u0a0b-\u0a0e\u0a11-\u0a12\u0a29\u0a31\u0a34\u0a37\u0a3a-\u0a58\u0a5d\u0a5f-\u0a71\u0a75-\u0a84\u0a8c\u0a8e\u0a92\u0aa9\u0ab1\u0ab4\u0aba-\u0abc\u0abe-\u0adf\u0ae1-\u0b04\u0b0d-\u0b0e\u0b11-\u0b12\u0b29\u0b31\u0b34-\u0b35\u0b3a-\u0b3c\u0b3e-\u0b5b\u0b5e\u0b62-\u0b84\u0b8b-\u0b8d\u0b91\u0b96-\u0b98\u0b9b\u0b9d\u0ba0-\u0ba2\u0ba5-\u0ba7\u0bab-\u0bad\u0bb6\u0bba-\u0c04\u0c0d\u0c11\u0c29\u0c34\u0c3a-\u0c5f\u0c62-\u0c84\u0c8d\u0c91\u0ca9\u0cb4\u0cba-\u0cdd\u0cdf\u0ce2-\u0d04\u0d0d\u0d11\u0d29\u0d3a-\u0d5f\u0d62-\u0e00\u0e2f\u0e31\u0e34-\u0e3f\u0e46-\u0e80\u0e83\u0e85-\u0e86\u0e89\u0e8b-\u0e8c\u0e8e-\u0e93\u0e98\u0ea0\u0ea4\u0ea6\u0ea8-\u0ea9\u0eac\u0eaf\u0eb1\u0eb4-\u0ebc\u0ebe-\u0ebf\u0ec5-\u0f3f\u0f48\u0f6a-\u109f\u10c6-\u10cf\u10f7-\u10ff\u1101\u1104\u1108\u110a\u110d\u1113-\u113b\u113d\u113f\u1141-\u114b\u114d\u114f\u1151-\u1153\u1156-\u1158\u115a-\u115e\u1162\u1164\u1166\u1168\u116a-\u116c\u116f-\u1171\u1174\u1176-\u119d\u119f-\u11a7\u11a9-\u11aa\u11ac-\u11ad\u11b0-\u11b6\u11b9\u11bb\u11c3-\u11ea\u11ec-\u11ef\u11f1-\u11f8\u11fa-\u1dff\u1e9c-\u1e9f\u1efa-\u1eff\u1f16-\u1f17\u1f1e-\u1f1f\u1f46-\u1f47\u1f4e-\u1f4f\u1f58\u1f5a\u1f5c\u1f5e\u1f7e-\u1f7f\u1fb5\u1fbd\u1fbf-\u1fc1\u1fc5\u1fcd-\u1fcf\u1fd4-\u1fd5\u1fdc-\u1fdf\u1fed-\u1ff1\u1ff5\u1ffd-\u2125\u2127-\u2129\u212c-\u212d\u212f-\u217f\u2183-\u3006\u3008-\u3020\u302a-\u3040\u3095-\u30a0\u30fb-\u3104\u312d-\u4dff\u9fa6-\uabff\ud7a4-\uffff]') # noqa - -# Simpler things -nonPubidCharRegexp = re.compile("[^\x20\x0D\x0Aa-zA-Z0-9\\-'()+,./:=?;!*#@$_%]") - - -class InfosetFilter(object): - replacementRegexp = re.compile(r"U[\dA-F]{5,5}") - - def __init__(self, - dropXmlnsLocalName=False, - dropXmlnsAttrNs=False, - preventDoubleDashComments=False, - preventDashAtCommentEnd=False, - replaceFormFeedCharacters=True, - preventSingleQuotePubid=False): - - self.dropXmlnsLocalName = dropXmlnsLocalName - self.dropXmlnsAttrNs = dropXmlnsAttrNs - - self.preventDoubleDashComments = preventDoubleDashComments - self.preventDashAtCommentEnd = preventDashAtCommentEnd - - self.replaceFormFeedCharacters = replaceFormFeedCharacters - - self.preventSingleQuotePubid = preventSingleQuotePubid - - self.replaceCache = {} - - def coerceAttribute(self, name, namespace=None): - if self.dropXmlnsLocalName and name.startswith("xmlns:"): - warnings.warn("Attributes cannot begin with xmlns", DataLossWarning) - return None - elif (self.dropXmlnsAttrNs and - namespace == "http://www.w3.org/2000/xmlns/"): - warnings.warn("Attributes cannot be in the xml namespace", DataLossWarning) - return None - else: - return self.toXmlName(name) - - def coerceElement(self, name): - return self.toXmlName(name) - - def coerceComment(self, data): - if self.preventDoubleDashComments: - while "--" in data: - warnings.warn("Comments cannot contain adjacent dashes", DataLossWarning) - data = data.replace("--", "- -") - if data.endswith("-"): - warnings.warn("Comments cannot end in a dash", DataLossWarning) - data += " " - return data - - def coerceCharacters(self, data): - if self.replaceFormFeedCharacters: - for _ in range(data.count("\x0C")): - warnings.warn("Text cannot contain U+000C", DataLossWarning) - data = data.replace("\x0C", " ") - # Other non-xml characters - return data - - def coercePubid(self, data): - dataOutput = data - for char in nonPubidCharRegexp.findall(data): - warnings.warn("Coercing non-XML pubid", DataLossWarning) - replacement = self.getReplacementCharacter(char) - dataOutput = dataOutput.replace(char, replacement) - if self.preventSingleQuotePubid and dataOutput.find("'") >= 0: - warnings.warn("Pubid cannot contain single quote", DataLossWarning) - dataOutput = dataOutput.replace("'", self.getReplacementCharacter("'")) - return dataOutput - - def toXmlName(self, name): - nameFirst = name[0] - nameRest = name[1:] - m = nonXmlNameFirstBMPRegexp.match(nameFirst) - if m: - warnings.warn("Coercing non-XML name: %s" % name, DataLossWarning) - nameFirstOutput = self.getReplacementCharacter(nameFirst) - else: - nameFirstOutput = nameFirst - - nameRestOutput = nameRest - replaceChars = set(nonXmlNameBMPRegexp.findall(nameRest)) - for char in replaceChars: - warnings.warn("Coercing non-XML name: %s" % name, DataLossWarning) - replacement = self.getReplacementCharacter(char) - nameRestOutput = nameRestOutput.replace(char, replacement) - return nameFirstOutput + nameRestOutput - - def getReplacementCharacter(self, char): - if char in self.replaceCache: - replacement = self.replaceCache[char] - else: - replacement = self.escapeChar(char) - return replacement - - def fromXmlName(self, name): - for item in set(self.replacementRegexp.findall(name)): - name = name.replace(item, self.unescapeChar(item)) - return name - - def escapeChar(self, char): - replacement = "U%05X" % ord(char) - self.replaceCache[char] = replacement - return replacement - - def unescapeChar(self, charcode): - return chr(int(charcode[1:], 16)) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_inputstream.py b/env/Lib/site-packages/pip/_vendor/html5lib/_inputstream.py deleted file mode 100644 index e0bb3760..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/_inputstream.py +++ /dev/null @@ -1,918 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from pip._vendor.six import text_type -from pip._vendor.six.moves import http_client, urllib - -import codecs -import re -from io import BytesIO, StringIO - -from pip._vendor import webencodings - -from .constants import EOF, spaceCharacters, asciiLetters, asciiUppercase -from .constants import _ReparseException -from . import _utils - -# Non-unicode versions of constants for use in the pre-parser -spaceCharactersBytes = frozenset([item.encode("ascii") for item in spaceCharacters]) -asciiLettersBytes = frozenset([item.encode("ascii") for item in asciiLetters]) -asciiUppercaseBytes = frozenset([item.encode("ascii") for item in asciiUppercase]) -spacesAngleBrackets = spaceCharactersBytes | frozenset([b">", b"<"]) - - -invalid_unicode_no_surrogate = "[\u0001-\u0008\u000B\u000E-\u001F\u007F-\u009F\uFDD0-\uFDEF\uFFFE\uFFFF\U0001FFFE\U0001FFFF\U0002FFFE\U0002FFFF\U0003FFFE\U0003FFFF\U0004FFFE\U0004FFFF\U0005FFFE\U0005FFFF\U0006FFFE\U0006FFFF\U0007FFFE\U0007FFFF\U0008FFFE\U0008FFFF\U0009FFFE\U0009FFFF\U000AFFFE\U000AFFFF\U000BFFFE\U000BFFFF\U000CFFFE\U000CFFFF\U000DFFFE\U000DFFFF\U000EFFFE\U000EFFFF\U000FFFFE\U000FFFFF\U0010FFFE\U0010FFFF]" # noqa - -if _utils.supports_lone_surrogates: - # Use one extra step of indirection and create surrogates with - # eval. Not using this indirection would introduce an illegal - # unicode literal on platforms not supporting such lone - # surrogates. - assert invalid_unicode_no_surrogate[-1] == "]" and invalid_unicode_no_surrogate.count("]") == 1 - invalid_unicode_re = re.compile(invalid_unicode_no_surrogate[:-1] + - eval('"\\uD800-\\uDFFF"') + # pylint:disable=eval-used - "]") -else: - invalid_unicode_re = re.compile(invalid_unicode_no_surrogate) - -non_bmp_invalid_codepoints = {0x1FFFE, 0x1FFFF, 0x2FFFE, 0x2FFFF, 0x3FFFE, - 0x3FFFF, 0x4FFFE, 0x4FFFF, 0x5FFFE, 0x5FFFF, - 0x6FFFE, 0x6FFFF, 0x7FFFE, 0x7FFFF, 0x8FFFE, - 0x8FFFF, 0x9FFFE, 0x9FFFF, 0xAFFFE, 0xAFFFF, - 0xBFFFE, 0xBFFFF, 0xCFFFE, 0xCFFFF, 0xDFFFE, - 0xDFFFF, 0xEFFFE, 0xEFFFF, 0xFFFFE, 0xFFFFF, - 0x10FFFE, 0x10FFFF} - -ascii_punctuation_re = re.compile("[\u0009-\u000D\u0020-\u002F\u003A-\u0040\u005C\u005B-\u0060\u007B-\u007E]") - -# Cache for charsUntil() -charsUntilRegEx = {} - - -class BufferedStream(object): - """Buffering for streams that do not have buffering of their own - - The buffer is implemented as a list of chunks on the assumption that - joining many strings will be slow since it is O(n**2) - """ - - def __init__(self, stream): - self.stream = stream - self.buffer = [] - self.position = [-1, 0] # chunk number, offset - - def tell(self): - pos = 0 - for chunk in self.buffer[:self.position[0]]: - pos += len(chunk) - pos += self.position[1] - return pos - - def seek(self, pos): - assert pos <= self._bufferedBytes() - offset = pos - i = 0 - while len(self.buffer[i]) < offset: - offset -= len(self.buffer[i]) - i += 1 - self.position = [i, offset] - - def read(self, bytes): - if not self.buffer: - return self._readStream(bytes) - elif (self.position[0] == len(self.buffer) and - self.position[1] == len(self.buffer[-1])): - return self._readStream(bytes) - else: - return self._readFromBuffer(bytes) - - def _bufferedBytes(self): - return sum([len(item) for item in self.buffer]) - - def _readStream(self, bytes): - data = self.stream.read(bytes) - self.buffer.append(data) - self.position[0] += 1 - self.position[1] = len(data) - return data - - def _readFromBuffer(self, bytes): - remainingBytes = bytes - rv = [] - bufferIndex = self.position[0] - bufferOffset = self.position[1] - while bufferIndex < len(self.buffer) and remainingBytes != 0: - assert remainingBytes > 0 - bufferedData = self.buffer[bufferIndex] - - if remainingBytes <= len(bufferedData) - bufferOffset: - bytesToRead = remainingBytes - self.position = [bufferIndex, bufferOffset + bytesToRead] - else: - bytesToRead = len(bufferedData) - bufferOffset - self.position = [bufferIndex, len(bufferedData)] - bufferIndex += 1 - rv.append(bufferedData[bufferOffset:bufferOffset + bytesToRead]) - remainingBytes -= bytesToRead - - bufferOffset = 0 - - if remainingBytes: - rv.append(self._readStream(remainingBytes)) - - return b"".join(rv) - - -def HTMLInputStream(source, **kwargs): - # Work around Python bug #20007: read(0) closes the connection. - # http://bugs.python.org/issue20007 - if (isinstance(source, http_client.HTTPResponse) or - # Also check for addinfourl wrapping HTTPResponse - (isinstance(source, urllib.response.addbase) and - isinstance(source.fp, http_client.HTTPResponse))): - isUnicode = False - elif hasattr(source, "read"): - isUnicode = isinstance(source.read(0), text_type) - else: - isUnicode = isinstance(source, text_type) - - if isUnicode: - encodings = [x for x in kwargs if x.endswith("_encoding")] - if encodings: - raise TypeError("Cannot set an encoding with a unicode input, set %r" % encodings) - - return HTMLUnicodeInputStream(source, **kwargs) - else: - return HTMLBinaryInputStream(source, **kwargs) - - -class HTMLUnicodeInputStream(object): - """Provides a unicode stream of characters to the HTMLTokenizer. - - This class takes care of character encoding and removing or replacing - incorrect byte-sequences and also provides column and line tracking. - - """ - - _defaultChunkSize = 10240 - - def __init__(self, source): - """Initialises the HTMLInputStream. - - HTMLInputStream(source, [encoding]) -> Normalized stream from source - for use by html5lib. - - source can be either a file-object, local filename or a string. - - The optional encoding parameter must be a string that indicates - the encoding. If specified, that encoding will be used, - regardless of any BOM or later declaration (such as in a meta - element) - - """ - - if not _utils.supports_lone_surrogates: - # Such platforms will have already checked for such - # surrogate errors, so no need to do this checking. - self.reportCharacterErrors = None - elif len("\U0010FFFF") == 1: - self.reportCharacterErrors = self.characterErrorsUCS4 - else: - self.reportCharacterErrors = self.characterErrorsUCS2 - - # List of where new lines occur - self.newLines = [0] - - self.charEncoding = (lookupEncoding("utf-8"), "certain") - self.dataStream = self.openStream(source) - - self.reset() - - def reset(self): - self.chunk = "" - self.chunkSize = 0 - self.chunkOffset = 0 - self.errors = [] - - # number of (complete) lines in previous chunks - self.prevNumLines = 0 - # number of columns in the last line of the previous chunk - self.prevNumCols = 0 - - # Deal with CR LF and surrogates split over chunk boundaries - self._bufferedCharacter = None - - def openStream(self, source): - """Produces a file object from source. - - source can be either a file object, local filename or a string. - - """ - # Already a file object - if hasattr(source, 'read'): - stream = source - else: - stream = StringIO(source) - - return stream - - def _position(self, offset): - chunk = self.chunk - nLines = chunk.count('\n', 0, offset) - positionLine = self.prevNumLines + nLines - lastLinePos = chunk.rfind('\n', 0, offset) - if lastLinePos == -1: - positionColumn = self.prevNumCols + offset - else: - positionColumn = offset - (lastLinePos + 1) - return (positionLine, positionColumn) - - def position(self): - """Returns (line, col) of the current position in the stream.""" - line, col = self._position(self.chunkOffset) - return (line + 1, col) - - def char(self): - """ Read one character from the stream or queue if available. Return - EOF when EOF is reached. - """ - # Read a new chunk from the input stream if necessary - if self.chunkOffset >= self.chunkSize: - if not self.readChunk(): - return EOF - - chunkOffset = self.chunkOffset - char = self.chunk[chunkOffset] - self.chunkOffset = chunkOffset + 1 - - return char - - def readChunk(self, chunkSize=None): - if chunkSize is None: - chunkSize = self._defaultChunkSize - - self.prevNumLines, self.prevNumCols = self._position(self.chunkSize) - - self.chunk = "" - self.chunkSize = 0 - self.chunkOffset = 0 - - data = self.dataStream.read(chunkSize) - - # Deal with CR LF and surrogates broken across chunks - if self._bufferedCharacter: - data = self._bufferedCharacter + data - self._bufferedCharacter = None - elif not data: - # We have no more data, bye-bye stream - return False - - if len(data) > 1: - lastv = ord(data[-1]) - if lastv == 0x0D or 0xD800 <= lastv <= 0xDBFF: - self._bufferedCharacter = data[-1] - data = data[:-1] - - if self.reportCharacterErrors: - self.reportCharacterErrors(data) - - # Replace invalid characters - data = data.replace("\r\n", "\n") - data = data.replace("\r", "\n") - - self.chunk = data - self.chunkSize = len(data) - - return True - - def characterErrorsUCS4(self, data): - for _ in range(len(invalid_unicode_re.findall(data))): - self.errors.append("invalid-codepoint") - - def characterErrorsUCS2(self, data): - # Someone picked the wrong compile option - # You lose - skip = False - for match in invalid_unicode_re.finditer(data): - if skip: - continue - codepoint = ord(match.group()) - pos = match.start() - # Pretty sure there should be endianness issues here - if _utils.isSurrogatePair(data[pos:pos + 2]): - # We have a surrogate pair! - char_val = _utils.surrogatePairToCodepoint(data[pos:pos + 2]) - if char_val in non_bmp_invalid_codepoints: - self.errors.append("invalid-codepoint") - skip = True - elif (codepoint >= 0xD800 and codepoint <= 0xDFFF and - pos == len(data) - 1): - self.errors.append("invalid-codepoint") - else: - skip = False - self.errors.append("invalid-codepoint") - - def charsUntil(self, characters, opposite=False): - """ Returns a string of characters from the stream up to but not - including any character in 'characters' or EOF. 'characters' must be - a container that supports the 'in' method and iteration over its - characters. - """ - - # Use a cache of regexps to find the required characters - try: - chars = charsUntilRegEx[(characters, opposite)] - except KeyError: - if __debug__: - for c in characters: - assert(ord(c) < 128) - regex = "".join(["\\x%02x" % ord(c) for c in characters]) - if not opposite: - regex = "^%s" % regex - chars = charsUntilRegEx[(characters, opposite)] = re.compile("[%s]+" % regex) - - rv = [] - - while True: - # Find the longest matching prefix - m = chars.match(self.chunk, self.chunkOffset) - if m is None: - # If nothing matched, and it wasn't because we ran out of chunk, - # then stop - if self.chunkOffset != self.chunkSize: - break - else: - end = m.end() - # If not the whole chunk matched, return everything - # up to the part that didn't match - if end != self.chunkSize: - rv.append(self.chunk[self.chunkOffset:end]) - self.chunkOffset = end - break - # If the whole remainder of the chunk matched, - # use it all and read the next chunk - rv.append(self.chunk[self.chunkOffset:]) - if not self.readChunk(): - # Reached EOF - break - - r = "".join(rv) - return r - - def unget(self, char): - # Only one character is allowed to be ungotten at once - it must - # be consumed again before any further call to unget - if char is not EOF: - if self.chunkOffset == 0: - # unget is called quite rarely, so it's a good idea to do - # more work here if it saves a bit of work in the frequently - # called char and charsUntil. - # So, just prepend the ungotten character onto the current - # chunk: - self.chunk = char + self.chunk - self.chunkSize += 1 - else: - self.chunkOffset -= 1 - assert self.chunk[self.chunkOffset] == char - - -class HTMLBinaryInputStream(HTMLUnicodeInputStream): - """Provides a unicode stream of characters to the HTMLTokenizer. - - This class takes care of character encoding and removing or replacing - incorrect byte-sequences and also provides column and line tracking. - - """ - - def __init__(self, source, override_encoding=None, transport_encoding=None, - same_origin_parent_encoding=None, likely_encoding=None, - default_encoding="windows-1252", useChardet=True): - """Initialises the HTMLInputStream. - - HTMLInputStream(source, [encoding]) -> Normalized stream from source - for use by html5lib. - - source can be either a file-object, local filename or a string. - - The optional encoding parameter must be a string that indicates - the encoding. If specified, that encoding will be used, - regardless of any BOM or later declaration (such as in a meta - element) - - """ - # Raw Stream - for unicode objects this will encode to utf-8 and set - # self.charEncoding as appropriate - self.rawStream = self.openStream(source) - - HTMLUnicodeInputStream.__init__(self, self.rawStream) - - # Encoding Information - # Number of bytes to use when looking for a meta element with - # encoding information - self.numBytesMeta = 1024 - # Number of bytes to use when using detecting encoding using chardet - self.numBytesChardet = 100 - # Things from args - self.override_encoding = override_encoding - self.transport_encoding = transport_encoding - self.same_origin_parent_encoding = same_origin_parent_encoding - self.likely_encoding = likely_encoding - self.default_encoding = default_encoding - - # Determine encoding - self.charEncoding = self.determineEncoding(useChardet) - assert self.charEncoding[0] is not None - - # Call superclass - self.reset() - - def reset(self): - self.dataStream = self.charEncoding[0].codec_info.streamreader(self.rawStream, 'replace') - HTMLUnicodeInputStream.reset(self) - - def openStream(self, source): - """Produces a file object from source. - - source can be either a file object, local filename or a string. - - """ - # Already a file object - if hasattr(source, 'read'): - stream = source - else: - stream = BytesIO(source) - - try: - stream.seek(stream.tell()) - except Exception: - stream = BufferedStream(stream) - - return stream - - def determineEncoding(self, chardet=True): - # BOMs take precedence over everything - # This will also read past the BOM if present - charEncoding = self.detectBOM(), "certain" - if charEncoding[0] is not None: - return charEncoding - - # If we've been overridden, we've been overridden - charEncoding = lookupEncoding(self.override_encoding), "certain" - if charEncoding[0] is not None: - return charEncoding - - # Now check the transport layer - charEncoding = lookupEncoding(self.transport_encoding), "certain" - if charEncoding[0] is not None: - return charEncoding - - # Look for meta elements with encoding information - charEncoding = self.detectEncodingMeta(), "tentative" - if charEncoding[0] is not None: - return charEncoding - - # Parent document encoding - charEncoding = lookupEncoding(self.same_origin_parent_encoding), "tentative" - if charEncoding[0] is not None and not charEncoding[0].name.startswith("utf-16"): - return charEncoding - - # "likely" encoding - charEncoding = lookupEncoding(self.likely_encoding), "tentative" - if charEncoding[0] is not None: - return charEncoding - - # Guess with chardet, if available - if chardet: - try: - from pip._vendor.chardet.universaldetector import UniversalDetector - except ImportError: - pass - else: - buffers = [] - detector = UniversalDetector() - while not detector.done: - buffer = self.rawStream.read(self.numBytesChardet) - assert isinstance(buffer, bytes) - if not buffer: - break - buffers.append(buffer) - detector.feed(buffer) - detector.close() - encoding = lookupEncoding(detector.result['encoding']) - self.rawStream.seek(0) - if encoding is not None: - return encoding, "tentative" - - # Try the default encoding - charEncoding = lookupEncoding(self.default_encoding), "tentative" - if charEncoding[0] is not None: - return charEncoding - - # Fallback to html5lib's default if even that hasn't worked - return lookupEncoding("windows-1252"), "tentative" - - def changeEncoding(self, newEncoding): - assert self.charEncoding[1] != "certain" - newEncoding = lookupEncoding(newEncoding) - if newEncoding is None: - return - if newEncoding.name in ("utf-16be", "utf-16le"): - newEncoding = lookupEncoding("utf-8") - assert newEncoding is not None - elif newEncoding == self.charEncoding[0]: - self.charEncoding = (self.charEncoding[0], "certain") - else: - self.rawStream.seek(0) - self.charEncoding = (newEncoding, "certain") - self.reset() - raise _ReparseException("Encoding changed from %s to %s" % (self.charEncoding[0], newEncoding)) - - def detectBOM(self): - """Attempts to detect at BOM at the start of the stream. If - an encoding can be determined from the BOM return the name of the - encoding otherwise return None""" - bomDict = { - codecs.BOM_UTF8: 'utf-8', - codecs.BOM_UTF16_LE: 'utf-16le', codecs.BOM_UTF16_BE: 'utf-16be', - codecs.BOM_UTF32_LE: 'utf-32le', codecs.BOM_UTF32_BE: 'utf-32be' - } - - # Go to beginning of file and read in 4 bytes - string = self.rawStream.read(4) - assert isinstance(string, bytes) - - # Try detecting the BOM using bytes from the string - encoding = bomDict.get(string[:3]) # UTF-8 - seek = 3 - if not encoding: - # Need to detect UTF-32 before UTF-16 - encoding = bomDict.get(string) # UTF-32 - seek = 4 - if not encoding: - encoding = bomDict.get(string[:2]) # UTF-16 - seek = 2 - - # Set the read position past the BOM if one was found, otherwise - # set it to the start of the stream - if encoding: - self.rawStream.seek(seek) - return lookupEncoding(encoding) - else: - self.rawStream.seek(0) - return None - - def detectEncodingMeta(self): - """Report the encoding declared by the meta element - """ - buffer = self.rawStream.read(self.numBytesMeta) - assert isinstance(buffer, bytes) - parser = EncodingParser(buffer) - self.rawStream.seek(0) - encoding = parser.getEncoding() - - if encoding is not None and encoding.name in ("utf-16be", "utf-16le"): - encoding = lookupEncoding("utf-8") - - return encoding - - -class EncodingBytes(bytes): - """String-like object with an associated position and various extra methods - If the position is ever greater than the string length then an exception is - raised""" - def __new__(self, value): - assert isinstance(value, bytes) - return bytes.__new__(self, value.lower()) - - def __init__(self, value): - # pylint:disable=unused-argument - self._position = -1 - - def __iter__(self): - return self - - def __next__(self): - p = self._position = self._position + 1 - if p >= len(self): - raise StopIteration - elif p < 0: - raise TypeError - return self[p:p + 1] - - def next(self): - # Py2 compat - return self.__next__() - - def previous(self): - p = self._position - if p >= len(self): - raise StopIteration - elif p < 0: - raise TypeError - self._position = p = p - 1 - return self[p:p + 1] - - def setPosition(self, position): - if self._position >= len(self): - raise StopIteration - self._position = position - - def getPosition(self): - if self._position >= len(self): - raise StopIteration - if self._position >= 0: - return self._position - else: - return None - - position = property(getPosition, setPosition) - - def getCurrentByte(self): - return self[self.position:self.position + 1] - - currentByte = property(getCurrentByte) - - def skip(self, chars=spaceCharactersBytes): - """Skip past a list of characters""" - p = self.position # use property for the error-checking - while p < len(self): - c = self[p:p + 1] - if c not in chars: - self._position = p - return c - p += 1 - self._position = p - return None - - def skipUntil(self, chars): - p = self.position - while p < len(self): - c = self[p:p + 1] - if c in chars: - self._position = p - return c - p += 1 - self._position = p - return None - - def matchBytes(self, bytes): - """Look for a sequence of bytes at the start of a string. If the bytes - are found return True and advance the position to the byte after the - match. Otherwise return False and leave the position alone""" - rv = self.startswith(bytes, self.position) - if rv: - self.position += len(bytes) - return rv - - def jumpTo(self, bytes): - """Look for the next sequence of bytes matching a given sequence. If - a match is found advance the position to the last byte of the match""" - try: - self._position = self.index(bytes, self.position) + len(bytes) - 1 - except ValueError: - raise StopIteration - return True - - -class EncodingParser(object): - """Mini parser for detecting character encoding from meta elements""" - - def __init__(self, data): - """string - the data to work on for encoding detection""" - self.data = EncodingBytes(data) - self.encoding = None - - def getEncoding(self): - if b"<meta" not in self.data: - return None - - methodDispatch = ( - (b"<!--", self.handleComment), - (b"<meta", self.handleMeta), - (b"</", self.handlePossibleEndTag), - (b"<!", self.handleOther), - (b"<?", self.handleOther), - (b"<", self.handlePossibleStartTag)) - for _ in self.data: - keepParsing = True - try: - self.data.jumpTo(b"<") - except StopIteration: - break - for key, method in methodDispatch: - if self.data.matchBytes(key): - try: - keepParsing = method() - break - except StopIteration: - keepParsing = False - break - if not keepParsing: - break - - return self.encoding - - def handleComment(self): - """Skip over comments""" - return self.data.jumpTo(b"-->") - - def handleMeta(self): - if self.data.currentByte not in spaceCharactersBytes: - # if we have <meta not followed by a space so just keep going - return True - # We have a valid meta element we want to search for attributes - hasPragma = False - pendingEncoding = None - while True: - # Try to find the next attribute after the current position - attr = self.getAttribute() - if attr is None: - return True - else: - if attr[0] == b"http-equiv": - hasPragma = attr[1] == b"content-type" - if hasPragma and pendingEncoding is not None: - self.encoding = pendingEncoding - return False - elif attr[0] == b"charset": - tentativeEncoding = attr[1] - codec = lookupEncoding(tentativeEncoding) - if codec is not None: - self.encoding = codec - return False - elif attr[0] == b"content": - contentParser = ContentAttrParser(EncodingBytes(attr[1])) - tentativeEncoding = contentParser.parse() - if tentativeEncoding is not None: - codec = lookupEncoding(tentativeEncoding) - if codec is not None: - if hasPragma: - self.encoding = codec - return False - else: - pendingEncoding = codec - - def handlePossibleStartTag(self): - return self.handlePossibleTag(False) - - def handlePossibleEndTag(self): - next(self.data) - return self.handlePossibleTag(True) - - def handlePossibleTag(self, endTag): - data = self.data - if data.currentByte not in asciiLettersBytes: - # If the next byte is not an ascii letter either ignore this - # fragment (possible start tag case) or treat it according to - # handleOther - if endTag: - data.previous() - self.handleOther() - return True - - c = data.skipUntil(spacesAngleBrackets) - if c == b"<": - # return to the first step in the overall "two step" algorithm - # reprocessing the < byte - data.previous() - else: - # Read all attributes - attr = self.getAttribute() - while attr is not None: - attr = self.getAttribute() - return True - - def handleOther(self): - return self.data.jumpTo(b">") - - def getAttribute(self): - """Return a name,value pair for the next attribute in the stream, - if one is found, or None""" - data = self.data - # Step 1 (skip chars) - c = data.skip(spaceCharactersBytes | frozenset([b"/"])) - assert c is None or len(c) == 1 - # Step 2 - if c in (b">", None): - return None - # Step 3 - attrName = [] - attrValue = [] - # Step 4 attribute name - while True: - if c == b"=" and attrName: - break - elif c in spaceCharactersBytes: - # Step 6! - c = data.skip() - break - elif c in (b"/", b">"): - return b"".join(attrName), b"" - elif c in asciiUppercaseBytes: - attrName.append(c.lower()) - elif c is None: - return None - else: - attrName.append(c) - # Step 5 - c = next(data) - # Step 7 - if c != b"=": - data.previous() - return b"".join(attrName), b"" - # Step 8 - next(data) - # Step 9 - c = data.skip() - # Step 10 - if c in (b"'", b'"'): - # 10.1 - quoteChar = c - while True: - # 10.2 - c = next(data) - # 10.3 - if c == quoteChar: - next(data) - return b"".join(attrName), b"".join(attrValue) - # 10.4 - elif c in asciiUppercaseBytes: - attrValue.append(c.lower()) - # 10.5 - else: - attrValue.append(c) - elif c == b">": - return b"".join(attrName), b"" - elif c in asciiUppercaseBytes: - attrValue.append(c.lower()) - elif c is None: - return None - else: - attrValue.append(c) - # Step 11 - while True: - c = next(data) - if c in spacesAngleBrackets: - return b"".join(attrName), b"".join(attrValue) - elif c in asciiUppercaseBytes: - attrValue.append(c.lower()) - elif c is None: - return None - else: - attrValue.append(c) - - -class ContentAttrParser(object): - def __init__(self, data): - assert isinstance(data, bytes) - self.data = data - - def parse(self): - try: - # Check if the attr name is charset - # otherwise return - self.data.jumpTo(b"charset") - self.data.position += 1 - self.data.skip() - if not self.data.currentByte == b"=": - # If there is no = sign keep looking for attrs - return None - self.data.position += 1 - self.data.skip() - # Look for an encoding between matching quote marks - if self.data.currentByte in (b'"', b"'"): - quoteMark = self.data.currentByte - self.data.position += 1 - oldPosition = self.data.position - if self.data.jumpTo(quoteMark): - return self.data[oldPosition:self.data.position] - else: - return None - else: - # Unquoted value - oldPosition = self.data.position - try: - self.data.skipUntil(spaceCharactersBytes) - return self.data[oldPosition:self.data.position] - except StopIteration: - # Return the whole remaining value - return self.data[oldPosition:] - except StopIteration: - return None - - -def lookupEncoding(encoding): - """Return the python codec name corresponding to an encoding or None if the - string doesn't correspond to a valid encoding.""" - if isinstance(encoding, bytes): - try: - encoding = encoding.decode("ascii") - except UnicodeDecodeError: - return None - - if encoding is not None: - try: - return webencodings.lookup(encoding) - except AttributeError: - return None - else: - return None diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_tokenizer.py b/env/Lib/site-packages/pip/_vendor/html5lib/_tokenizer.py deleted file mode 100644 index 5f00253e..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/_tokenizer.py +++ /dev/null @@ -1,1735 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from pip._vendor.six import unichr as chr - -from collections import deque, OrderedDict -from sys import version_info - -from .constants import spaceCharacters -from .constants import entities -from .constants import asciiLetters, asciiUpper2Lower -from .constants import digits, hexDigits, EOF -from .constants import tokenTypes, tagTokenTypes -from .constants import replacementCharacters - -from ._inputstream import HTMLInputStream - -from ._trie import Trie - -entitiesTrie = Trie(entities) - -if version_info >= (3, 7): - attributeMap = dict -else: - attributeMap = OrderedDict - - -class HTMLTokenizer(object): - """ This class takes care of tokenizing HTML. - - * self.currentToken - Holds the token that is currently being processed. - - * self.state - Holds a reference to the method to be invoked... XXX - - * self.stream - Points to HTMLInputStream object. - """ - - def __init__(self, stream, parser=None, **kwargs): - - self.stream = HTMLInputStream(stream, **kwargs) - self.parser = parser - - # Setup the initial tokenizer state - self.escapeFlag = False - self.lastFourChars = [] - self.state = self.dataState - self.escape = False - - # The current token being created - self.currentToken = None - super(HTMLTokenizer, self).__init__() - - def __iter__(self): - """ This is where the magic happens. - - We do our usually processing through the states and when we have a token - to return we yield the token which pauses processing until the next token - is requested. - """ - self.tokenQueue = deque([]) - # Start processing. When EOF is reached self.state will return False - # instead of True and the loop will terminate. - while self.state(): - while self.stream.errors: - yield {"type": tokenTypes["ParseError"], "data": self.stream.errors.pop(0)} - while self.tokenQueue: - yield self.tokenQueue.popleft() - - def consumeNumberEntity(self, isHex): - """This function returns either U+FFFD or the character based on the - decimal or hexadecimal representation. It also discards ";" if present. - If not present self.tokenQueue.append({"type": tokenTypes["ParseError"]}) is invoked. - """ - - allowed = digits - radix = 10 - if isHex: - allowed = hexDigits - radix = 16 - - charStack = [] - - # Consume all the characters that are in range while making sure we - # don't hit an EOF. - c = self.stream.char() - while c in allowed and c is not EOF: - charStack.append(c) - c = self.stream.char() - - # Convert the set of characters consumed to an int. - charAsInt = int("".join(charStack), radix) - - # Certain characters get replaced with others - if charAsInt in replacementCharacters: - char = replacementCharacters[charAsInt] - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "illegal-codepoint-for-numeric-entity", - "datavars": {"charAsInt": charAsInt}}) - elif ((0xD800 <= charAsInt <= 0xDFFF) or - (charAsInt > 0x10FFFF)): - char = "\uFFFD" - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "illegal-codepoint-for-numeric-entity", - "datavars": {"charAsInt": charAsInt}}) - else: - # Should speed up this check somehow (e.g. move the set to a constant) - if ((0x0001 <= charAsInt <= 0x0008) or - (0x000E <= charAsInt <= 0x001F) or - (0x007F <= charAsInt <= 0x009F) or - (0xFDD0 <= charAsInt <= 0xFDEF) or - charAsInt in frozenset([0x000B, 0xFFFE, 0xFFFF, 0x1FFFE, - 0x1FFFF, 0x2FFFE, 0x2FFFF, 0x3FFFE, - 0x3FFFF, 0x4FFFE, 0x4FFFF, 0x5FFFE, - 0x5FFFF, 0x6FFFE, 0x6FFFF, 0x7FFFE, - 0x7FFFF, 0x8FFFE, 0x8FFFF, 0x9FFFE, - 0x9FFFF, 0xAFFFE, 0xAFFFF, 0xBFFFE, - 0xBFFFF, 0xCFFFE, 0xCFFFF, 0xDFFFE, - 0xDFFFF, 0xEFFFE, 0xEFFFF, 0xFFFFE, - 0xFFFFF, 0x10FFFE, 0x10FFFF])): - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": - "illegal-codepoint-for-numeric-entity", - "datavars": {"charAsInt": charAsInt}}) - try: - # Try/except needed as UCS-2 Python builds' unichar only works - # within the BMP. - char = chr(charAsInt) - except ValueError: - v = charAsInt - 0x10000 - char = chr(0xD800 | (v >> 10)) + chr(0xDC00 | (v & 0x3FF)) - - # Discard the ; if present. Otherwise, put it back on the queue and - # invoke parseError on parser. - if c != ";": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "numeric-entity-without-semicolon"}) - self.stream.unget(c) - - return char - - def consumeEntity(self, allowedChar=None, fromAttribute=False): - # Initialise to the default output for when no entity is matched - output = "&" - - charStack = [self.stream.char()] - if (charStack[0] in spaceCharacters or charStack[0] in (EOF, "<", "&") or - (allowedChar is not None and allowedChar == charStack[0])): - self.stream.unget(charStack[0]) - - elif charStack[0] == "#": - # Read the next character to see if it's hex or decimal - hex = False - charStack.append(self.stream.char()) - if charStack[-1] in ("x", "X"): - hex = True - charStack.append(self.stream.char()) - - # charStack[-1] should be the first digit - if (hex and charStack[-1] in hexDigits) \ - or (not hex and charStack[-1] in digits): - # At least one digit found, so consume the whole number - self.stream.unget(charStack[-1]) - output = self.consumeNumberEntity(hex) - else: - # No digits found - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "expected-numeric-entity"}) - self.stream.unget(charStack.pop()) - output = "&" + "".join(charStack) - - else: - # At this point in the process might have named entity. Entities - # are stored in the global variable "entities". - # - # Consume characters and compare to these to a substring of the - # entity names in the list until the substring no longer matches. - while (charStack[-1] is not EOF): - if not entitiesTrie.has_keys_with_prefix("".join(charStack)): - break - charStack.append(self.stream.char()) - - # At this point we have a string that starts with some characters - # that may match an entity - # Try to find the longest entity the string will match to take care - # of ¬i for instance. - try: - entityName = entitiesTrie.longest_prefix("".join(charStack[:-1])) - entityLength = len(entityName) - except KeyError: - entityName = None - - if entityName is not None: - if entityName[-1] != ";": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "named-entity-without-semicolon"}) - if (entityName[-1] != ";" and fromAttribute and - (charStack[entityLength] in asciiLetters or - charStack[entityLength] in digits or - charStack[entityLength] == "=")): - self.stream.unget(charStack.pop()) - output = "&" + "".join(charStack) - else: - output = entities[entityName] - self.stream.unget(charStack.pop()) - output += "".join(charStack[entityLength:]) - else: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-named-entity"}) - self.stream.unget(charStack.pop()) - output = "&" + "".join(charStack) - - if fromAttribute: - self.currentToken["data"][-1][1] += output - else: - if output in spaceCharacters: - tokenType = "SpaceCharacters" - else: - tokenType = "Characters" - self.tokenQueue.append({"type": tokenTypes[tokenType], "data": output}) - - def processEntityInAttribute(self, allowedChar): - """This method replaces the need for "entityInAttributeValueState". - """ - self.consumeEntity(allowedChar=allowedChar, fromAttribute=True) - - def emitCurrentToken(self): - """This method is a generic handler for emitting the tags. It also sets - the state to "data" because that's what's needed after a token has been - emitted. - """ - token = self.currentToken - # Add token to the queue to be yielded - if (token["type"] in tagTokenTypes): - token["name"] = token["name"].translate(asciiUpper2Lower) - if token["type"] == tokenTypes["StartTag"]: - raw = token["data"] - data = attributeMap(raw) - if len(raw) > len(data): - # we had some duplicated attribute, fix so first wins - data.update(raw[::-1]) - token["data"] = data - - if token["type"] == tokenTypes["EndTag"]: - if token["data"]: - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "attributes-in-end-tag"}) - if token["selfClosing"]: - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "self-closing-flag-on-end-tag"}) - self.tokenQueue.append(token) - self.state = self.dataState - - # Below are the various tokenizer states worked out. - def dataState(self): - data = self.stream.char() - if data == "&": - self.state = self.entityDataState - elif data == "<": - self.state = self.tagOpenState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\u0000"}) - elif data is EOF: - # Tokenization ends. - return False - elif data in spaceCharacters: - # Directly after emitting a token you switch back to the "data - # state". At that point spaceCharacters are important so they are - # emitted separately. - self.tokenQueue.append({"type": tokenTypes["SpaceCharacters"], "data": - data + self.stream.charsUntil(spaceCharacters, True)}) - # No need to update lastFourChars here, since the first space will - # have already been appended to lastFourChars and will have broken - # any <!-- or --> sequences - else: - chars = self.stream.charsUntil(("&", "<", "\u0000")) - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": - data + chars}) - return True - - def entityDataState(self): - self.consumeEntity() - self.state = self.dataState - return True - - def rcdataState(self): - data = self.stream.char() - if data == "&": - self.state = self.characterReferenceInRcdata - elif data == "<": - self.state = self.rcdataLessThanSignState - elif data == EOF: - # Tokenization ends. - return False - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - elif data in spaceCharacters: - # Directly after emitting a token you switch back to the "data - # state". At that point spaceCharacters are important so they are - # emitted separately. - self.tokenQueue.append({"type": tokenTypes["SpaceCharacters"], "data": - data + self.stream.charsUntil(spaceCharacters, True)}) - # No need to update lastFourChars here, since the first space will - # have already been appended to lastFourChars and will have broken - # any <!-- or --> sequences - else: - chars = self.stream.charsUntil(("&", "<", "\u0000")) - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": - data + chars}) - return True - - def characterReferenceInRcdata(self): - self.consumeEntity() - self.state = self.rcdataState - return True - - def rawtextState(self): - data = self.stream.char() - if data == "<": - self.state = self.rawtextLessThanSignState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - elif data == EOF: - # Tokenization ends. - return False - else: - chars = self.stream.charsUntil(("<", "\u0000")) - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": - data + chars}) - return True - - def scriptDataState(self): - data = self.stream.char() - if data == "<": - self.state = self.scriptDataLessThanSignState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - elif data == EOF: - # Tokenization ends. - return False - else: - chars = self.stream.charsUntil(("<", "\u0000")) - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": - data + chars}) - return True - - def plaintextState(self): - data = self.stream.char() - if data == EOF: - # Tokenization ends. - return False - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": - data + self.stream.charsUntil("\u0000")}) - return True - - def tagOpenState(self): - data = self.stream.char() - if data == "!": - self.state = self.markupDeclarationOpenState - elif data == "/": - self.state = self.closeTagOpenState - elif data in asciiLetters: - self.currentToken = {"type": tokenTypes["StartTag"], - "name": data, "data": [], - "selfClosing": False, - "selfClosingAcknowledged": False} - self.state = self.tagNameState - elif data == ">": - # XXX In theory it could be something besides a tag name. But - # do we really care? - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-tag-name-but-got-right-bracket"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<>"}) - self.state = self.dataState - elif data == "?": - # XXX In theory it could be something besides a tag name. But - # do we really care? - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-tag-name-but-got-question-mark"}) - self.stream.unget(data) - self.state = self.bogusCommentState - else: - # XXX - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-tag-name"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) - self.stream.unget(data) - self.state = self.dataState - return True - - def closeTagOpenState(self): - data = self.stream.char() - if data in asciiLetters: - self.currentToken = {"type": tokenTypes["EndTag"], "name": data, - "data": [], "selfClosing": False} - self.state = self.tagNameState - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-closing-tag-but-got-right-bracket"}) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-closing-tag-but-got-eof"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) - self.state = self.dataState - else: - # XXX data can be _'_... - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-closing-tag-but-got-char", - "datavars": {"data": data}}) - self.stream.unget(data) - self.state = self.bogusCommentState - return True - - def tagNameState(self): - data = self.stream.char() - if data in spaceCharacters: - self.state = self.beforeAttributeNameState - elif data == ">": - self.emitCurrentToken() - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-tag-name"}) - self.state = self.dataState - elif data == "/": - self.state = self.selfClosingStartTagState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["name"] += "\uFFFD" - else: - self.currentToken["name"] += data - # (Don't use charsUntil here, because tag names are - # very short and it's faster to not do anything fancy) - return True - - def rcdataLessThanSignState(self): - data = self.stream.char() - if data == "/": - self.temporaryBuffer = "" - self.state = self.rcdataEndTagOpenState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) - self.stream.unget(data) - self.state = self.rcdataState - return True - - def rcdataEndTagOpenState(self): - data = self.stream.char() - if data in asciiLetters: - self.temporaryBuffer += data - self.state = self.rcdataEndTagNameState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) - self.stream.unget(data) - self.state = self.rcdataState - return True - - def rcdataEndTagNameState(self): - appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower() - data = self.stream.char() - if data in spaceCharacters and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.state = self.beforeAttributeNameState - elif data == "/" and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.state = self.selfClosingStartTagState - elif data == ">" and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.emitCurrentToken() - self.state = self.dataState - elif data in asciiLetters: - self.temporaryBuffer += data - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "</" + self.temporaryBuffer}) - self.stream.unget(data) - self.state = self.rcdataState - return True - - def rawtextLessThanSignState(self): - data = self.stream.char() - if data == "/": - self.temporaryBuffer = "" - self.state = self.rawtextEndTagOpenState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) - self.stream.unget(data) - self.state = self.rawtextState - return True - - def rawtextEndTagOpenState(self): - data = self.stream.char() - if data in asciiLetters: - self.temporaryBuffer += data - self.state = self.rawtextEndTagNameState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) - self.stream.unget(data) - self.state = self.rawtextState - return True - - def rawtextEndTagNameState(self): - appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower() - data = self.stream.char() - if data in spaceCharacters and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.state = self.beforeAttributeNameState - elif data == "/" and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.state = self.selfClosingStartTagState - elif data == ">" and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.emitCurrentToken() - self.state = self.dataState - elif data in asciiLetters: - self.temporaryBuffer += data - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "</" + self.temporaryBuffer}) - self.stream.unget(data) - self.state = self.rawtextState - return True - - def scriptDataLessThanSignState(self): - data = self.stream.char() - if data == "/": - self.temporaryBuffer = "" - self.state = self.scriptDataEndTagOpenState - elif data == "!": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<!"}) - self.state = self.scriptDataEscapeStartState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) - self.stream.unget(data) - self.state = self.scriptDataState - return True - - def scriptDataEndTagOpenState(self): - data = self.stream.char() - if data in asciiLetters: - self.temporaryBuffer += data - self.state = self.scriptDataEndTagNameState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) - self.stream.unget(data) - self.state = self.scriptDataState - return True - - def scriptDataEndTagNameState(self): - appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower() - data = self.stream.char() - if data in spaceCharacters and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.state = self.beforeAttributeNameState - elif data == "/" and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.state = self.selfClosingStartTagState - elif data == ">" and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.emitCurrentToken() - self.state = self.dataState - elif data in asciiLetters: - self.temporaryBuffer += data - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "</" + self.temporaryBuffer}) - self.stream.unget(data) - self.state = self.scriptDataState - return True - - def scriptDataEscapeStartState(self): - data = self.stream.char() - if data == "-": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) - self.state = self.scriptDataEscapeStartDashState - else: - self.stream.unget(data) - self.state = self.scriptDataState - return True - - def scriptDataEscapeStartDashState(self): - data = self.stream.char() - if data == "-": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) - self.state = self.scriptDataEscapedDashDashState - else: - self.stream.unget(data) - self.state = self.scriptDataState - return True - - def scriptDataEscapedState(self): - data = self.stream.char() - if data == "-": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) - self.state = self.scriptDataEscapedDashState - elif data == "<": - self.state = self.scriptDataEscapedLessThanSignState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - elif data == EOF: - self.state = self.dataState - else: - chars = self.stream.charsUntil(("<", "-", "\u0000")) - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": - data + chars}) - return True - - def scriptDataEscapedDashState(self): - data = self.stream.char() - if data == "-": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) - self.state = self.scriptDataEscapedDashDashState - elif data == "<": - self.state = self.scriptDataEscapedLessThanSignState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - self.state = self.scriptDataEscapedState - elif data == EOF: - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) - self.state = self.scriptDataEscapedState - return True - - def scriptDataEscapedDashDashState(self): - data = self.stream.char() - if data == "-": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) - elif data == "<": - self.state = self.scriptDataEscapedLessThanSignState - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": ">"}) - self.state = self.scriptDataState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - self.state = self.scriptDataEscapedState - elif data == EOF: - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) - self.state = self.scriptDataEscapedState - return True - - def scriptDataEscapedLessThanSignState(self): - data = self.stream.char() - if data == "/": - self.temporaryBuffer = "" - self.state = self.scriptDataEscapedEndTagOpenState - elif data in asciiLetters: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<" + data}) - self.temporaryBuffer = data - self.state = self.scriptDataDoubleEscapeStartState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) - self.stream.unget(data) - self.state = self.scriptDataEscapedState - return True - - def scriptDataEscapedEndTagOpenState(self): - data = self.stream.char() - if data in asciiLetters: - self.temporaryBuffer = data - self.state = self.scriptDataEscapedEndTagNameState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"}) - self.stream.unget(data) - self.state = self.scriptDataEscapedState - return True - - def scriptDataEscapedEndTagNameState(self): - appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower() - data = self.stream.char() - if data in spaceCharacters and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.state = self.beforeAttributeNameState - elif data == "/" and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.state = self.selfClosingStartTagState - elif data == ">" and appropriate: - self.currentToken = {"type": tokenTypes["EndTag"], - "name": self.temporaryBuffer, - "data": [], "selfClosing": False} - self.emitCurrentToken() - self.state = self.dataState - elif data in asciiLetters: - self.temporaryBuffer += data - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "</" + self.temporaryBuffer}) - self.stream.unget(data) - self.state = self.scriptDataEscapedState - return True - - def scriptDataDoubleEscapeStartState(self): - data = self.stream.char() - if data in (spaceCharacters | frozenset(("/", ">"))): - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) - if self.temporaryBuffer.lower() == "script": - self.state = self.scriptDataDoubleEscapedState - else: - self.state = self.scriptDataEscapedState - elif data in asciiLetters: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) - self.temporaryBuffer += data - else: - self.stream.unget(data) - self.state = self.scriptDataEscapedState - return True - - def scriptDataDoubleEscapedState(self): - data = self.stream.char() - if data == "-": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) - self.state = self.scriptDataDoubleEscapedDashState - elif data == "<": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) - self.state = self.scriptDataDoubleEscapedLessThanSignState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - elif data == EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-script-in-script"}) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) - return True - - def scriptDataDoubleEscapedDashState(self): - data = self.stream.char() - if data == "-": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) - self.state = self.scriptDataDoubleEscapedDashDashState - elif data == "<": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) - self.state = self.scriptDataDoubleEscapedLessThanSignState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - self.state = self.scriptDataDoubleEscapedState - elif data == EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-script-in-script"}) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) - self.state = self.scriptDataDoubleEscapedState - return True - - def scriptDataDoubleEscapedDashDashState(self): - data = self.stream.char() - if data == "-": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"}) - elif data == "<": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"}) - self.state = self.scriptDataDoubleEscapedLessThanSignState - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": ">"}) - self.state = self.scriptDataState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": "\uFFFD"}) - self.state = self.scriptDataDoubleEscapedState - elif data == EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-script-in-script"}) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) - self.state = self.scriptDataDoubleEscapedState - return True - - def scriptDataDoubleEscapedLessThanSignState(self): - data = self.stream.char() - if data == "/": - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "/"}) - self.temporaryBuffer = "" - self.state = self.scriptDataDoubleEscapeEndState - else: - self.stream.unget(data) - self.state = self.scriptDataDoubleEscapedState - return True - - def scriptDataDoubleEscapeEndState(self): - data = self.stream.char() - if data in (spaceCharacters | frozenset(("/", ">"))): - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) - if self.temporaryBuffer.lower() == "script": - self.state = self.scriptDataEscapedState - else: - self.state = self.scriptDataDoubleEscapedState - elif data in asciiLetters: - self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data}) - self.temporaryBuffer += data - else: - self.stream.unget(data) - self.state = self.scriptDataDoubleEscapedState - return True - - def beforeAttributeNameState(self): - data = self.stream.char() - if data in spaceCharacters: - self.stream.charsUntil(spaceCharacters, True) - elif data in asciiLetters: - self.currentToken["data"].append([data, ""]) - self.state = self.attributeNameState - elif data == ">": - self.emitCurrentToken() - elif data == "/": - self.state = self.selfClosingStartTagState - elif data in ("'", '"', "=", "<"): - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "invalid-character-in-attribute-name"}) - self.currentToken["data"].append([data, ""]) - self.state = self.attributeNameState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"].append(["\uFFFD", ""]) - self.state = self.attributeNameState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-attribute-name-but-got-eof"}) - self.state = self.dataState - else: - self.currentToken["data"].append([data, ""]) - self.state = self.attributeNameState - return True - - def attributeNameState(self): - data = self.stream.char() - leavingThisState = True - emitToken = False - if data == "=": - self.state = self.beforeAttributeValueState - elif data in asciiLetters: - self.currentToken["data"][-1][0] += data +\ - self.stream.charsUntil(asciiLetters, True) - leavingThisState = False - elif data == ">": - # XXX If we emit here the attributes are converted to a dict - # without being checked and when the code below runs we error - # because data is a dict not a list - emitToken = True - elif data in spaceCharacters: - self.state = self.afterAttributeNameState - elif data == "/": - self.state = self.selfClosingStartTagState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"][-1][0] += "\uFFFD" - leavingThisState = False - elif data in ("'", '"', "<"): - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": - "invalid-character-in-attribute-name"}) - self.currentToken["data"][-1][0] += data - leavingThisState = False - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "eof-in-attribute-name"}) - self.state = self.dataState - else: - self.currentToken["data"][-1][0] += data - leavingThisState = False - - if leavingThisState: - # Attributes are not dropped at this stage. That happens when the - # start tag token is emitted so values can still be safely appended - # to attributes, but we do want to report the parse error in time. - self.currentToken["data"][-1][0] = ( - self.currentToken["data"][-1][0].translate(asciiUpper2Lower)) - for name, _ in self.currentToken["data"][:-1]: - if self.currentToken["data"][-1][0] == name: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "duplicate-attribute"}) - break - # XXX Fix for above XXX - if emitToken: - self.emitCurrentToken() - return True - - def afterAttributeNameState(self): - data = self.stream.char() - if data in spaceCharacters: - self.stream.charsUntil(spaceCharacters, True) - elif data == "=": - self.state = self.beforeAttributeValueState - elif data == ">": - self.emitCurrentToken() - elif data in asciiLetters: - self.currentToken["data"].append([data, ""]) - self.state = self.attributeNameState - elif data == "/": - self.state = self.selfClosingStartTagState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"].append(["\uFFFD", ""]) - self.state = self.attributeNameState - elif data in ("'", '"', "<"): - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "invalid-character-after-attribute-name"}) - self.currentToken["data"].append([data, ""]) - self.state = self.attributeNameState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-end-of-tag-but-got-eof"}) - self.state = self.dataState - else: - self.currentToken["data"].append([data, ""]) - self.state = self.attributeNameState - return True - - def beforeAttributeValueState(self): - data = self.stream.char() - if data in spaceCharacters: - self.stream.charsUntil(spaceCharacters, True) - elif data == "\"": - self.state = self.attributeValueDoubleQuotedState - elif data == "&": - self.state = self.attributeValueUnQuotedState - self.stream.unget(data) - elif data == "'": - self.state = self.attributeValueSingleQuotedState - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-attribute-value-but-got-right-bracket"}) - self.emitCurrentToken() - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"][-1][1] += "\uFFFD" - self.state = self.attributeValueUnQuotedState - elif data in ("=", "<", "`"): - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "equals-in-unquoted-attribute-value"}) - self.currentToken["data"][-1][1] += data - self.state = self.attributeValueUnQuotedState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-attribute-value-but-got-eof"}) - self.state = self.dataState - else: - self.currentToken["data"][-1][1] += data - self.state = self.attributeValueUnQuotedState - return True - - def attributeValueDoubleQuotedState(self): - data = self.stream.char() - if data == "\"": - self.state = self.afterAttributeValueState - elif data == "&": - self.processEntityInAttribute('"') - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"][-1][1] += "\uFFFD" - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-attribute-value-double-quote"}) - self.state = self.dataState - else: - self.currentToken["data"][-1][1] += data +\ - self.stream.charsUntil(("\"", "&", "\u0000")) - return True - - def attributeValueSingleQuotedState(self): - data = self.stream.char() - if data == "'": - self.state = self.afterAttributeValueState - elif data == "&": - self.processEntityInAttribute("'") - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"][-1][1] += "\uFFFD" - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-attribute-value-single-quote"}) - self.state = self.dataState - else: - self.currentToken["data"][-1][1] += data +\ - self.stream.charsUntil(("'", "&", "\u0000")) - return True - - def attributeValueUnQuotedState(self): - data = self.stream.char() - if data in spaceCharacters: - self.state = self.beforeAttributeNameState - elif data == "&": - self.processEntityInAttribute(">") - elif data == ">": - self.emitCurrentToken() - elif data in ('"', "'", "=", "<", "`"): - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-character-in-unquoted-attribute-value"}) - self.currentToken["data"][-1][1] += data - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"][-1][1] += "\uFFFD" - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-attribute-value-no-quotes"}) - self.state = self.dataState - else: - self.currentToken["data"][-1][1] += data + self.stream.charsUntil( - frozenset(("&", ">", '"', "'", "=", "<", "`", "\u0000")) | spaceCharacters) - return True - - def afterAttributeValueState(self): - data = self.stream.char() - if data in spaceCharacters: - self.state = self.beforeAttributeNameState - elif data == ">": - self.emitCurrentToken() - elif data == "/": - self.state = self.selfClosingStartTagState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-EOF-after-attribute-value"}) - self.stream.unget(data) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-character-after-attribute-value"}) - self.stream.unget(data) - self.state = self.beforeAttributeNameState - return True - - def selfClosingStartTagState(self): - data = self.stream.char() - if data == ">": - self.currentToken["selfClosing"] = True - self.emitCurrentToken() - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": - "unexpected-EOF-after-solidus-in-tag"}) - self.stream.unget(data) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-character-after-solidus-in-tag"}) - self.stream.unget(data) - self.state = self.beforeAttributeNameState - return True - - def bogusCommentState(self): - # Make a new comment token and give it as value all the characters - # until the first > or EOF (charsUntil checks for EOF automatically) - # and emit it. - data = self.stream.charsUntil(">") - data = data.replace("\u0000", "\uFFFD") - self.tokenQueue.append( - {"type": tokenTypes["Comment"], "data": data}) - - # Eat the character directly after the bogus comment which is either a - # ">" or an EOF. - self.stream.char() - self.state = self.dataState - return True - - def markupDeclarationOpenState(self): - charStack = [self.stream.char()] - if charStack[-1] == "-": - charStack.append(self.stream.char()) - if charStack[-1] == "-": - self.currentToken = {"type": tokenTypes["Comment"], "data": ""} - self.state = self.commentStartState - return True - elif charStack[-1] in ('d', 'D'): - matched = True - for expected in (('o', 'O'), ('c', 'C'), ('t', 'T'), - ('y', 'Y'), ('p', 'P'), ('e', 'E')): - charStack.append(self.stream.char()) - if charStack[-1] not in expected: - matched = False - break - if matched: - self.currentToken = {"type": tokenTypes["Doctype"], - "name": "", - "publicId": None, "systemId": None, - "correct": True} - self.state = self.doctypeState - return True - elif (charStack[-1] == "[" and - self.parser is not None and - self.parser.tree.openElements and - self.parser.tree.openElements[-1].namespace != self.parser.tree.defaultNamespace): - matched = True - for expected in ["C", "D", "A", "T", "A", "["]: - charStack.append(self.stream.char()) - if charStack[-1] != expected: - matched = False - break - if matched: - self.state = self.cdataSectionState - return True - - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-dashes-or-doctype"}) - - while charStack: - self.stream.unget(charStack.pop()) - self.state = self.bogusCommentState - return True - - def commentStartState(self): - data = self.stream.char() - if data == "-": - self.state = self.commentStartDashState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"] += "\uFFFD" - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "incorrect-comment"}) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-comment"}) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["data"] += data - self.state = self.commentState - return True - - def commentStartDashState(self): - data = self.stream.char() - if data == "-": - self.state = self.commentEndState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"] += "-\uFFFD" - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "incorrect-comment"}) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-comment"}) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["data"] += "-" + data - self.state = self.commentState - return True - - def commentState(self): - data = self.stream.char() - if data == "-": - self.state = self.commentEndDashState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"] += "\uFFFD" - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "eof-in-comment"}) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["data"] += data + \ - self.stream.charsUntil(("-", "\u0000")) - return True - - def commentEndDashState(self): - data = self.stream.char() - if data == "-": - self.state = self.commentEndState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"] += "-\uFFFD" - self.state = self.commentState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-comment-end-dash"}) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["data"] += "-" + data - self.state = self.commentState - return True - - def commentEndState(self): - data = self.stream.char() - if data == ">": - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"] += "--\uFFFD" - self.state = self.commentState - elif data == "!": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-bang-after-double-dash-in-comment"}) - self.state = self.commentEndBangState - elif data == "-": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-dash-after-double-dash-in-comment"}) - self.currentToken["data"] += data - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-comment-double-dash"}) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - # XXX - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-comment"}) - self.currentToken["data"] += "--" + data - self.state = self.commentState - return True - - def commentEndBangState(self): - data = self.stream.char() - if data == ">": - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data == "-": - self.currentToken["data"] += "--!" - self.state = self.commentEndDashState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["data"] += "--!\uFFFD" - self.state = self.commentState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-comment-end-bang-state"}) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["data"] += "--!" + data - self.state = self.commentState - return True - - def doctypeState(self): - data = self.stream.char() - if data in spaceCharacters: - self.state = self.beforeDoctypeNameState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-doctype-name-but-got-eof"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "need-space-after-doctype"}) - self.stream.unget(data) - self.state = self.beforeDoctypeNameState - return True - - def beforeDoctypeNameState(self): - data = self.stream.char() - if data in spaceCharacters: - pass - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-doctype-name-but-got-right-bracket"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["name"] = "\uFFFD" - self.state = self.doctypeNameState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-doctype-name-but-got-eof"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["name"] = data - self.state = self.doctypeNameState - return True - - def doctypeNameState(self): - data = self.stream.char() - if data in spaceCharacters: - self.currentToken["name"] = self.currentToken["name"].translate(asciiUpper2Lower) - self.state = self.afterDoctypeNameState - elif data == ">": - self.currentToken["name"] = self.currentToken["name"].translate(asciiUpper2Lower) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["name"] += "\uFFFD" - self.state = self.doctypeNameState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype-name"}) - self.currentToken["correct"] = False - self.currentToken["name"] = self.currentToken["name"].translate(asciiUpper2Lower) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["name"] += data - return True - - def afterDoctypeNameState(self): - data = self.stream.char() - if data in spaceCharacters: - pass - elif data == ">": - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.currentToken["correct"] = False - self.stream.unget(data) - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - if data in ("p", "P"): - matched = True - for expected in (("u", "U"), ("b", "B"), ("l", "L"), - ("i", "I"), ("c", "C")): - data = self.stream.char() - if data not in expected: - matched = False - break - if matched: - self.state = self.afterDoctypePublicKeywordState - return True - elif data in ("s", "S"): - matched = True - for expected in (("y", "Y"), ("s", "S"), ("t", "T"), - ("e", "E"), ("m", "M")): - data = self.stream.char() - if data not in expected: - matched = False - break - if matched: - self.state = self.afterDoctypeSystemKeywordState - return True - - # All the characters read before the current 'data' will be - # [a-zA-Z], so they're garbage in the bogus doctype and can be - # discarded; only the latest character might be '>' or EOF - # and needs to be ungetted - self.stream.unget(data) - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "expected-space-or-right-bracket-in-doctype", "datavars": - {"data": data}}) - self.currentToken["correct"] = False - self.state = self.bogusDoctypeState - - return True - - def afterDoctypePublicKeywordState(self): - data = self.stream.char() - if data in spaceCharacters: - self.state = self.beforeDoctypePublicIdentifierState - elif data in ("'", '"'): - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.stream.unget(data) - self.state = self.beforeDoctypePublicIdentifierState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.stream.unget(data) - self.state = self.beforeDoctypePublicIdentifierState - return True - - def beforeDoctypePublicIdentifierState(self): - data = self.stream.char() - if data in spaceCharacters: - pass - elif data == "\"": - self.currentToken["publicId"] = "" - self.state = self.doctypePublicIdentifierDoubleQuotedState - elif data == "'": - self.currentToken["publicId"] = "" - self.state = self.doctypePublicIdentifierSingleQuotedState - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-end-of-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.currentToken["correct"] = False - self.state = self.bogusDoctypeState - return True - - def doctypePublicIdentifierDoubleQuotedState(self): - data = self.stream.char() - if data == "\"": - self.state = self.afterDoctypePublicIdentifierState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["publicId"] += "\uFFFD" - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-end-of-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["publicId"] += data - return True - - def doctypePublicIdentifierSingleQuotedState(self): - data = self.stream.char() - if data == "'": - self.state = self.afterDoctypePublicIdentifierState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["publicId"] += "\uFFFD" - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-end-of-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["publicId"] += data - return True - - def afterDoctypePublicIdentifierState(self): - data = self.stream.char() - if data in spaceCharacters: - self.state = self.betweenDoctypePublicAndSystemIdentifiersState - elif data == ">": - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data == '"': - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.currentToken["systemId"] = "" - self.state = self.doctypeSystemIdentifierDoubleQuotedState - elif data == "'": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.currentToken["systemId"] = "" - self.state = self.doctypeSystemIdentifierSingleQuotedState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.currentToken["correct"] = False - self.state = self.bogusDoctypeState - return True - - def betweenDoctypePublicAndSystemIdentifiersState(self): - data = self.stream.char() - if data in spaceCharacters: - pass - elif data == ">": - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data == '"': - self.currentToken["systemId"] = "" - self.state = self.doctypeSystemIdentifierDoubleQuotedState - elif data == "'": - self.currentToken["systemId"] = "" - self.state = self.doctypeSystemIdentifierSingleQuotedState - elif data == EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.currentToken["correct"] = False - self.state = self.bogusDoctypeState - return True - - def afterDoctypeSystemKeywordState(self): - data = self.stream.char() - if data in spaceCharacters: - self.state = self.beforeDoctypeSystemIdentifierState - elif data in ("'", '"'): - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.stream.unget(data) - self.state = self.beforeDoctypeSystemIdentifierState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.stream.unget(data) - self.state = self.beforeDoctypeSystemIdentifierState - return True - - def beforeDoctypeSystemIdentifierState(self): - data = self.stream.char() - if data in spaceCharacters: - pass - elif data == "\"": - self.currentToken["systemId"] = "" - self.state = self.doctypeSystemIdentifierDoubleQuotedState - elif data == "'": - self.currentToken["systemId"] = "" - self.state = self.doctypeSystemIdentifierSingleQuotedState - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.currentToken["correct"] = False - self.state = self.bogusDoctypeState - return True - - def doctypeSystemIdentifierDoubleQuotedState(self): - data = self.stream.char() - if data == "\"": - self.state = self.afterDoctypeSystemIdentifierState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["systemId"] += "\uFFFD" - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-end-of-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["systemId"] += data - return True - - def doctypeSystemIdentifierSingleQuotedState(self): - data = self.stream.char() - if data == "'": - self.state = self.afterDoctypeSystemIdentifierState - elif data == "\u0000": - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - self.currentToken["systemId"] += "\uFFFD" - elif data == ">": - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-end-of-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.currentToken["systemId"] += data - return True - - def afterDoctypeSystemIdentifierState(self): - data = self.stream.char() - if data in spaceCharacters: - pass - elif data == ">": - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "eof-in-doctype"}) - self.currentToken["correct"] = False - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - self.tokenQueue.append({"type": tokenTypes["ParseError"], "data": - "unexpected-char-in-doctype"}) - self.state = self.bogusDoctypeState - return True - - def bogusDoctypeState(self): - data = self.stream.char() - if data == ">": - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - elif data is EOF: - # XXX EMIT - self.stream.unget(data) - self.tokenQueue.append(self.currentToken) - self.state = self.dataState - else: - pass - return True - - def cdataSectionState(self): - data = [] - while True: - data.append(self.stream.charsUntil("]")) - data.append(self.stream.charsUntil(">")) - char = self.stream.char() - if char == EOF: - break - else: - assert char == ">" - if data[-1][-2:] == "]]": - data[-1] = data[-1][:-2] - break - else: - data.append(char) - - data = "".join(data) # pylint:disable=redefined-variable-type - # Deal with null here rather than in the parser - nullCount = data.count("\u0000") - if nullCount > 0: - for _ in range(nullCount): - self.tokenQueue.append({"type": tokenTypes["ParseError"], - "data": "invalid-codepoint"}) - data = data.replace("\u0000", "\uFFFD") - if data: - self.tokenQueue.append({"type": tokenTypes["Characters"], - "data": data}) - self.state = self.dataState - return True diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__init__.py deleted file mode 100644 index 07bad5d3..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__init__.py +++ /dev/null @@ -1,5 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from .py import Trie - -__all__ = ["Trie"] diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 948138bf21c0d7677f4e18a9dcc56d220438985a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 380 zcmYe~<>g{vU|^UdaWFNPfq~&Mh=Yuo7#J8F7#J9ewHO!}QW#Pga~N_NqZo6UqL^}- zqnH^PQkYVhb69d&qgWXkQdrU%qu5edgBdj0UV==~WWL3pm{gpfQ(BT5pP5^bUsQ67 zBPFvevp6$9@0LJmUS@KBN@{#gW=U#MVovc(Mg|53O~zX+Aw`*~MQjWV41SvIx47ct z(@IN9i&Ep`i$KmPVrF1qC}Lq?V7SFpPzhFci#<L*F()TJekDT@$Uk7>SG%)SOlWax zQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vVr=N?zpKGwEV@$BCuWN9KYmkCj zOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOs%}AIa&}^RYH>_KW`TZuS!!NNevy7g xNp6m5PG*vRd`VGes(yTYW?p7Ve7s&k<t+}I-29Z%oK!oI|B68_7h&RI0s!5RXkGvS diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-39.pyc deleted file mode 100644 index 2693bbb73e2f1897267f6d0e71288337437604d2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1624 zcmYe~<>g{vU|^UdaWM5OGXuk85C<7^FfcGUFfcF_M=&rjq%fo~<}l<kMlt3xMKR?v zM=>)pR0*Uoq%h^M<g!MwGBSiS<jJuxq_R~yF*1N4SdJYc7s-&vWWeCgkiwk8(!!9! zlFHi59L15s8qA={_7Y^LCi5-+#H8Z<oYIoi_{`jb{GyUu94VP)nZ=p;dA9^g^D>k3 zQ&Qt|GD}j65_5_*8E>)sCKeQA=A|ctv?F5{D5uzpfq@~FA&N1DA&M!5F^V~byPYA8 z5$pucD3%n~6t)(IDApAA6pj{#D7F;N6s{JADE4*+7KSK}U<OT|TPz_(nW<H>j!DHO zMTyBJ3Q38@sS3$CiN(bVY57G8B}JL3#eT_5Q2Rg>GXnzy3>O<PFff!blrYvXG&3z= zTF6k#)WML#P|8pwSHfJw)XW&n0Co>!3R4S54U-E4NJNv_FPRZ!5)^|BXJueu5C+AA z6axc8215-)tWYgu4dVia4u*w{MJzRplb8xwf*DpaXfod7DlSPZDk(0{EXmMhy2Yet zaEq~GCF3o&f}+&4%!(p*1_p*-EzVXkp~b01#WATlDVaqv{&}e`MVV!(3c3oRex6~j zLBXCOj=>6^elGrguECy;F~P3BuE8O$K?-Iu0RcWSi6*)^`RSR(C7IbVsd;5FKAA}| z#hE3kx&?{J*@@|?#W4k$1^V%2sd*{+Mfw>fxjCjenMwNbpzzX<2L+;DLFFw@o8r`x z<ow(MJCNT#gZx`10}61x?9|F)J)4~T<iwm}J3Y8EO_p1%#ia$QMMZ233=FqeK+0}0 z7pInJGT&k;PR&Ux;$dK5C=z5~U|7j`i!(kR98>Y}Mcg1^UJwD211Ty7C2a;KJ|+%E z4yGzjxUCp*2}(=OprBV`U|^_WSirE5!G$4Kq?W0MX#rym<3h$F4n~F)#$bj*jufU~ z22Eza5I0RGup5d%c4#sefqVyc*)8Vm)Jkv+KnReFZi!?h7RQ5p5)X>9ct|vff@}n7 zXJF)E<N`TS66{25YH>R`1mtAK8iq24BAyz?V1^Qg6vh(98pdYE6h?7|W+oSgSdChy z8pafc8YXUrRwhXXuv$4}5heykhG2$5xe_Ljz9z;LhF}IwCcl@UB&x}Li?t{*FFo}Z zb53gBEe`M0O4p*I{2~-TGiE|O3rcuJU?214<maWQ7MDQ%Dg*K>C{7p{IT%@(#2AGb zMVP9D!Tv>6iQ!XFMgvEV7|5p#3m8BV0*aa%h8iYGhBQ!wF#2gS7RfR&Frc`KJqHrd z=x!56wJ|=kBsEtJ<Umk5U|{58tdhXuFt9RBMn6r?TO9H6d5O8H@$t8~;^TAkQ%Z9{ zY@Yb|!qUVXs0@32d`f<Dd^{wTh=bB4$bm)jpj6EZO}5FYIXUt1NbVB>sRIQdIQ4Ua z90e-9L1D(n$-&OS1r`Unfh#^ft+b@HC^bI52vmF&fx@W><bzxM$@w`ssmUdo`FX{9 ziAl*tprYj#w<ox~1xMa3ZX_jOBaz&Ih(rz>i0AA;385I|5D_LOMgc}1Mj>VZBvf}8 diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-39.pyc deleted file mode 100644 index ff2ef154a2f14c3b384b2ffb17b82206e1625b9e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2285 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 diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/_base.py b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/_base.py deleted file mode 100644 index 6b71975f..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/_base.py +++ /dev/null @@ -1,40 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -try: - from collections.abc import Mapping -except ImportError: # Python 2.7 - from collections import Mapping - - -class Trie(Mapping): - """Abstract base class for tries""" - - def keys(self, prefix=None): - # pylint:disable=arguments-differ - keys = super(Trie, self).keys() - - if prefix is None: - return set(keys) - - return {x for x in keys if x.startswith(prefix)} - - def has_keys_with_prefix(self, prefix): - for key in self.keys(): - if key.startswith(prefix): - return True - - return False - - def longest_prefix(self, prefix): - if prefix in self: - return prefix - - for i in range(1, len(prefix) + 1): - if prefix[:-i] in self: - return prefix[:-i] - - raise KeyError(prefix) - - def longest_prefix_item(self, prefix): - lprefix = self.longest_prefix(prefix) - return (lprefix, self[lprefix]) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/py.py b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/py.py deleted file mode 100644 index c178b219..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/py.py +++ /dev/null @@ -1,67 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals -from pip._vendor.six import text_type - -from bisect import bisect_left - -from ._base import Trie as ABCTrie - - -class Trie(ABCTrie): - def __init__(self, data): - if not all(isinstance(x, text_type) for x in data.keys()): - raise TypeError("All keys must be strings") - - self._data = data - self._keys = sorted(data.keys()) - self._cachestr = "" - self._cachepoints = (0, len(data)) - - def __contains__(self, key): - return key in self._data - - def __len__(self): - return len(self._data) - - def __iter__(self): - return iter(self._data) - - def __getitem__(self, key): - return self._data[key] - - def keys(self, prefix=None): - if prefix is None or prefix == "" or not self._keys: - return set(self._keys) - - if prefix.startswith(self._cachestr): - lo, hi = self._cachepoints - start = i = bisect_left(self._keys, prefix, lo, hi) - else: - start = i = bisect_left(self._keys, prefix) - - keys = set() - if start == len(self._keys): - return keys - - while self._keys[i].startswith(prefix): - keys.add(self._keys[i]) - i += 1 - - self._cachestr = prefix - self._cachepoints = (start, i) - - return keys - - def has_keys_with_prefix(self, prefix): - if prefix in self._data: - return True - - if prefix.startswith(self._cachestr): - lo, hi = self._cachepoints - i = bisect_left(self._keys, prefix, lo, hi) - else: - i = bisect_left(self._keys, prefix) - - if i == len(self._keys): - return False - - return self._keys[i].startswith(prefix) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_utils.py b/env/Lib/site-packages/pip/_vendor/html5lib/_utils.py deleted file mode 100644 index d7c4926a..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/_utils.py +++ /dev/null @@ -1,159 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from types import ModuleType - -try: - from collections.abc import Mapping -except ImportError: - from collections import Mapping - -from pip._vendor.six import text_type, PY3 - -if PY3: - import xml.etree.ElementTree as default_etree -else: - try: - import xml.etree.cElementTree as default_etree - except ImportError: - import xml.etree.ElementTree as default_etree - - -__all__ = ["default_etree", "MethodDispatcher", "isSurrogatePair", - "surrogatePairToCodepoint", "moduleFactoryFactory", - "supports_lone_surrogates"] - - -# Platforms not supporting lone surrogates (\uD800-\uDFFF) should be -# caught by the below test. In general this would be any platform -# using UTF-16 as its encoding of unicode strings, such as -# Jython. This is because UTF-16 itself is based on the use of such -# surrogates, and there is no mechanism to further escape such -# escapes. -try: - _x = eval('"\\uD800"') # pylint:disable=eval-used - if not isinstance(_x, text_type): - # We need this with u"" because of http://bugs.jython.org/issue2039 - _x = eval('u"\\uD800"') # pylint:disable=eval-used - assert isinstance(_x, text_type) -except Exception: - supports_lone_surrogates = False -else: - supports_lone_surrogates = True - - -class MethodDispatcher(dict): - """Dict with 2 special properties: - - On initiation, keys that are lists, sets or tuples are converted to - multiple keys so accessing any one of the items in the original - list-like object returns the matching value - - md = MethodDispatcher({("foo", "bar"):"baz"}) - md["foo"] == "baz" - - A default value which can be set through the default attribute. - """ - - def __init__(self, items=()): - _dictEntries = [] - for name, value in items: - if isinstance(name, (list, tuple, frozenset, set)): - for item in name: - _dictEntries.append((item, value)) - else: - _dictEntries.append((name, value)) - dict.__init__(self, _dictEntries) - assert len(self) == len(_dictEntries) - self.default = None - - def __getitem__(self, key): - return dict.get(self, key, self.default) - - def __get__(self, instance, owner=None): - return BoundMethodDispatcher(instance, self) - - -class BoundMethodDispatcher(Mapping): - """Wraps a MethodDispatcher, binding its return values to `instance`""" - def __init__(self, instance, dispatcher): - self.instance = instance - self.dispatcher = dispatcher - - def __getitem__(self, key): - # see https://docs.python.org/3/reference/datamodel.html#object.__get__ - # on a function, __get__ is used to bind a function to an instance as a bound method - return self.dispatcher[key].__get__(self.instance) - - def get(self, key, default): - if key in self.dispatcher: - return self[key] - else: - return default - - def __iter__(self): - return iter(self.dispatcher) - - def __len__(self): - return len(self.dispatcher) - - def __contains__(self, key): - return key in self.dispatcher - - -# Some utility functions to deal with weirdness around UCS2 vs UCS4 -# python builds - -def isSurrogatePair(data): - return (len(data) == 2 and - ord(data[0]) >= 0xD800 and ord(data[0]) <= 0xDBFF and - ord(data[1]) >= 0xDC00 and ord(data[1]) <= 0xDFFF) - - -def surrogatePairToCodepoint(data): - char_val = (0x10000 + (ord(data[0]) - 0xD800) * 0x400 + - (ord(data[1]) - 0xDC00)) - return char_val - -# Module Factory Factory (no, this isn't Java, I know) -# Here to stop this being duplicated all over the place. - - -def moduleFactoryFactory(factory): - moduleCache = {} - - def moduleFactory(baseModule, *args, **kwargs): - if isinstance(ModuleType.__name__, type("")): - name = "_%s_factory" % baseModule.__name__ - else: - name = b"_%s_factory" % baseModule.__name__ - - kwargs_tuple = tuple(kwargs.items()) - - try: - return moduleCache[name][args][kwargs_tuple] - except KeyError: - mod = ModuleType(name) - objs = factory(baseModule, *args, **kwargs) - mod.__dict__.update(objs) - if "name" not in moduleCache: - moduleCache[name] = {} - if "args" not in moduleCache[name]: - moduleCache[name][args] = {} - if "kwargs" not in moduleCache[name][args]: - moduleCache[name][args][kwargs_tuple] = {} - moduleCache[name][args][kwargs_tuple] = mod - return mod - - return moduleFactory - - -def memoize(func): - cache = {} - - def wrapped(*args, **kwargs): - key = (tuple(args), tuple(kwargs.items())) - if key not in cache: - cache[key] = func(*args, **kwargs) - return cache[key] - - return wrapped diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/constants.py b/env/Lib/site-packages/pip/_vendor/html5lib/constants.py deleted file mode 100644 index fe3e237c..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/constants.py +++ /dev/null @@ -1,2946 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -import string - -EOF = None - -E = { - "null-character": - "Null character in input stream, replaced with U+FFFD.", - "invalid-codepoint": - "Invalid codepoint in stream.", - "incorrectly-placed-solidus": - "Solidus (/) incorrectly placed in tag.", - "incorrect-cr-newline-entity": - "Incorrect CR newline entity, replaced with LF.", - "illegal-windows-1252-entity": - "Entity used with illegal number (windows-1252 reference).", - "cant-convert-numeric-entity": - "Numeric entity couldn't be converted to character " - "(codepoint U+%(charAsInt)08x).", - "illegal-codepoint-for-numeric-entity": - "Numeric entity represents an illegal codepoint: " - "U+%(charAsInt)08x.", - "numeric-entity-without-semicolon": - "Numeric entity didn't end with ';'.", - "expected-numeric-entity-but-got-eof": - "Numeric entity expected. Got end of file instead.", - "expected-numeric-entity": - "Numeric entity expected but none found.", - "named-entity-without-semicolon": - "Named entity didn't end with ';'.", - "expected-named-entity": - "Named entity expected. Got none.", - "attributes-in-end-tag": - "End tag contains unexpected attributes.", - 'self-closing-flag-on-end-tag': - "End tag contains unexpected self-closing flag.", - "expected-tag-name-but-got-right-bracket": - "Expected tag name. Got '>' instead.", - "expected-tag-name-but-got-question-mark": - "Expected tag name. Got '?' instead. (HTML doesn't " - "support processing instructions.)", - "expected-tag-name": - "Expected tag name. Got something else instead", - "expected-closing-tag-but-got-right-bracket": - "Expected closing tag. Got '>' instead. Ignoring '</>'.", - "expected-closing-tag-but-got-eof": - "Expected closing tag. Unexpected end of file.", - "expected-closing-tag-but-got-char": - "Expected closing tag. Unexpected character '%(data)s' found.", - "eof-in-tag-name": - "Unexpected end of file in the tag name.", - "expected-attribute-name-but-got-eof": - "Unexpected end of file. Expected attribute name instead.", - "eof-in-attribute-name": - "Unexpected end of file in attribute name.", - "invalid-character-in-attribute-name": - "Invalid character in attribute name", - "duplicate-attribute": - "Dropped duplicate attribute on tag.", - "expected-end-of-tag-name-but-got-eof": - "Unexpected end of file. Expected = or end of tag.", - "expected-attribute-value-but-got-eof": - "Unexpected end of file. Expected attribute value.", - "expected-attribute-value-but-got-right-bracket": - "Expected attribute value. Got '>' instead.", - 'equals-in-unquoted-attribute-value': - "Unexpected = in unquoted attribute", - 'unexpected-character-in-unquoted-attribute-value': - "Unexpected character in unquoted attribute", - "invalid-character-after-attribute-name": - "Unexpected character after attribute name.", - "unexpected-character-after-attribute-value": - "Unexpected character after attribute value.", - "eof-in-attribute-value-double-quote": - "Unexpected end of file in attribute value (\").", - "eof-in-attribute-value-single-quote": - "Unexpected end of file in attribute value (').", - "eof-in-attribute-value-no-quotes": - "Unexpected end of file in attribute value.", - "unexpected-EOF-after-solidus-in-tag": - "Unexpected end of file in tag. Expected >", - "unexpected-character-after-solidus-in-tag": - "Unexpected character after / in tag. Expected >", - "expected-dashes-or-doctype": - "Expected '--' or 'DOCTYPE'. Not found.", - "unexpected-bang-after-double-dash-in-comment": - "Unexpected ! after -- in comment", - "unexpected-space-after-double-dash-in-comment": - "Unexpected space after -- in comment", - "incorrect-comment": - "Incorrect comment.", - "eof-in-comment": - "Unexpected end of file in comment.", - "eof-in-comment-end-dash": - "Unexpected end of file in comment (-)", - "unexpected-dash-after-double-dash-in-comment": - "Unexpected '-' after '--' found in comment.", - "eof-in-comment-double-dash": - "Unexpected end of file in comment (--).", - "eof-in-comment-end-space-state": - "Unexpected end of file in comment.", - "eof-in-comment-end-bang-state": - "Unexpected end of file in comment.", - "unexpected-char-in-comment": - "Unexpected character in comment found.", - "need-space-after-doctype": - "No space after literal string 'DOCTYPE'.", - "expected-doctype-name-but-got-right-bracket": - "Unexpected > character. Expected DOCTYPE name.", - "expected-doctype-name-but-got-eof": - "Unexpected end of file. Expected DOCTYPE name.", - "eof-in-doctype-name": - "Unexpected end of file in DOCTYPE name.", - "eof-in-doctype": - "Unexpected end of file in DOCTYPE.", - "expected-space-or-right-bracket-in-doctype": - "Expected space or '>'. Got '%(data)s'", - "unexpected-end-of-doctype": - "Unexpected end of DOCTYPE.", - "unexpected-char-in-doctype": - "Unexpected character in DOCTYPE.", - "eof-in-innerhtml": - "XXX innerHTML EOF", - "unexpected-doctype": - "Unexpected DOCTYPE. Ignored.", - "non-html-root": - "html needs to be the first start tag.", - "expected-doctype-but-got-eof": - "Unexpected End of file. Expected DOCTYPE.", - "unknown-doctype": - "Erroneous DOCTYPE.", - "expected-doctype-but-got-chars": - "Unexpected non-space characters. Expected DOCTYPE.", - "expected-doctype-but-got-start-tag": - "Unexpected start tag (%(name)s). Expected DOCTYPE.", - "expected-doctype-but-got-end-tag": - "Unexpected end tag (%(name)s). Expected DOCTYPE.", - "end-tag-after-implied-root": - "Unexpected end tag (%(name)s) after the (implied) root element.", - "expected-named-closing-tag-but-got-eof": - "Unexpected end of file. Expected end tag (%(name)s).", - "two-heads-are-not-better-than-one": - "Unexpected start tag head in existing head. Ignored.", - "unexpected-end-tag": - "Unexpected end tag (%(name)s). Ignored.", - "unexpected-start-tag-out-of-my-head": - "Unexpected start tag (%(name)s) that can be in head. Moved.", - "unexpected-start-tag": - "Unexpected start tag (%(name)s).", - "missing-end-tag": - "Missing end tag (%(name)s).", - "missing-end-tags": - "Missing end tags (%(name)s).", - "unexpected-start-tag-implies-end-tag": - "Unexpected start tag (%(startName)s) " - "implies end tag (%(endName)s).", - "unexpected-start-tag-treated-as": - "Unexpected start tag (%(originalName)s). Treated as %(newName)s.", - "deprecated-tag": - "Unexpected start tag %(name)s. Don't use it!", - "unexpected-start-tag-ignored": - "Unexpected start tag %(name)s. Ignored.", - "expected-one-end-tag-but-got-another": - "Unexpected end tag (%(gotName)s). " - "Missing end tag (%(expectedName)s).", - "end-tag-too-early": - "End tag (%(name)s) seen too early. Expected other end tag.", - "end-tag-too-early-named": - "Unexpected end tag (%(gotName)s). Expected end tag (%(expectedName)s).", - "end-tag-too-early-ignored": - "End tag (%(name)s) seen too early. Ignored.", - "adoption-agency-1.1": - "End tag (%(name)s) violates step 1, " - "paragraph 1 of the adoption agency algorithm.", - "adoption-agency-1.2": - "End tag (%(name)s) violates step 1, " - "paragraph 2 of the adoption agency algorithm.", - "adoption-agency-1.3": - "End tag (%(name)s) violates step 1, " - "paragraph 3 of the adoption agency algorithm.", - "adoption-agency-4.4": - "End tag (%(name)s) violates step 4, " - "paragraph 4 of the adoption agency algorithm.", - "unexpected-end-tag-treated-as": - "Unexpected end tag (%(originalName)s). Treated as %(newName)s.", - "no-end-tag": - "This element (%(name)s) has no end tag.", - "unexpected-implied-end-tag-in-table": - "Unexpected implied end tag (%(name)s) in the table phase.", - "unexpected-implied-end-tag-in-table-body": - "Unexpected implied end tag (%(name)s) in the table body phase.", - "unexpected-char-implies-table-voodoo": - "Unexpected non-space characters in " - "table context caused voodoo mode.", - "unexpected-hidden-input-in-table": - "Unexpected input with type hidden in table context.", - "unexpected-form-in-table": - "Unexpected form in table context.", - "unexpected-start-tag-implies-table-voodoo": - "Unexpected start tag (%(name)s) in " - "table context caused voodoo mode.", - "unexpected-end-tag-implies-table-voodoo": - "Unexpected end tag (%(name)s) in " - "table context caused voodoo mode.", - "unexpected-cell-in-table-body": - "Unexpected table cell start tag (%(name)s) " - "in the table body phase.", - "unexpected-cell-end-tag": - "Got table cell end tag (%(name)s) " - "while required end tags are missing.", - "unexpected-end-tag-in-table-body": - "Unexpected end tag (%(name)s) in the table body phase. Ignored.", - "unexpected-implied-end-tag-in-table-row": - "Unexpected implied end tag (%(name)s) in the table row phase.", - "unexpected-end-tag-in-table-row": - "Unexpected end tag (%(name)s) in the table row phase. Ignored.", - "unexpected-select-in-select": - "Unexpected select start tag in the select phase " - "treated as select end tag.", - "unexpected-input-in-select": - "Unexpected input start tag in the select phase.", - "unexpected-start-tag-in-select": - "Unexpected start tag token (%(name)s in the select phase. " - "Ignored.", - "unexpected-end-tag-in-select": - "Unexpected end tag (%(name)s) in the select phase. Ignored.", - "unexpected-table-element-start-tag-in-select-in-table": - "Unexpected table element start tag (%(name)s) in the select in table phase.", - "unexpected-table-element-end-tag-in-select-in-table": - "Unexpected table element end tag (%(name)s) in the select in table phase.", - "unexpected-char-after-body": - "Unexpected non-space characters in the after body phase.", - "unexpected-start-tag-after-body": - "Unexpected start tag token (%(name)s)" - " in the after body phase.", - "unexpected-end-tag-after-body": - "Unexpected end tag token (%(name)s)" - " in the after body phase.", - "unexpected-char-in-frameset": - "Unexpected characters in the frameset phase. Characters ignored.", - "unexpected-start-tag-in-frameset": - "Unexpected start tag token (%(name)s)" - " in the frameset phase. Ignored.", - "unexpected-frameset-in-frameset-innerhtml": - "Unexpected end tag token (frameset) " - "in the frameset phase (innerHTML).", - "unexpected-end-tag-in-frameset": - "Unexpected end tag token (%(name)s)" - " in the frameset phase. Ignored.", - "unexpected-char-after-frameset": - "Unexpected non-space characters in the " - "after frameset phase. Ignored.", - "unexpected-start-tag-after-frameset": - "Unexpected start tag (%(name)s)" - " in the after frameset phase. Ignored.", - "unexpected-end-tag-after-frameset": - "Unexpected end tag (%(name)s)" - " in the after frameset phase. Ignored.", - "unexpected-end-tag-after-body-innerhtml": - "Unexpected end tag after body(innerHtml)", - "expected-eof-but-got-char": - "Unexpected non-space characters. Expected end of file.", - "expected-eof-but-got-start-tag": - "Unexpected start tag (%(name)s)" - ". Expected end of file.", - "expected-eof-but-got-end-tag": - "Unexpected end tag (%(name)s)" - ". Expected end of file.", - "eof-in-table": - "Unexpected end of file. Expected table content.", - "eof-in-select": - "Unexpected end of file. Expected select content.", - "eof-in-frameset": - "Unexpected end of file. Expected frameset content.", - "eof-in-script-in-script": - "Unexpected end of file. Expected script content.", - "eof-in-foreign-lands": - "Unexpected end of file. Expected foreign content", - "non-void-element-with-trailing-solidus": - "Trailing solidus not allowed on element %(name)s", - "unexpected-html-element-in-foreign-content": - "Element %(name)s not allowed in a non-html context", - "unexpected-end-tag-before-html": - "Unexpected end tag (%(name)s) before html.", - "unexpected-inhead-noscript-tag": - "Element %(name)s not allowed in a inhead-noscript context", - "eof-in-head-noscript": - "Unexpected end of file. Expected inhead-noscript content", - "char-in-head-noscript": - "Unexpected non-space character. Expected inhead-noscript content", - "XXX-undefined-error": - "Undefined error (this sucks and should be fixed)", -} - -namespaces = { - "html": "http://www.w3.org/1999/xhtml", - "mathml": "http://www.w3.org/1998/Math/MathML", - "svg": "http://www.w3.org/2000/svg", - "xlink": "http://www.w3.org/1999/xlink", - "xml": "http://www.w3.org/XML/1998/namespace", - "xmlns": "http://www.w3.org/2000/xmlns/" -} - -scopingElements = frozenset([ - (namespaces["html"], "applet"), - (namespaces["html"], "caption"), - (namespaces["html"], "html"), - (namespaces["html"], "marquee"), - (namespaces["html"], "object"), - (namespaces["html"], "table"), - (namespaces["html"], "td"), - (namespaces["html"], "th"), - (namespaces["mathml"], "mi"), - (namespaces["mathml"], "mo"), - (namespaces["mathml"], "mn"), - (namespaces["mathml"], "ms"), - (namespaces["mathml"], "mtext"), - (namespaces["mathml"], "annotation-xml"), - (namespaces["svg"], "foreignObject"), - (namespaces["svg"], "desc"), - (namespaces["svg"], "title"), -]) - -formattingElements = frozenset([ - (namespaces["html"], "a"), - (namespaces["html"], "b"), - (namespaces["html"], "big"), - (namespaces["html"], "code"), - (namespaces["html"], "em"), - (namespaces["html"], "font"), - (namespaces["html"], "i"), - (namespaces["html"], "nobr"), - (namespaces["html"], "s"), - (namespaces["html"], "small"), - (namespaces["html"], "strike"), - (namespaces["html"], "strong"), - (namespaces["html"], "tt"), - (namespaces["html"], "u") -]) - -specialElements = frozenset([ - (namespaces["html"], "address"), - (namespaces["html"], "applet"), - (namespaces["html"], "area"), - (namespaces["html"], "article"), - (namespaces["html"], "aside"), - (namespaces["html"], "base"), - (namespaces["html"], "basefont"), - (namespaces["html"], "bgsound"), - (namespaces["html"], "blockquote"), - (namespaces["html"], "body"), - (namespaces["html"], "br"), - (namespaces["html"], "button"), - (namespaces["html"], "caption"), - (namespaces["html"], "center"), - (namespaces["html"], "col"), - (namespaces["html"], "colgroup"), - (namespaces["html"], "command"), - (namespaces["html"], "dd"), - (namespaces["html"], "details"), - (namespaces["html"], "dir"), - (namespaces["html"], "div"), - (namespaces["html"], "dl"), - (namespaces["html"], "dt"), - (namespaces["html"], "embed"), - (namespaces["html"], "fieldset"), - (namespaces["html"], "figure"), - (namespaces["html"], "footer"), - (namespaces["html"], "form"), - (namespaces["html"], "frame"), - (namespaces["html"], "frameset"), - (namespaces["html"], "h1"), - (namespaces["html"], "h2"), - (namespaces["html"], "h3"), - (namespaces["html"], "h4"), - (namespaces["html"], "h5"), - (namespaces["html"], "h6"), - (namespaces["html"], "head"), - (namespaces["html"], "header"), - (namespaces["html"], "hr"), - (namespaces["html"], "html"), - (namespaces["html"], "iframe"), - # Note that image is commented out in the spec as "this isn't an - # element that can end up on the stack, so it doesn't matter," - (namespaces["html"], "image"), - (namespaces["html"], "img"), - (namespaces["html"], "input"), - (namespaces["html"], "isindex"), - (namespaces["html"], "li"), - (namespaces["html"], "link"), - (namespaces["html"], "listing"), - (namespaces["html"], "marquee"), - (namespaces["html"], "menu"), - (namespaces["html"], "meta"), - (namespaces["html"], "nav"), - (namespaces["html"], "noembed"), - (namespaces["html"], "noframes"), - (namespaces["html"], "noscript"), - (namespaces["html"], "object"), - (namespaces["html"], "ol"), - (namespaces["html"], "p"), - (namespaces["html"], "param"), - (namespaces["html"], "plaintext"), - (namespaces["html"], "pre"), - (namespaces["html"], "script"), - (namespaces["html"], "section"), - (namespaces["html"], "select"), - (namespaces["html"], "style"), - (namespaces["html"], "table"), - (namespaces["html"], "tbody"), - (namespaces["html"], "td"), - (namespaces["html"], "textarea"), - (namespaces["html"], "tfoot"), - (namespaces["html"], "th"), - (namespaces["html"], "thead"), - (namespaces["html"], "title"), - (namespaces["html"], "tr"), - (namespaces["html"], "ul"), - (namespaces["html"], "wbr"), - (namespaces["html"], "xmp"), - (namespaces["svg"], "foreignObject") -]) - -htmlIntegrationPointElements = frozenset([ - (namespaces["mathml"], "annotation-xml"), - (namespaces["svg"], "foreignObject"), - (namespaces["svg"], "desc"), - (namespaces["svg"], "title") -]) - -mathmlTextIntegrationPointElements = frozenset([ - (namespaces["mathml"], "mi"), - (namespaces["mathml"], "mo"), - (namespaces["mathml"], "mn"), - (namespaces["mathml"], "ms"), - (namespaces["mathml"], "mtext") -]) - -adjustSVGAttributes = { - "attributename": "attributeName", - "attributetype": "attributeType", - "basefrequency": "baseFrequency", - "baseprofile": "baseProfile", - "calcmode": "calcMode", - "clippathunits": "clipPathUnits", - "contentscripttype": "contentScriptType", - "contentstyletype": "contentStyleType", - "diffuseconstant": "diffuseConstant", - "edgemode": "edgeMode", - "externalresourcesrequired": "externalResourcesRequired", - "filterres": "filterRes", - "filterunits": "filterUnits", - "glyphref": "glyphRef", - "gradienttransform": "gradientTransform", - "gradientunits": "gradientUnits", - "kernelmatrix": "kernelMatrix", - "kernelunitlength": "kernelUnitLength", - "keypoints": "keyPoints", - "keysplines": "keySplines", - "keytimes": "keyTimes", - "lengthadjust": "lengthAdjust", - "limitingconeangle": "limitingConeAngle", - "markerheight": "markerHeight", - "markerunits": "markerUnits", - "markerwidth": "markerWidth", - "maskcontentunits": "maskContentUnits", - "maskunits": "maskUnits", - "numoctaves": "numOctaves", - "pathlength": "pathLength", - "patterncontentunits": "patternContentUnits", - "patterntransform": "patternTransform", - "patternunits": "patternUnits", - "pointsatx": "pointsAtX", - "pointsaty": "pointsAtY", - "pointsatz": "pointsAtZ", - "preservealpha": "preserveAlpha", - "preserveaspectratio": "preserveAspectRatio", - "primitiveunits": "primitiveUnits", - "refx": "refX", - "refy": "refY", - "repeatcount": "repeatCount", - "repeatdur": "repeatDur", - "requiredextensions": "requiredExtensions", - "requiredfeatures": "requiredFeatures", - "specularconstant": "specularConstant", - "specularexponent": "specularExponent", - "spreadmethod": "spreadMethod", - "startoffset": "startOffset", - "stddeviation": "stdDeviation", - "stitchtiles": "stitchTiles", - "surfacescale": "surfaceScale", - "systemlanguage": "systemLanguage", - "tablevalues": "tableValues", - "targetx": "targetX", - "targety": "targetY", - "textlength": "textLength", - "viewbox": "viewBox", - "viewtarget": "viewTarget", - "xchannelselector": "xChannelSelector", - "ychannelselector": "yChannelSelector", - "zoomandpan": "zoomAndPan" -} - -adjustMathMLAttributes = {"definitionurl": "definitionURL"} - -adjustForeignAttributes = { - "xlink:actuate": ("xlink", "actuate", namespaces["xlink"]), - "xlink:arcrole": ("xlink", "arcrole", namespaces["xlink"]), - "xlink:href": ("xlink", "href", namespaces["xlink"]), - "xlink:role": ("xlink", "role", namespaces["xlink"]), - "xlink:show": ("xlink", "show", namespaces["xlink"]), - "xlink:title": ("xlink", "title", namespaces["xlink"]), - "xlink:type": ("xlink", "type", namespaces["xlink"]), - "xml:base": ("xml", "base", namespaces["xml"]), - "xml:lang": ("xml", "lang", namespaces["xml"]), - "xml:space": ("xml", "space", namespaces["xml"]), - "xmlns": (None, "xmlns", namespaces["xmlns"]), - "xmlns:xlink": ("xmlns", "xlink", namespaces["xmlns"]) -} - -unadjustForeignAttributes = {(ns, local): qname for qname, (prefix, local, ns) in - adjustForeignAttributes.items()} - -spaceCharacters = frozenset([ - "\t", - "\n", - "\u000C", - " ", - "\r" -]) - -tableInsertModeElements = frozenset([ - "table", - "tbody", - "tfoot", - "thead", - "tr" -]) - -asciiLowercase = frozenset(string.ascii_lowercase) -asciiUppercase = frozenset(string.ascii_uppercase) -asciiLetters = frozenset(string.ascii_letters) -digits = frozenset(string.digits) -hexDigits = frozenset(string.hexdigits) - -asciiUpper2Lower = {ord(c): ord(c.lower()) for c in string.ascii_uppercase} - -# Heading elements need to be ordered -headingElements = ( - "h1", - "h2", - "h3", - "h4", - "h5", - "h6" -) - -voidElements = frozenset([ - "base", - "command", - "event-source", - "link", - "meta", - "hr", - "br", - "img", - "embed", - "param", - "area", - "col", - "input", - "source", - "track" -]) - -cdataElements = frozenset(['title', 'textarea']) - -rcdataElements = frozenset([ - 'style', - 'script', - 'xmp', - 'iframe', - 'noembed', - 'noframes', - 'noscript' -]) - -booleanAttributes = { - "": frozenset(["irrelevant", "itemscope"]), - "style": frozenset(["scoped"]), - "img": frozenset(["ismap"]), - "audio": frozenset(["autoplay", "controls"]), - "video": frozenset(["autoplay", "controls"]), - "script": frozenset(["defer", "async"]), - "details": frozenset(["open"]), - "datagrid": frozenset(["multiple", "disabled"]), - "command": frozenset(["hidden", "disabled", "checked", "default"]), - "hr": frozenset(["noshade"]), - "menu": frozenset(["autosubmit"]), - "fieldset": frozenset(["disabled", "readonly"]), - "option": frozenset(["disabled", "readonly", "selected"]), - "optgroup": frozenset(["disabled", "readonly"]), - "button": frozenset(["disabled", "autofocus"]), - "input": frozenset(["disabled", "readonly", "required", "autofocus", "checked", "ismap"]), - "select": frozenset(["disabled", "readonly", "autofocus", "multiple"]), - "output": frozenset(["disabled", "readonly"]), - "iframe": frozenset(["seamless"]), -} - -# entitiesWindows1252 has to be _ordered_ and needs to have an index. It -# therefore can't be a frozenset. -entitiesWindows1252 = ( - 8364, # 0x80 0x20AC EURO SIGN - 65533, # 0x81 UNDEFINED - 8218, # 0x82 0x201A SINGLE LOW-9 QUOTATION MARK - 402, # 0x83 0x0192 LATIN SMALL LETTER F WITH HOOK - 8222, # 0x84 0x201E DOUBLE LOW-9 QUOTATION MARK - 8230, # 0x85 0x2026 HORIZONTAL ELLIPSIS - 8224, # 0x86 0x2020 DAGGER - 8225, # 0x87 0x2021 DOUBLE DAGGER - 710, # 0x88 0x02C6 MODIFIER LETTER CIRCUMFLEX ACCENT - 8240, # 0x89 0x2030 PER MILLE SIGN - 352, # 0x8A 0x0160 LATIN CAPITAL LETTER S WITH CARON - 8249, # 0x8B 0x2039 SINGLE LEFT-POINTING ANGLE QUOTATION MARK - 338, # 0x8C 0x0152 LATIN CAPITAL LIGATURE OE - 65533, # 0x8D UNDEFINED - 381, # 0x8E 0x017D LATIN CAPITAL LETTER Z WITH CARON - 65533, # 0x8F UNDEFINED - 65533, # 0x90 UNDEFINED - 8216, # 0x91 0x2018 LEFT SINGLE QUOTATION MARK - 8217, # 0x92 0x2019 RIGHT SINGLE QUOTATION MARK - 8220, # 0x93 0x201C LEFT DOUBLE QUOTATION MARK - 8221, # 0x94 0x201D RIGHT DOUBLE QUOTATION MARK - 8226, # 0x95 0x2022 BULLET - 8211, # 0x96 0x2013 EN DASH - 8212, # 0x97 0x2014 EM DASH - 732, # 0x98 0x02DC SMALL TILDE - 8482, # 0x99 0x2122 TRADE MARK SIGN - 353, # 0x9A 0x0161 LATIN SMALL LETTER S WITH CARON - 8250, # 0x9B 0x203A SINGLE RIGHT-POINTING ANGLE QUOTATION MARK - 339, # 0x9C 0x0153 LATIN SMALL LIGATURE OE - 65533, # 0x9D UNDEFINED - 382, # 0x9E 0x017E LATIN SMALL LETTER Z WITH CARON - 376 # 0x9F 0x0178 LATIN CAPITAL LETTER Y WITH DIAERESIS -) - -xmlEntities = frozenset(['lt;', 'gt;', 'amp;', 'apos;', 'quot;']) - -entities = { - "AElig": "\xc6", - "AElig;": "\xc6", - "AMP": "&", - "AMP;": "&", - "Aacute": "\xc1", - "Aacute;": "\xc1", - "Abreve;": "\u0102", - "Acirc": "\xc2", - "Acirc;": "\xc2", - "Acy;": "\u0410", - "Afr;": "\U0001d504", - "Agrave": "\xc0", - "Agrave;": "\xc0", - "Alpha;": "\u0391", - "Amacr;": "\u0100", - "And;": "\u2a53", - "Aogon;": "\u0104", - "Aopf;": "\U0001d538", - "ApplyFunction;": "\u2061", - "Aring": "\xc5", - "Aring;": "\xc5", - "Ascr;": "\U0001d49c", - "Assign;": "\u2254", - "Atilde": "\xc3", - "Atilde;": "\xc3", - "Auml": "\xc4", - "Auml;": "\xc4", - "Backslash;": "\u2216", - "Barv;": "\u2ae7", - "Barwed;": "\u2306", - "Bcy;": "\u0411", - "Because;": "\u2235", - "Bernoullis;": "\u212c", - "Beta;": "\u0392", - "Bfr;": "\U0001d505", - "Bopf;": "\U0001d539", - "Breve;": "\u02d8", - "Bscr;": "\u212c", - "Bumpeq;": "\u224e", - "CHcy;": "\u0427", - "COPY": "\xa9", - "COPY;": "\xa9", - "Cacute;": "\u0106", - "Cap;": "\u22d2", - "CapitalDifferentialD;": "\u2145", - "Cayleys;": "\u212d", - "Ccaron;": "\u010c", - "Ccedil": "\xc7", - "Ccedil;": "\xc7", - "Ccirc;": "\u0108", - "Cconint;": "\u2230", - "Cdot;": "\u010a", - "Cedilla;": "\xb8", - "CenterDot;": "\xb7", - "Cfr;": "\u212d", - "Chi;": "\u03a7", - "CircleDot;": "\u2299", - "CircleMinus;": "\u2296", - "CirclePlus;": "\u2295", - "CircleTimes;": "\u2297", - "ClockwiseContourIntegral;": "\u2232", - "CloseCurlyDoubleQuote;": "\u201d", - "CloseCurlyQuote;": "\u2019", - "Colon;": "\u2237", - "Colone;": "\u2a74", - "Congruent;": "\u2261", - "Conint;": "\u222f", - "ContourIntegral;": "\u222e", - "Copf;": "\u2102", - "Coproduct;": "\u2210", - "CounterClockwiseContourIntegral;": "\u2233", - "Cross;": "\u2a2f", - "Cscr;": "\U0001d49e", - "Cup;": "\u22d3", - "CupCap;": "\u224d", - "DD;": "\u2145", - "DDotrahd;": "\u2911", - "DJcy;": "\u0402", - "DScy;": "\u0405", - "DZcy;": "\u040f", - "Dagger;": "\u2021", - "Darr;": "\u21a1", - "Dashv;": "\u2ae4", - "Dcaron;": "\u010e", - "Dcy;": "\u0414", - "Del;": "\u2207", - "Delta;": "\u0394", - "Dfr;": "\U0001d507", - "DiacriticalAcute;": "\xb4", - "DiacriticalDot;": "\u02d9", - "DiacriticalDoubleAcute;": "\u02dd", - "DiacriticalGrave;": "`", - "DiacriticalTilde;": "\u02dc", - "Diamond;": "\u22c4", - "DifferentialD;": "\u2146", - "Dopf;": "\U0001d53b", - "Dot;": "\xa8", - "DotDot;": "\u20dc", - "DotEqual;": "\u2250", - "DoubleContourIntegral;": "\u222f", - "DoubleDot;": "\xa8", - "DoubleDownArrow;": "\u21d3", - "DoubleLeftArrow;": "\u21d0", - "DoubleLeftRightArrow;": "\u21d4", - "DoubleLeftTee;": "\u2ae4", - "DoubleLongLeftArrow;": "\u27f8", - "DoubleLongLeftRightArrow;": "\u27fa", - "DoubleLongRightArrow;": "\u27f9", - "DoubleRightArrow;": "\u21d2", - "DoubleRightTee;": "\u22a8", - "DoubleUpArrow;": "\u21d1", - "DoubleUpDownArrow;": "\u21d5", - "DoubleVerticalBar;": "\u2225", - "DownArrow;": "\u2193", - "DownArrowBar;": "\u2913", - "DownArrowUpArrow;": "\u21f5", - "DownBreve;": "\u0311", - "DownLeftRightVector;": "\u2950", - "DownLeftTeeVector;": "\u295e", - "DownLeftVector;": "\u21bd", - "DownLeftVectorBar;": "\u2956", - "DownRightTeeVector;": "\u295f", - "DownRightVector;": "\u21c1", - "DownRightVectorBar;": "\u2957", - "DownTee;": "\u22a4", - "DownTeeArrow;": "\u21a7", - "Downarrow;": "\u21d3", - "Dscr;": "\U0001d49f", - "Dstrok;": "\u0110", - "ENG;": "\u014a", - "ETH": "\xd0", - "ETH;": "\xd0", - "Eacute": "\xc9", - "Eacute;": "\xc9", - "Ecaron;": "\u011a", - "Ecirc": "\xca", - "Ecirc;": "\xca", - "Ecy;": "\u042d", - "Edot;": "\u0116", - "Efr;": "\U0001d508", - "Egrave": "\xc8", - "Egrave;": "\xc8", - "Element;": "\u2208", - "Emacr;": "\u0112", - "EmptySmallSquare;": "\u25fb", - "EmptyVerySmallSquare;": "\u25ab", - "Eogon;": "\u0118", - "Eopf;": "\U0001d53c", - "Epsilon;": "\u0395", - "Equal;": "\u2a75", - "EqualTilde;": "\u2242", - "Equilibrium;": "\u21cc", - "Escr;": "\u2130", - "Esim;": "\u2a73", - "Eta;": "\u0397", - "Euml": "\xcb", - "Euml;": "\xcb", - "Exists;": "\u2203", - "ExponentialE;": "\u2147", - "Fcy;": "\u0424", - "Ffr;": "\U0001d509", - "FilledSmallSquare;": "\u25fc", - "FilledVerySmallSquare;": "\u25aa", - "Fopf;": "\U0001d53d", - "ForAll;": "\u2200", - "Fouriertrf;": "\u2131", - "Fscr;": "\u2131", - "GJcy;": "\u0403", - "GT": ">", - "GT;": ">", - "Gamma;": "\u0393", - "Gammad;": "\u03dc", - "Gbreve;": "\u011e", - "Gcedil;": "\u0122", - "Gcirc;": "\u011c", - "Gcy;": "\u0413", - "Gdot;": "\u0120", - "Gfr;": "\U0001d50a", - "Gg;": "\u22d9", - "Gopf;": "\U0001d53e", - "GreaterEqual;": "\u2265", - "GreaterEqualLess;": "\u22db", - "GreaterFullEqual;": "\u2267", - "GreaterGreater;": "\u2aa2", - "GreaterLess;": "\u2277", - "GreaterSlantEqual;": "\u2a7e", - "GreaterTilde;": "\u2273", - "Gscr;": "\U0001d4a2", - "Gt;": "\u226b", - "HARDcy;": "\u042a", - "Hacek;": "\u02c7", - "Hat;": "^", - "Hcirc;": "\u0124", - "Hfr;": "\u210c", - "HilbertSpace;": "\u210b", - "Hopf;": "\u210d", - "HorizontalLine;": "\u2500", - "Hscr;": "\u210b", - "Hstrok;": "\u0126", - "HumpDownHump;": "\u224e", - "HumpEqual;": "\u224f", - "IEcy;": "\u0415", - "IJlig;": "\u0132", - "IOcy;": "\u0401", - "Iacute": "\xcd", - "Iacute;": "\xcd", - "Icirc": "\xce", - "Icirc;": "\xce", - "Icy;": "\u0418", - "Idot;": "\u0130", - "Ifr;": "\u2111", - "Igrave": "\xcc", - "Igrave;": "\xcc", - "Im;": "\u2111", - "Imacr;": "\u012a", - "ImaginaryI;": "\u2148", - "Implies;": "\u21d2", - "Int;": "\u222c", - "Integral;": "\u222b", - "Intersection;": "\u22c2", - "InvisibleComma;": "\u2063", - "InvisibleTimes;": "\u2062", - "Iogon;": "\u012e", - "Iopf;": "\U0001d540", - "Iota;": "\u0399", - "Iscr;": "\u2110", - "Itilde;": "\u0128", - "Iukcy;": "\u0406", - "Iuml": "\xcf", - "Iuml;": "\xcf", - "Jcirc;": "\u0134", - "Jcy;": "\u0419", - "Jfr;": "\U0001d50d", - "Jopf;": "\U0001d541", - "Jscr;": "\U0001d4a5", - "Jsercy;": "\u0408", - "Jukcy;": "\u0404", - "KHcy;": "\u0425", - "KJcy;": "\u040c", - "Kappa;": "\u039a", - "Kcedil;": "\u0136", - "Kcy;": "\u041a", - "Kfr;": "\U0001d50e", - "Kopf;": "\U0001d542", - "Kscr;": "\U0001d4a6", - "LJcy;": "\u0409", - "LT": "<", - "LT;": "<", - "Lacute;": "\u0139", - "Lambda;": "\u039b", - "Lang;": "\u27ea", - "Laplacetrf;": "\u2112", - "Larr;": "\u219e", - "Lcaron;": "\u013d", - "Lcedil;": "\u013b", - "Lcy;": "\u041b", - "LeftAngleBracket;": "\u27e8", - "LeftArrow;": "\u2190", - "LeftArrowBar;": "\u21e4", - "LeftArrowRightArrow;": "\u21c6", - "LeftCeiling;": "\u2308", - "LeftDoubleBracket;": "\u27e6", - "LeftDownTeeVector;": "\u2961", - "LeftDownVector;": "\u21c3", - "LeftDownVectorBar;": "\u2959", - "LeftFloor;": "\u230a", - "LeftRightArrow;": "\u2194", - "LeftRightVector;": "\u294e", - "LeftTee;": "\u22a3", - "LeftTeeArrow;": "\u21a4", - "LeftTeeVector;": "\u295a", - "LeftTriangle;": "\u22b2", - "LeftTriangleBar;": "\u29cf", - "LeftTriangleEqual;": "\u22b4", - "LeftUpDownVector;": "\u2951", - "LeftUpTeeVector;": "\u2960", - "LeftUpVector;": "\u21bf", - "LeftUpVectorBar;": "\u2958", - "LeftVector;": "\u21bc", - "LeftVectorBar;": "\u2952", - "Leftarrow;": "\u21d0", - "Leftrightarrow;": "\u21d4", - "LessEqualGreater;": "\u22da", - "LessFullEqual;": "\u2266", - "LessGreater;": "\u2276", - "LessLess;": "\u2aa1", - "LessSlantEqual;": "\u2a7d", - "LessTilde;": "\u2272", - "Lfr;": "\U0001d50f", - "Ll;": "\u22d8", - "Lleftarrow;": "\u21da", - "Lmidot;": "\u013f", - "LongLeftArrow;": "\u27f5", - "LongLeftRightArrow;": "\u27f7", - "LongRightArrow;": "\u27f6", - "Longleftarrow;": "\u27f8", - "Longleftrightarrow;": "\u27fa", - "Longrightarrow;": "\u27f9", - "Lopf;": "\U0001d543", - "LowerLeftArrow;": "\u2199", - "LowerRightArrow;": "\u2198", - "Lscr;": "\u2112", - "Lsh;": "\u21b0", - "Lstrok;": "\u0141", - "Lt;": "\u226a", - "Map;": "\u2905", - "Mcy;": "\u041c", - "MediumSpace;": "\u205f", - "Mellintrf;": "\u2133", - "Mfr;": "\U0001d510", - "MinusPlus;": "\u2213", - "Mopf;": "\U0001d544", - "Mscr;": "\u2133", - "Mu;": "\u039c", - "NJcy;": "\u040a", - "Nacute;": "\u0143", - "Ncaron;": "\u0147", - "Ncedil;": "\u0145", - "Ncy;": "\u041d", - "NegativeMediumSpace;": "\u200b", - "NegativeThickSpace;": "\u200b", - "NegativeThinSpace;": "\u200b", - "NegativeVeryThinSpace;": "\u200b", - "NestedGreaterGreater;": "\u226b", - "NestedLessLess;": "\u226a", - "NewLine;": "\n", - "Nfr;": "\U0001d511", - "NoBreak;": "\u2060", - "NonBreakingSpace;": "\xa0", - "Nopf;": "\u2115", - "Not;": "\u2aec", - "NotCongruent;": "\u2262", - "NotCupCap;": "\u226d", - "NotDoubleVerticalBar;": "\u2226", - "NotElement;": "\u2209", - "NotEqual;": "\u2260", - "NotEqualTilde;": "\u2242\u0338", - "NotExists;": "\u2204", - "NotGreater;": "\u226f", - "NotGreaterEqual;": "\u2271", - "NotGreaterFullEqual;": "\u2267\u0338", - "NotGreaterGreater;": "\u226b\u0338", - "NotGreaterLess;": "\u2279", - "NotGreaterSlantEqual;": "\u2a7e\u0338", - "NotGreaterTilde;": "\u2275", - "NotHumpDownHump;": "\u224e\u0338", - "NotHumpEqual;": "\u224f\u0338", - "NotLeftTriangle;": "\u22ea", - "NotLeftTriangleBar;": "\u29cf\u0338", - "NotLeftTriangleEqual;": "\u22ec", - "NotLess;": "\u226e", - "NotLessEqual;": "\u2270", - "NotLessGreater;": "\u2278", - "NotLessLess;": "\u226a\u0338", - "NotLessSlantEqual;": "\u2a7d\u0338", - "NotLessTilde;": "\u2274", - "NotNestedGreaterGreater;": "\u2aa2\u0338", - "NotNestedLessLess;": "\u2aa1\u0338", - "NotPrecedes;": "\u2280", - "NotPrecedesEqual;": "\u2aaf\u0338", - "NotPrecedesSlantEqual;": "\u22e0", - "NotReverseElement;": "\u220c", - "NotRightTriangle;": "\u22eb", - "NotRightTriangleBar;": "\u29d0\u0338", - "NotRightTriangleEqual;": "\u22ed", - "NotSquareSubset;": "\u228f\u0338", - "NotSquareSubsetEqual;": "\u22e2", - "NotSquareSuperset;": "\u2290\u0338", - "NotSquareSupersetEqual;": "\u22e3", - "NotSubset;": "\u2282\u20d2", - "NotSubsetEqual;": "\u2288", - "NotSucceeds;": "\u2281", - "NotSucceedsEqual;": "\u2ab0\u0338", - "NotSucceedsSlantEqual;": "\u22e1", - "NotSucceedsTilde;": "\u227f\u0338", - "NotSuperset;": "\u2283\u20d2", - "NotSupersetEqual;": "\u2289", - "NotTilde;": "\u2241", - "NotTildeEqual;": "\u2244", - "NotTildeFullEqual;": "\u2247", - "NotTildeTilde;": "\u2249", - "NotVerticalBar;": "\u2224", - "Nscr;": "\U0001d4a9", - "Ntilde": "\xd1", - "Ntilde;": "\xd1", - "Nu;": "\u039d", - "OElig;": "\u0152", - "Oacute": "\xd3", - "Oacute;": "\xd3", - "Ocirc": "\xd4", - "Ocirc;": "\xd4", - "Ocy;": "\u041e", - "Odblac;": "\u0150", - "Ofr;": "\U0001d512", - "Ograve": "\xd2", - "Ograve;": "\xd2", - "Omacr;": "\u014c", - "Omega;": "\u03a9", - "Omicron;": "\u039f", - "Oopf;": "\U0001d546", - "OpenCurlyDoubleQuote;": "\u201c", - "OpenCurlyQuote;": "\u2018", - "Or;": "\u2a54", - "Oscr;": "\U0001d4aa", - "Oslash": "\xd8", - "Oslash;": "\xd8", - "Otilde": "\xd5", - "Otilde;": "\xd5", - "Otimes;": "\u2a37", - "Ouml": "\xd6", - "Ouml;": "\xd6", - "OverBar;": "\u203e", - "OverBrace;": "\u23de", - "OverBracket;": "\u23b4", - "OverParenthesis;": "\u23dc", - "PartialD;": "\u2202", - "Pcy;": "\u041f", - "Pfr;": "\U0001d513", - "Phi;": "\u03a6", - "Pi;": "\u03a0", - "PlusMinus;": "\xb1", - "Poincareplane;": "\u210c", - "Popf;": "\u2119", - "Pr;": "\u2abb", - "Precedes;": "\u227a", - "PrecedesEqual;": "\u2aaf", - "PrecedesSlantEqual;": "\u227c", - "PrecedesTilde;": "\u227e", - "Prime;": "\u2033", - "Product;": "\u220f", - "Proportion;": "\u2237", - "Proportional;": "\u221d", - "Pscr;": "\U0001d4ab", - "Psi;": "\u03a8", - "QUOT": "\"", - "QUOT;": "\"", - "Qfr;": "\U0001d514", - "Qopf;": "\u211a", - "Qscr;": "\U0001d4ac", - "RBarr;": "\u2910", - "REG": "\xae", - "REG;": "\xae", - "Racute;": "\u0154", - "Rang;": "\u27eb", - "Rarr;": "\u21a0", - "Rarrtl;": "\u2916", - "Rcaron;": "\u0158", - "Rcedil;": "\u0156", - "Rcy;": "\u0420", - "Re;": "\u211c", - "ReverseElement;": "\u220b", - "ReverseEquilibrium;": "\u21cb", - "ReverseUpEquilibrium;": "\u296f", - "Rfr;": "\u211c", - "Rho;": "\u03a1", - "RightAngleBracket;": "\u27e9", - "RightArrow;": "\u2192", - "RightArrowBar;": "\u21e5", - "RightArrowLeftArrow;": "\u21c4", - "RightCeiling;": "\u2309", - "RightDoubleBracket;": "\u27e7", - "RightDownTeeVector;": "\u295d", - "RightDownVector;": "\u21c2", - "RightDownVectorBar;": "\u2955", - "RightFloor;": "\u230b", - "RightTee;": "\u22a2", - "RightTeeArrow;": "\u21a6", - "RightTeeVector;": "\u295b", - "RightTriangle;": "\u22b3", - "RightTriangleBar;": "\u29d0", - "RightTriangleEqual;": "\u22b5", - "RightUpDownVector;": "\u294f", - "RightUpTeeVector;": "\u295c", - "RightUpVector;": "\u21be", - "RightUpVectorBar;": "\u2954", - "RightVector;": "\u21c0", - "RightVectorBar;": "\u2953", - "Rightarrow;": "\u21d2", - "Ropf;": "\u211d", - "RoundImplies;": "\u2970", - "Rrightarrow;": "\u21db", - "Rscr;": "\u211b", - "Rsh;": "\u21b1", - "RuleDelayed;": "\u29f4", - "SHCHcy;": "\u0429", - "SHcy;": "\u0428", - "SOFTcy;": "\u042c", - "Sacute;": "\u015a", - "Sc;": "\u2abc", - "Scaron;": "\u0160", - "Scedil;": "\u015e", - "Scirc;": "\u015c", - "Scy;": "\u0421", - "Sfr;": "\U0001d516", - "ShortDownArrow;": "\u2193", - "ShortLeftArrow;": "\u2190", - "ShortRightArrow;": "\u2192", - "ShortUpArrow;": "\u2191", - "Sigma;": "\u03a3", - "SmallCircle;": "\u2218", - "Sopf;": "\U0001d54a", - "Sqrt;": "\u221a", - "Square;": "\u25a1", - "SquareIntersection;": "\u2293", - "SquareSubset;": "\u228f", - "SquareSubsetEqual;": "\u2291", - "SquareSuperset;": "\u2290", - "SquareSupersetEqual;": "\u2292", - "SquareUnion;": "\u2294", - "Sscr;": "\U0001d4ae", - "Star;": "\u22c6", - "Sub;": "\u22d0", - "Subset;": "\u22d0", - "SubsetEqual;": "\u2286", - "Succeeds;": "\u227b", - "SucceedsEqual;": "\u2ab0", - "SucceedsSlantEqual;": "\u227d", - "SucceedsTilde;": "\u227f", - "SuchThat;": "\u220b", - "Sum;": "\u2211", - "Sup;": "\u22d1", - "Superset;": "\u2283", - "SupersetEqual;": "\u2287", - "Supset;": "\u22d1", - "THORN": "\xde", - "THORN;": "\xde", - "TRADE;": "\u2122", - "TSHcy;": "\u040b", - "TScy;": "\u0426", - "Tab;": "\t", - "Tau;": "\u03a4", - "Tcaron;": "\u0164", - "Tcedil;": "\u0162", - "Tcy;": "\u0422", - "Tfr;": "\U0001d517", - "Therefore;": "\u2234", - "Theta;": "\u0398", - "ThickSpace;": "\u205f\u200a", - "ThinSpace;": "\u2009", - "Tilde;": "\u223c", - "TildeEqual;": "\u2243", - "TildeFullEqual;": "\u2245", - "TildeTilde;": "\u2248", - "Topf;": "\U0001d54b", - "TripleDot;": "\u20db", - "Tscr;": "\U0001d4af", - "Tstrok;": "\u0166", - "Uacute": "\xda", - "Uacute;": "\xda", - "Uarr;": "\u219f", - "Uarrocir;": "\u2949", - "Ubrcy;": "\u040e", - "Ubreve;": "\u016c", - "Ucirc": "\xdb", - "Ucirc;": "\xdb", - "Ucy;": "\u0423", - "Udblac;": "\u0170", - "Ufr;": "\U0001d518", - "Ugrave": "\xd9", - "Ugrave;": "\xd9", - "Umacr;": "\u016a", - "UnderBar;": "_", - "UnderBrace;": "\u23df", - "UnderBracket;": "\u23b5", - "UnderParenthesis;": "\u23dd", - "Union;": "\u22c3", - "UnionPlus;": "\u228e", - "Uogon;": "\u0172", - "Uopf;": "\U0001d54c", - "UpArrow;": "\u2191", - "UpArrowBar;": "\u2912", - "UpArrowDownArrow;": "\u21c5", - "UpDownArrow;": "\u2195", - "UpEquilibrium;": "\u296e", - "UpTee;": "\u22a5", - "UpTeeArrow;": "\u21a5", - "Uparrow;": "\u21d1", - "Updownarrow;": "\u21d5", - "UpperLeftArrow;": "\u2196", - "UpperRightArrow;": "\u2197", - "Upsi;": "\u03d2", - "Upsilon;": "\u03a5", - "Uring;": "\u016e", - "Uscr;": "\U0001d4b0", - "Utilde;": "\u0168", - "Uuml": "\xdc", - "Uuml;": "\xdc", - "VDash;": "\u22ab", - "Vbar;": "\u2aeb", - "Vcy;": "\u0412", - "Vdash;": "\u22a9", - "Vdashl;": "\u2ae6", - "Vee;": "\u22c1", - "Verbar;": "\u2016", - "Vert;": "\u2016", - "VerticalBar;": "\u2223", - "VerticalLine;": "|", - "VerticalSeparator;": "\u2758", - "VerticalTilde;": "\u2240", - "VeryThinSpace;": "\u200a", - "Vfr;": "\U0001d519", - "Vopf;": "\U0001d54d", - "Vscr;": "\U0001d4b1", - "Vvdash;": "\u22aa", - "Wcirc;": "\u0174", - "Wedge;": "\u22c0", - "Wfr;": "\U0001d51a", - "Wopf;": "\U0001d54e", - "Wscr;": "\U0001d4b2", - "Xfr;": "\U0001d51b", - "Xi;": "\u039e", - "Xopf;": "\U0001d54f", - "Xscr;": "\U0001d4b3", - "YAcy;": "\u042f", - "YIcy;": "\u0407", - "YUcy;": "\u042e", - "Yacute": "\xdd", - "Yacute;": "\xdd", - "Ycirc;": "\u0176", - "Ycy;": "\u042b", - "Yfr;": "\U0001d51c", - "Yopf;": "\U0001d550", - "Yscr;": "\U0001d4b4", - "Yuml;": "\u0178", - "ZHcy;": "\u0416", - "Zacute;": "\u0179", - "Zcaron;": "\u017d", - "Zcy;": "\u0417", - "Zdot;": "\u017b", - "ZeroWidthSpace;": "\u200b", - "Zeta;": "\u0396", - "Zfr;": "\u2128", - "Zopf;": "\u2124", - "Zscr;": "\U0001d4b5", - "aacute": "\xe1", - "aacute;": "\xe1", - "abreve;": "\u0103", - "ac;": "\u223e", - "acE;": "\u223e\u0333", - "acd;": "\u223f", - "acirc": "\xe2", - "acirc;": "\xe2", - "acute": "\xb4", - "acute;": "\xb4", - "acy;": "\u0430", - "aelig": "\xe6", - "aelig;": "\xe6", - "af;": "\u2061", - "afr;": "\U0001d51e", - "agrave": "\xe0", - "agrave;": "\xe0", - "alefsym;": "\u2135", - "aleph;": "\u2135", - "alpha;": "\u03b1", - "amacr;": "\u0101", - "amalg;": "\u2a3f", - "amp": "&", - "amp;": "&", - "and;": "\u2227", - "andand;": "\u2a55", - "andd;": "\u2a5c", - "andslope;": "\u2a58", - "andv;": "\u2a5a", - "ang;": "\u2220", - "ange;": "\u29a4", - "angle;": "\u2220", - "angmsd;": "\u2221", - "angmsdaa;": "\u29a8", - "angmsdab;": "\u29a9", - "angmsdac;": "\u29aa", - "angmsdad;": "\u29ab", - "angmsdae;": "\u29ac", - "angmsdaf;": "\u29ad", - "angmsdag;": "\u29ae", - "angmsdah;": "\u29af", - "angrt;": "\u221f", - "angrtvb;": "\u22be", - "angrtvbd;": "\u299d", - "angsph;": "\u2222", - "angst;": "\xc5", - "angzarr;": "\u237c", - "aogon;": "\u0105", - "aopf;": "\U0001d552", - "ap;": "\u2248", - "apE;": "\u2a70", - "apacir;": "\u2a6f", - "ape;": "\u224a", - "apid;": "\u224b", - "apos;": "'", - "approx;": "\u2248", - "approxeq;": "\u224a", - "aring": "\xe5", - "aring;": "\xe5", - "ascr;": "\U0001d4b6", - "ast;": "*", - "asymp;": "\u2248", - "asympeq;": "\u224d", - "atilde": "\xe3", - "atilde;": "\xe3", - "auml": "\xe4", - "auml;": "\xe4", - "awconint;": "\u2233", - "awint;": "\u2a11", - "bNot;": "\u2aed", - "backcong;": "\u224c", - "backepsilon;": "\u03f6", - "backprime;": "\u2035", - "backsim;": "\u223d", - "backsimeq;": "\u22cd", - "barvee;": "\u22bd", - "barwed;": "\u2305", - "barwedge;": "\u2305", - "bbrk;": "\u23b5", - "bbrktbrk;": "\u23b6", - "bcong;": "\u224c", - "bcy;": "\u0431", - "bdquo;": "\u201e", - "becaus;": "\u2235", - "because;": "\u2235", - "bemptyv;": "\u29b0", - "bepsi;": "\u03f6", - "bernou;": "\u212c", - "beta;": "\u03b2", - "beth;": "\u2136", - "between;": "\u226c", - "bfr;": "\U0001d51f", - "bigcap;": "\u22c2", - "bigcirc;": "\u25ef", - "bigcup;": "\u22c3", - "bigodot;": "\u2a00", - "bigoplus;": "\u2a01", - "bigotimes;": "\u2a02", - "bigsqcup;": "\u2a06", - "bigstar;": "\u2605", - "bigtriangledown;": "\u25bd", - "bigtriangleup;": "\u25b3", - "biguplus;": "\u2a04", - "bigvee;": "\u22c1", - "bigwedge;": "\u22c0", - "bkarow;": "\u290d", - "blacklozenge;": "\u29eb", - "blacksquare;": "\u25aa", - "blacktriangle;": "\u25b4", - "blacktriangledown;": "\u25be", - "blacktriangleleft;": "\u25c2", - "blacktriangleright;": "\u25b8", - "blank;": "\u2423", - "blk12;": "\u2592", - "blk14;": "\u2591", - "blk34;": "\u2593", - "block;": "\u2588", - "bne;": "=\u20e5", - "bnequiv;": "\u2261\u20e5", - "bnot;": "\u2310", - "bopf;": "\U0001d553", - "bot;": "\u22a5", - "bottom;": "\u22a5", - "bowtie;": "\u22c8", - "boxDL;": "\u2557", - "boxDR;": "\u2554", - "boxDl;": "\u2556", - "boxDr;": "\u2553", - "boxH;": "\u2550", - "boxHD;": "\u2566", - "boxHU;": "\u2569", - "boxHd;": "\u2564", - "boxHu;": "\u2567", - "boxUL;": "\u255d", - "boxUR;": "\u255a", - "boxUl;": "\u255c", - "boxUr;": "\u2559", - "boxV;": "\u2551", - "boxVH;": "\u256c", - "boxVL;": "\u2563", - "boxVR;": "\u2560", - "boxVh;": "\u256b", - "boxVl;": "\u2562", - "boxVr;": "\u255f", - "boxbox;": "\u29c9", - "boxdL;": "\u2555", - "boxdR;": "\u2552", - "boxdl;": "\u2510", - "boxdr;": "\u250c", - "boxh;": "\u2500", - "boxhD;": "\u2565", - "boxhU;": "\u2568", - "boxhd;": "\u252c", - "boxhu;": "\u2534", - "boxminus;": "\u229f", - "boxplus;": "\u229e", - "boxtimes;": "\u22a0", - "boxuL;": "\u255b", - "boxuR;": "\u2558", - "boxul;": "\u2518", - "boxur;": "\u2514", - "boxv;": "\u2502", - "boxvH;": "\u256a", - "boxvL;": "\u2561", - "boxvR;": "\u255e", - "boxvh;": "\u253c", - "boxvl;": "\u2524", - "boxvr;": "\u251c", - "bprime;": "\u2035", - "breve;": "\u02d8", - "brvbar": "\xa6", - "brvbar;": "\xa6", - "bscr;": "\U0001d4b7", - "bsemi;": "\u204f", - "bsim;": "\u223d", - "bsime;": "\u22cd", - "bsol;": "\\", - "bsolb;": "\u29c5", - "bsolhsub;": "\u27c8", - "bull;": "\u2022", - "bullet;": "\u2022", - "bump;": "\u224e", - "bumpE;": "\u2aae", - "bumpe;": "\u224f", - "bumpeq;": "\u224f", - "cacute;": "\u0107", - "cap;": "\u2229", - "capand;": "\u2a44", - "capbrcup;": "\u2a49", - "capcap;": "\u2a4b", - "capcup;": "\u2a47", - "capdot;": "\u2a40", - "caps;": "\u2229\ufe00", - "caret;": "\u2041", - "caron;": "\u02c7", - "ccaps;": "\u2a4d", - "ccaron;": "\u010d", - "ccedil": "\xe7", - "ccedil;": "\xe7", - "ccirc;": "\u0109", - "ccups;": "\u2a4c", - "ccupssm;": "\u2a50", - "cdot;": "\u010b", - "cedil": "\xb8", - "cedil;": "\xb8", - "cemptyv;": "\u29b2", - "cent": "\xa2", - "cent;": "\xa2", - "centerdot;": "\xb7", - "cfr;": "\U0001d520", - "chcy;": "\u0447", - "check;": "\u2713", - "checkmark;": "\u2713", - "chi;": "\u03c7", - "cir;": "\u25cb", - "cirE;": "\u29c3", - "circ;": "\u02c6", - "circeq;": "\u2257", - "circlearrowleft;": "\u21ba", - "circlearrowright;": "\u21bb", - "circledR;": "\xae", - "circledS;": "\u24c8", - "circledast;": "\u229b", - "circledcirc;": "\u229a", - "circleddash;": "\u229d", - "cire;": "\u2257", - "cirfnint;": "\u2a10", - "cirmid;": "\u2aef", - "cirscir;": "\u29c2", - "clubs;": "\u2663", - "clubsuit;": "\u2663", - "colon;": ":", - "colone;": "\u2254", - "coloneq;": "\u2254", - "comma;": ",", - "commat;": "@", - "comp;": "\u2201", - "compfn;": "\u2218", - "complement;": "\u2201", - "complexes;": "\u2102", - "cong;": "\u2245", - "congdot;": "\u2a6d", - "conint;": "\u222e", - "copf;": "\U0001d554", - "coprod;": "\u2210", - "copy": "\xa9", - "copy;": "\xa9", - "copysr;": "\u2117", - "crarr;": "\u21b5", - "cross;": "\u2717", - "cscr;": "\U0001d4b8", - "csub;": "\u2acf", - "csube;": "\u2ad1", - "csup;": "\u2ad0", - "csupe;": "\u2ad2", - "ctdot;": "\u22ef", - "cudarrl;": "\u2938", - "cudarrr;": "\u2935", - "cuepr;": "\u22de", - "cuesc;": "\u22df", - "cularr;": "\u21b6", - "cularrp;": "\u293d", - "cup;": "\u222a", - "cupbrcap;": "\u2a48", - "cupcap;": "\u2a46", - "cupcup;": "\u2a4a", - "cupdot;": "\u228d", - "cupor;": "\u2a45", - "cups;": "\u222a\ufe00", - "curarr;": "\u21b7", - "curarrm;": "\u293c", - "curlyeqprec;": "\u22de", - "curlyeqsucc;": "\u22df", - "curlyvee;": "\u22ce", - "curlywedge;": "\u22cf", - "curren": "\xa4", - "curren;": "\xa4", - "curvearrowleft;": "\u21b6", - "curvearrowright;": "\u21b7", - "cuvee;": "\u22ce", - "cuwed;": "\u22cf", - "cwconint;": "\u2232", - "cwint;": "\u2231", - "cylcty;": "\u232d", - "dArr;": "\u21d3", - "dHar;": "\u2965", - "dagger;": "\u2020", - "daleth;": "\u2138", - "darr;": "\u2193", - "dash;": "\u2010", - "dashv;": "\u22a3", - "dbkarow;": "\u290f", - "dblac;": "\u02dd", - "dcaron;": "\u010f", - "dcy;": "\u0434", - "dd;": "\u2146", - "ddagger;": "\u2021", - "ddarr;": "\u21ca", - "ddotseq;": "\u2a77", - "deg": "\xb0", - "deg;": "\xb0", - "delta;": "\u03b4", - "demptyv;": "\u29b1", - "dfisht;": "\u297f", - "dfr;": "\U0001d521", - "dharl;": "\u21c3", - "dharr;": "\u21c2", - "diam;": "\u22c4", - "diamond;": "\u22c4", - "diamondsuit;": "\u2666", - "diams;": "\u2666", - "die;": "\xa8", - "digamma;": "\u03dd", - "disin;": "\u22f2", - "div;": "\xf7", - "divide": "\xf7", - "divide;": "\xf7", - "divideontimes;": "\u22c7", - "divonx;": "\u22c7", - "djcy;": "\u0452", - "dlcorn;": "\u231e", - "dlcrop;": "\u230d", - "dollar;": "$", - "dopf;": "\U0001d555", - "dot;": "\u02d9", - "doteq;": "\u2250", - "doteqdot;": "\u2251", - "dotminus;": "\u2238", - "dotplus;": "\u2214", - "dotsquare;": "\u22a1", - "doublebarwedge;": "\u2306", - "downarrow;": "\u2193", - "downdownarrows;": "\u21ca", - "downharpoonleft;": "\u21c3", - "downharpoonright;": "\u21c2", - "drbkarow;": "\u2910", - "drcorn;": "\u231f", - "drcrop;": "\u230c", - "dscr;": "\U0001d4b9", - "dscy;": "\u0455", - "dsol;": "\u29f6", - "dstrok;": "\u0111", - "dtdot;": "\u22f1", - "dtri;": "\u25bf", - "dtrif;": "\u25be", - "duarr;": "\u21f5", - "duhar;": "\u296f", - "dwangle;": "\u29a6", - "dzcy;": "\u045f", - "dzigrarr;": "\u27ff", - "eDDot;": "\u2a77", - "eDot;": "\u2251", - "eacute": "\xe9", - "eacute;": "\xe9", - "easter;": "\u2a6e", - "ecaron;": "\u011b", - "ecir;": "\u2256", - "ecirc": "\xea", - "ecirc;": "\xea", - "ecolon;": "\u2255", - "ecy;": "\u044d", - "edot;": "\u0117", - "ee;": "\u2147", - "efDot;": "\u2252", - "efr;": "\U0001d522", - "eg;": "\u2a9a", - "egrave": "\xe8", - "egrave;": "\xe8", - "egs;": "\u2a96", - "egsdot;": "\u2a98", - "el;": "\u2a99", - "elinters;": "\u23e7", - "ell;": "\u2113", - "els;": "\u2a95", - "elsdot;": "\u2a97", - "emacr;": "\u0113", - "empty;": "\u2205", - "emptyset;": "\u2205", - "emptyv;": "\u2205", - "emsp13;": "\u2004", - "emsp14;": "\u2005", - "emsp;": "\u2003", - "eng;": "\u014b", - "ensp;": "\u2002", - "eogon;": "\u0119", - "eopf;": "\U0001d556", - "epar;": "\u22d5", - "eparsl;": "\u29e3", - "eplus;": "\u2a71", - "epsi;": "\u03b5", - "epsilon;": "\u03b5", - "epsiv;": "\u03f5", - "eqcirc;": "\u2256", - "eqcolon;": "\u2255", - "eqsim;": "\u2242", - "eqslantgtr;": "\u2a96", - "eqslantless;": "\u2a95", - "equals;": "=", - "equest;": "\u225f", - "equiv;": "\u2261", - "equivDD;": "\u2a78", - "eqvparsl;": "\u29e5", - "erDot;": "\u2253", - "erarr;": "\u2971", - "escr;": "\u212f", - "esdot;": "\u2250", - "esim;": "\u2242", - "eta;": "\u03b7", - "eth": "\xf0", - "eth;": "\xf0", - "euml": "\xeb", - "euml;": "\xeb", - "euro;": "\u20ac", - "excl;": "!", - "exist;": "\u2203", - "expectation;": "\u2130", - "exponentiale;": "\u2147", - "fallingdotseq;": "\u2252", - "fcy;": "\u0444", - "female;": "\u2640", - "ffilig;": "\ufb03", - "fflig;": "\ufb00", - "ffllig;": "\ufb04", - "ffr;": "\U0001d523", - "filig;": "\ufb01", - "fjlig;": "fj", - "flat;": "\u266d", - "fllig;": "\ufb02", - "fltns;": "\u25b1", - "fnof;": "\u0192", - "fopf;": "\U0001d557", - "forall;": "\u2200", - "fork;": "\u22d4", - "forkv;": "\u2ad9", - "fpartint;": "\u2a0d", - "frac12": "\xbd", - "frac12;": "\xbd", - "frac13;": "\u2153", - "frac14": "\xbc", - "frac14;": "\xbc", - "frac15;": "\u2155", - "frac16;": "\u2159", - "frac18;": "\u215b", - "frac23;": "\u2154", - "frac25;": "\u2156", - "frac34": "\xbe", - "frac34;": "\xbe", - "frac35;": "\u2157", - "frac38;": "\u215c", - "frac45;": "\u2158", - "frac56;": "\u215a", - "frac58;": "\u215d", - "frac78;": "\u215e", - "frasl;": "\u2044", - "frown;": "\u2322", - "fscr;": "\U0001d4bb", - "gE;": "\u2267", - "gEl;": "\u2a8c", - "gacute;": "\u01f5", - "gamma;": "\u03b3", - "gammad;": "\u03dd", - "gap;": "\u2a86", - "gbreve;": "\u011f", - "gcirc;": "\u011d", - "gcy;": "\u0433", - "gdot;": "\u0121", - "ge;": "\u2265", - "gel;": "\u22db", - "geq;": "\u2265", - "geqq;": "\u2267", - "geqslant;": "\u2a7e", - "ges;": "\u2a7e", - "gescc;": "\u2aa9", - "gesdot;": "\u2a80", - "gesdoto;": "\u2a82", - "gesdotol;": "\u2a84", - "gesl;": "\u22db\ufe00", - "gesles;": "\u2a94", - "gfr;": "\U0001d524", - "gg;": "\u226b", - "ggg;": "\u22d9", - "gimel;": "\u2137", - "gjcy;": "\u0453", - "gl;": "\u2277", - "glE;": "\u2a92", - "gla;": "\u2aa5", - "glj;": "\u2aa4", - "gnE;": "\u2269", - "gnap;": "\u2a8a", - "gnapprox;": "\u2a8a", - "gne;": "\u2a88", - "gneq;": "\u2a88", - "gneqq;": "\u2269", - "gnsim;": "\u22e7", - "gopf;": "\U0001d558", - "grave;": "`", - "gscr;": "\u210a", - "gsim;": "\u2273", - "gsime;": "\u2a8e", - "gsiml;": "\u2a90", - "gt": ">", - "gt;": ">", - "gtcc;": "\u2aa7", - "gtcir;": "\u2a7a", - "gtdot;": "\u22d7", - "gtlPar;": "\u2995", - "gtquest;": "\u2a7c", - "gtrapprox;": "\u2a86", - "gtrarr;": "\u2978", - "gtrdot;": "\u22d7", - "gtreqless;": "\u22db", - "gtreqqless;": "\u2a8c", - "gtrless;": "\u2277", - "gtrsim;": "\u2273", - "gvertneqq;": "\u2269\ufe00", - "gvnE;": "\u2269\ufe00", - "hArr;": "\u21d4", - "hairsp;": "\u200a", - "half;": "\xbd", - "hamilt;": "\u210b", - "hardcy;": "\u044a", - "harr;": "\u2194", - "harrcir;": "\u2948", - "harrw;": "\u21ad", - "hbar;": "\u210f", - "hcirc;": "\u0125", - "hearts;": "\u2665", - "heartsuit;": "\u2665", - "hellip;": "\u2026", - "hercon;": "\u22b9", - "hfr;": "\U0001d525", - "hksearow;": "\u2925", - "hkswarow;": "\u2926", - "hoarr;": "\u21ff", - "homtht;": "\u223b", - "hookleftarrow;": "\u21a9", - "hookrightarrow;": "\u21aa", - "hopf;": "\U0001d559", - "horbar;": "\u2015", - "hscr;": "\U0001d4bd", - "hslash;": "\u210f", - "hstrok;": "\u0127", - "hybull;": "\u2043", - "hyphen;": "\u2010", - "iacute": "\xed", - "iacute;": "\xed", - "ic;": "\u2063", - "icirc": "\xee", - "icirc;": "\xee", - "icy;": "\u0438", - "iecy;": "\u0435", - "iexcl": "\xa1", - "iexcl;": "\xa1", - "iff;": "\u21d4", - "ifr;": "\U0001d526", - "igrave": "\xec", - "igrave;": "\xec", - "ii;": "\u2148", - "iiiint;": "\u2a0c", - "iiint;": "\u222d", - "iinfin;": "\u29dc", - "iiota;": "\u2129", - "ijlig;": "\u0133", - "imacr;": "\u012b", - "image;": "\u2111", - "imagline;": "\u2110", - "imagpart;": "\u2111", - "imath;": "\u0131", - "imof;": "\u22b7", - "imped;": "\u01b5", - "in;": "\u2208", - "incare;": "\u2105", - "infin;": "\u221e", - "infintie;": "\u29dd", - "inodot;": "\u0131", - "int;": "\u222b", - "intcal;": "\u22ba", - "integers;": "\u2124", - "intercal;": "\u22ba", - "intlarhk;": "\u2a17", - "intprod;": "\u2a3c", - "iocy;": "\u0451", - "iogon;": "\u012f", - "iopf;": "\U0001d55a", - "iota;": "\u03b9", - "iprod;": "\u2a3c", - "iquest": "\xbf", - "iquest;": "\xbf", - "iscr;": "\U0001d4be", - "isin;": "\u2208", - "isinE;": "\u22f9", - "isindot;": "\u22f5", - "isins;": "\u22f4", - "isinsv;": "\u22f3", - "isinv;": "\u2208", - "it;": "\u2062", - "itilde;": "\u0129", - "iukcy;": "\u0456", - "iuml": "\xef", - "iuml;": "\xef", - "jcirc;": "\u0135", - "jcy;": "\u0439", - "jfr;": "\U0001d527", - "jmath;": "\u0237", - "jopf;": "\U0001d55b", - "jscr;": "\U0001d4bf", - "jsercy;": "\u0458", - "jukcy;": "\u0454", - "kappa;": "\u03ba", - "kappav;": "\u03f0", - "kcedil;": "\u0137", - "kcy;": "\u043a", - "kfr;": "\U0001d528", - "kgreen;": "\u0138", - "khcy;": "\u0445", - "kjcy;": "\u045c", - "kopf;": "\U0001d55c", - "kscr;": "\U0001d4c0", - "lAarr;": "\u21da", - "lArr;": "\u21d0", - "lAtail;": "\u291b", - "lBarr;": "\u290e", - "lE;": "\u2266", - "lEg;": "\u2a8b", - "lHar;": "\u2962", - "lacute;": "\u013a", - "laemptyv;": "\u29b4", - "lagran;": "\u2112", - "lambda;": "\u03bb", - "lang;": "\u27e8", - "langd;": "\u2991", - "langle;": "\u27e8", - "lap;": "\u2a85", - "laquo": "\xab", - "laquo;": "\xab", - "larr;": "\u2190", - "larrb;": "\u21e4", - "larrbfs;": "\u291f", - "larrfs;": "\u291d", - "larrhk;": "\u21a9", - "larrlp;": "\u21ab", - "larrpl;": "\u2939", - "larrsim;": "\u2973", - "larrtl;": "\u21a2", - "lat;": "\u2aab", - "latail;": "\u2919", - "late;": "\u2aad", - "lates;": "\u2aad\ufe00", - "lbarr;": "\u290c", - "lbbrk;": "\u2772", - "lbrace;": "{", - "lbrack;": "[", - "lbrke;": "\u298b", - "lbrksld;": "\u298f", - "lbrkslu;": "\u298d", - "lcaron;": "\u013e", - "lcedil;": "\u013c", - "lceil;": "\u2308", - "lcub;": "{", - "lcy;": "\u043b", - "ldca;": "\u2936", - "ldquo;": "\u201c", - "ldquor;": "\u201e", - "ldrdhar;": "\u2967", - "ldrushar;": "\u294b", - "ldsh;": "\u21b2", - "le;": "\u2264", - "leftarrow;": "\u2190", - "leftarrowtail;": "\u21a2", - "leftharpoondown;": "\u21bd", - "leftharpoonup;": "\u21bc", - "leftleftarrows;": "\u21c7", - "leftrightarrow;": "\u2194", - "leftrightarrows;": "\u21c6", - "leftrightharpoons;": "\u21cb", - "leftrightsquigarrow;": "\u21ad", - "leftthreetimes;": "\u22cb", - "leg;": "\u22da", - "leq;": "\u2264", - "leqq;": "\u2266", - "leqslant;": "\u2a7d", - "les;": "\u2a7d", - "lescc;": "\u2aa8", - "lesdot;": "\u2a7f", - "lesdoto;": "\u2a81", - "lesdotor;": "\u2a83", - "lesg;": "\u22da\ufe00", - "lesges;": "\u2a93", - "lessapprox;": "\u2a85", - "lessdot;": "\u22d6", - "lesseqgtr;": "\u22da", - "lesseqqgtr;": "\u2a8b", - "lessgtr;": "\u2276", - "lesssim;": "\u2272", - "lfisht;": "\u297c", - "lfloor;": "\u230a", - "lfr;": "\U0001d529", - "lg;": "\u2276", - "lgE;": "\u2a91", - "lhard;": "\u21bd", - "lharu;": "\u21bc", - "lharul;": "\u296a", - "lhblk;": "\u2584", - "ljcy;": "\u0459", - "ll;": "\u226a", - "llarr;": "\u21c7", - "llcorner;": "\u231e", - "llhard;": "\u296b", - "lltri;": "\u25fa", - "lmidot;": "\u0140", - "lmoust;": "\u23b0", - "lmoustache;": "\u23b0", - "lnE;": "\u2268", - "lnap;": "\u2a89", - "lnapprox;": "\u2a89", - "lne;": "\u2a87", - "lneq;": "\u2a87", - "lneqq;": "\u2268", - "lnsim;": "\u22e6", - "loang;": "\u27ec", - "loarr;": "\u21fd", - "lobrk;": "\u27e6", - "longleftarrow;": "\u27f5", - "longleftrightarrow;": "\u27f7", - "longmapsto;": "\u27fc", - "longrightarrow;": "\u27f6", - "looparrowleft;": "\u21ab", - "looparrowright;": "\u21ac", - "lopar;": "\u2985", - "lopf;": "\U0001d55d", - "loplus;": "\u2a2d", - "lotimes;": "\u2a34", - "lowast;": "\u2217", - "lowbar;": "_", - "loz;": "\u25ca", - "lozenge;": "\u25ca", - "lozf;": "\u29eb", - "lpar;": "(", - "lparlt;": "\u2993", - "lrarr;": "\u21c6", - "lrcorner;": "\u231f", - "lrhar;": "\u21cb", - "lrhard;": "\u296d", - "lrm;": "\u200e", - "lrtri;": "\u22bf", - "lsaquo;": "\u2039", - "lscr;": "\U0001d4c1", - "lsh;": "\u21b0", - "lsim;": "\u2272", - "lsime;": "\u2a8d", - "lsimg;": "\u2a8f", - "lsqb;": "[", - "lsquo;": "\u2018", - "lsquor;": "\u201a", - "lstrok;": "\u0142", - "lt": "<", - "lt;": "<", - "ltcc;": "\u2aa6", - "ltcir;": "\u2a79", - "ltdot;": "\u22d6", - "lthree;": "\u22cb", - "ltimes;": "\u22c9", - "ltlarr;": "\u2976", - "ltquest;": "\u2a7b", - "ltrPar;": "\u2996", - "ltri;": "\u25c3", - "ltrie;": "\u22b4", - "ltrif;": "\u25c2", - "lurdshar;": "\u294a", - "luruhar;": "\u2966", - "lvertneqq;": "\u2268\ufe00", - "lvnE;": "\u2268\ufe00", - "mDDot;": "\u223a", - "macr": "\xaf", - "macr;": "\xaf", - "male;": "\u2642", - "malt;": "\u2720", - "maltese;": "\u2720", - "map;": "\u21a6", - "mapsto;": "\u21a6", - "mapstodown;": "\u21a7", - "mapstoleft;": "\u21a4", - "mapstoup;": "\u21a5", - "marker;": "\u25ae", - "mcomma;": "\u2a29", - "mcy;": "\u043c", - "mdash;": "\u2014", - "measuredangle;": "\u2221", - "mfr;": "\U0001d52a", - "mho;": "\u2127", - "micro": "\xb5", - "micro;": "\xb5", - "mid;": "\u2223", - "midast;": "*", - "midcir;": "\u2af0", - "middot": "\xb7", - "middot;": "\xb7", - "minus;": "\u2212", - "minusb;": "\u229f", - "minusd;": "\u2238", - "minusdu;": "\u2a2a", - "mlcp;": "\u2adb", - "mldr;": "\u2026", - "mnplus;": "\u2213", - "models;": "\u22a7", - "mopf;": "\U0001d55e", - "mp;": "\u2213", - "mscr;": "\U0001d4c2", - "mstpos;": "\u223e", - "mu;": "\u03bc", - "multimap;": "\u22b8", - "mumap;": "\u22b8", - "nGg;": "\u22d9\u0338", - "nGt;": "\u226b\u20d2", - "nGtv;": "\u226b\u0338", - "nLeftarrow;": "\u21cd", - "nLeftrightarrow;": "\u21ce", - "nLl;": "\u22d8\u0338", - "nLt;": "\u226a\u20d2", - "nLtv;": "\u226a\u0338", - "nRightarrow;": "\u21cf", - "nVDash;": "\u22af", - "nVdash;": "\u22ae", - "nabla;": "\u2207", - "nacute;": "\u0144", - "nang;": "\u2220\u20d2", - "nap;": "\u2249", - "napE;": "\u2a70\u0338", - "napid;": "\u224b\u0338", - "napos;": "\u0149", - "napprox;": "\u2249", - "natur;": "\u266e", - "natural;": "\u266e", - "naturals;": "\u2115", - "nbsp": "\xa0", - "nbsp;": "\xa0", - "nbump;": "\u224e\u0338", - "nbumpe;": "\u224f\u0338", - "ncap;": "\u2a43", - "ncaron;": "\u0148", - "ncedil;": "\u0146", - "ncong;": "\u2247", - "ncongdot;": "\u2a6d\u0338", - "ncup;": "\u2a42", - "ncy;": "\u043d", - "ndash;": "\u2013", - "ne;": "\u2260", - "neArr;": "\u21d7", - "nearhk;": "\u2924", - "nearr;": "\u2197", - "nearrow;": "\u2197", - "nedot;": "\u2250\u0338", - "nequiv;": "\u2262", - "nesear;": "\u2928", - "nesim;": "\u2242\u0338", - "nexist;": "\u2204", - "nexists;": "\u2204", - "nfr;": "\U0001d52b", - "ngE;": "\u2267\u0338", - "nge;": "\u2271", - "ngeq;": "\u2271", - "ngeqq;": "\u2267\u0338", - "ngeqslant;": "\u2a7e\u0338", - "nges;": "\u2a7e\u0338", - "ngsim;": "\u2275", - "ngt;": "\u226f", - "ngtr;": "\u226f", - "nhArr;": "\u21ce", - "nharr;": "\u21ae", - "nhpar;": "\u2af2", - "ni;": "\u220b", - "nis;": "\u22fc", - "nisd;": "\u22fa", - "niv;": "\u220b", - "njcy;": "\u045a", - "nlArr;": "\u21cd", - "nlE;": "\u2266\u0338", - "nlarr;": "\u219a", - "nldr;": "\u2025", - "nle;": "\u2270", - "nleftarrow;": "\u219a", - "nleftrightarrow;": "\u21ae", - "nleq;": "\u2270", - "nleqq;": "\u2266\u0338", - "nleqslant;": "\u2a7d\u0338", - "nles;": "\u2a7d\u0338", - "nless;": "\u226e", - "nlsim;": "\u2274", - "nlt;": "\u226e", - "nltri;": "\u22ea", - "nltrie;": "\u22ec", - "nmid;": "\u2224", - "nopf;": "\U0001d55f", - "not": "\xac", - "not;": "\xac", - "notin;": "\u2209", - "notinE;": "\u22f9\u0338", - "notindot;": "\u22f5\u0338", - "notinva;": "\u2209", - "notinvb;": "\u22f7", - "notinvc;": "\u22f6", - "notni;": "\u220c", - "notniva;": "\u220c", - "notnivb;": "\u22fe", - "notnivc;": "\u22fd", - "npar;": "\u2226", - "nparallel;": "\u2226", - "nparsl;": "\u2afd\u20e5", - "npart;": "\u2202\u0338", - "npolint;": "\u2a14", - "npr;": "\u2280", - "nprcue;": "\u22e0", - "npre;": "\u2aaf\u0338", - "nprec;": "\u2280", - "npreceq;": "\u2aaf\u0338", - "nrArr;": "\u21cf", - "nrarr;": "\u219b", - "nrarrc;": "\u2933\u0338", - "nrarrw;": "\u219d\u0338", - "nrightarrow;": "\u219b", - "nrtri;": "\u22eb", - "nrtrie;": "\u22ed", - "nsc;": "\u2281", - "nsccue;": "\u22e1", - "nsce;": "\u2ab0\u0338", - "nscr;": "\U0001d4c3", - "nshortmid;": "\u2224", - "nshortparallel;": "\u2226", - "nsim;": "\u2241", - "nsime;": "\u2244", - "nsimeq;": "\u2244", - "nsmid;": "\u2224", - "nspar;": "\u2226", - "nsqsube;": "\u22e2", - "nsqsupe;": "\u22e3", - "nsub;": "\u2284", - "nsubE;": "\u2ac5\u0338", - "nsube;": "\u2288", - "nsubset;": "\u2282\u20d2", - "nsubseteq;": "\u2288", - "nsubseteqq;": "\u2ac5\u0338", - "nsucc;": "\u2281", - "nsucceq;": "\u2ab0\u0338", - "nsup;": "\u2285", - "nsupE;": "\u2ac6\u0338", - "nsupe;": "\u2289", - "nsupset;": "\u2283\u20d2", - "nsupseteq;": "\u2289", - "nsupseteqq;": "\u2ac6\u0338", - "ntgl;": "\u2279", - "ntilde": "\xf1", - "ntilde;": "\xf1", - "ntlg;": "\u2278", - "ntriangleleft;": "\u22ea", - "ntrianglelefteq;": "\u22ec", - "ntriangleright;": "\u22eb", - "ntrianglerighteq;": "\u22ed", - "nu;": "\u03bd", - "num;": "#", - "numero;": "\u2116", - "numsp;": "\u2007", - "nvDash;": "\u22ad", - "nvHarr;": "\u2904", - "nvap;": "\u224d\u20d2", - "nvdash;": "\u22ac", - "nvge;": "\u2265\u20d2", - "nvgt;": ">\u20d2", - "nvinfin;": "\u29de", - "nvlArr;": "\u2902", - "nvle;": "\u2264\u20d2", - "nvlt;": "<\u20d2", - "nvltrie;": "\u22b4\u20d2", - "nvrArr;": "\u2903", - "nvrtrie;": "\u22b5\u20d2", - "nvsim;": "\u223c\u20d2", - "nwArr;": "\u21d6", - "nwarhk;": "\u2923", - "nwarr;": "\u2196", - "nwarrow;": "\u2196", - "nwnear;": "\u2927", - "oS;": "\u24c8", - "oacute": "\xf3", - "oacute;": "\xf3", - "oast;": "\u229b", - "ocir;": "\u229a", - "ocirc": "\xf4", - "ocirc;": "\xf4", - "ocy;": "\u043e", - "odash;": "\u229d", - "odblac;": "\u0151", - "odiv;": "\u2a38", - "odot;": "\u2299", - "odsold;": "\u29bc", - "oelig;": "\u0153", - "ofcir;": "\u29bf", - "ofr;": "\U0001d52c", - "ogon;": "\u02db", - "ograve": "\xf2", - "ograve;": "\xf2", - "ogt;": "\u29c1", - "ohbar;": "\u29b5", - "ohm;": "\u03a9", - "oint;": "\u222e", - "olarr;": "\u21ba", - "olcir;": "\u29be", - "olcross;": "\u29bb", - "oline;": "\u203e", - "olt;": "\u29c0", - "omacr;": "\u014d", - "omega;": "\u03c9", - "omicron;": "\u03bf", - "omid;": "\u29b6", - "ominus;": "\u2296", - "oopf;": "\U0001d560", - "opar;": "\u29b7", - "operp;": "\u29b9", - "oplus;": "\u2295", - "or;": "\u2228", - "orarr;": "\u21bb", - "ord;": "\u2a5d", - "order;": "\u2134", - "orderof;": "\u2134", - "ordf": "\xaa", - "ordf;": "\xaa", - "ordm": "\xba", - "ordm;": "\xba", - "origof;": "\u22b6", - "oror;": "\u2a56", - "orslope;": "\u2a57", - "orv;": "\u2a5b", - "oscr;": "\u2134", - "oslash": "\xf8", - "oslash;": "\xf8", - "osol;": "\u2298", - "otilde": "\xf5", - "otilde;": "\xf5", - "otimes;": "\u2297", - "otimesas;": "\u2a36", - "ouml": "\xf6", - "ouml;": "\xf6", - "ovbar;": "\u233d", - "par;": "\u2225", - "para": "\xb6", - "para;": "\xb6", - "parallel;": "\u2225", - "parsim;": "\u2af3", - "parsl;": "\u2afd", - "part;": "\u2202", - "pcy;": "\u043f", - "percnt;": "%", - "period;": ".", - "permil;": "\u2030", - "perp;": "\u22a5", - "pertenk;": "\u2031", - "pfr;": "\U0001d52d", - "phi;": "\u03c6", - "phiv;": "\u03d5", - "phmmat;": "\u2133", - "phone;": "\u260e", - "pi;": "\u03c0", - "pitchfork;": "\u22d4", - "piv;": "\u03d6", - "planck;": "\u210f", - "planckh;": "\u210e", - "plankv;": "\u210f", - "plus;": "+", - "plusacir;": "\u2a23", - "plusb;": "\u229e", - "pluscir;": "\u2a22", - "plusdo;": "\u2214", - "plusdu;": "\u2a25", - "pluse;": "\u2a72", - "plusmn": "\xb1", - "plusmn;": "\xb1", - "plussim;": "\u2a26", - "plustwo;": "\u2a27", - "pm;": "\xb1", - "pointint;": "\u2a15", - "popf;": "\U0001d561", - "pound": "\xa3", - "pound;": "\xa3", - "pr;": "\u227a", - "prE;": "\u2ab3", - "prap;": "\u2ab7", - "prcue;": "\u227c", - "pre;": "\u2aaf", - "prec;": "\u227a", - "precapprox;": "\u2ab7", - "preccurlyeq;": "\u227c", - "preceq;": "\u2aaf", - "precnapprox;": "\u2ab9", - "precneqq;": "\u2ab5", - "precnsim;": "\u22e8", - "precsim;": "\u227e", - "prime;": "\u2032", - "primes;": "\u2119", - "prnE;": "\u2ab5", - "prnap;": "\u2ab9", - "prnsim;": "\u22e8", - "prod;": "\u220f", - "profalar;": "\u232e", - "profline;": "\u2312", - "profsurf;": "\u2313", - "prop;": "\u221d", - "propto;": "\u221d", - "prsim;": "\u227e", - "prurel;": "\u22b0", - "pscr;": "\U0001d4c5", - "psi;": "\u03c8", - "puncsp;": "\u2008", - "qfr;": "\U0001d52e", - "qint;": "\u2a0c", - "qopf;": "\U0001d562", - "qprime;": "\u2057", - "qscr;": "\U0001d4c6", - "quaternions;": "\u210d", - "quatint;": "\u2a16", - "quest;": "?", - "questeq;": "\u225f", - "quot": "\"", - "quot;": "\"", - "rAarr;": "\u21db", - "rArr;": "\u21d2", - "rAtail;": "\u291c", - "rBarr;": "\u290f", - "rHar;": "\u2964", - "race;": "\u223d\u0331", - "racute;": "\u0155", - "radic;": "\u221a", - "raemptyv;": "\u29b3", - "rang;": "\u27e9", - "rangd;": "\u2992", - "range;": "\u29a5", - "rangle;": "\u27e9", - "raquo": "\xbb", - "raquo;": "\xbb", - "rarr;": "\u2192", - "rarrap;": "\u2975", - "rarrb;": "\u21e5", - "rarrbfs;": "\u2920", - "rarrc;": "\u2933", - "rarrfs;": "\u291e", - "rarrhk;": "\u21aa", - "rarrlp;": "\u21ac", - "rarrpl;": "\u2945", - "rarrsim;": "\u2974", - "rarrtl;": "\u21a3", - "rarrw;": "\u219d", - "ratail;": "\u291a", - "ratio;": "\u2236", - "rationals;": "\u211a", - "rbarr;": "\u290d", - "rbbrk;": "\u2773", - "rbrace;": "}", - "rbrack;": "]", - "rbrke;": "\u298c", - "rbrksld;": "\u298e", - "rbrkslu;": "\u2990", - "rcaron;": "\u0159", - "rcedil;": "\u0157", - "rceil;": "\u2309", - "rcub;": "}", - "rcy;": "\u0440", - "rdca;": "\u2937", - "rdldhar;": "\u2969", - "rdquo;": "\u201d", - "rdquor;": "\u201d", - "rdsh;": "\u21b3", - "real;": "\u211c", - "realine;": "\u211b", - "realpart;": "\u211c", - "reals;": "\u211d", - "rect;": "\u25ad", - "reg": "\xae", - "reg;": "\xae", - "rfisht;": "\u297d", - "rfloor;": "\u230b", - "rfr;": "\U0001d52f", - "rhard;": "\u21c1", - "rharu;": "\u21c0", - "rharul;": "\u296c", - "rho;": "\u03c1", - "rhov;": "\u03f1", - "rightarrow;": "\u2192", - "rightarrowtail;": "\u21a3", - "rightharpoondown;": "\u21c1", - "rightharpoonup;": "\u21c0", - "rightleftarrows;": "\u21c4", - "rightleftharpoons;": "\u21cc", - "rightrightarrows;": "\u21c9", - "rightsquigarrow;": "\u219d", - "rightthreetimes;": "\u22cc", - "ring;": "\u02da", - "risingdotseq;": "\u2253", - "rlarr;": "\u21c4", - "rlhar;": "\u21cc", - "rlm;": "\u200f", - "rmoust;": "\u23b1", - "rmoustache;": "\u23b1", - "rnmid;": "\u2aee", - "roang;": "\u27ed", - "roarr;": "\u21fe", - "robrk;": "\u27e7", - "ropar;": "\u2986", - "ropf;": "\U0001d563", - "roplus;": "\u2a2e", - "rotimes;": "\u2a35", - "rpar;": ")", - "rpargt;": "\u2994", - "rppolint;": "\u2a12", - "rrarr;": "\u21c9", - "rsaquo;": "\u203a", - "rscr;": "\U0001d4c7", - "rsh;": "\u21b1", - "rsqb;": "]", - "rsquo;": "\u2019", - "rsquor;": "\u2019", - "rthree;": "\u22cc", - "rtimes;": "\u22ca", - "rtri;": "\u25b9", - "rtrie;": "\u22b5", - "rtrif;": "\u25b8", - "rtriltri;": "\u29ce", - "ruluhar;": "\u2968", - "rx;": "\u211e", - "sacute;": "\u015b", - "sbquo;": "\u201a", - "sc;": "\u227b", - "scE;": "\u2ab4", - "scap;": "\u2ab8", - "scaron;": "\u0161", - "sccue;": "\u227d", - "sce;": "\u2ab0", - "scedil;": "\u015f", - "scirc;": "\u015d", - "scnE;": "\u2ab6", - "scnap;": "\u2aba", - "scnsim;": "\u22e9", - "scpolint;": "\u2a13", - "scsim;": "\u227f", - "scy;": "\u0441", - "sdot;": "\u22c5", - "sdotb;": "\u22a1", - "sdote;": "\u2a66", - "seArr;": "\u21d8", - "searhk;": "\u2925", - "searr;": "\u2198", - "searrow;": "\u2198", - "sect": "\xa7", - "sect;": "\xa7", - "semi;": ";", - "seswar;": "\u2929", - "setminus;": "\u2216", - "setmn;": "\u2216", - "sext;": "\u2736", - "sfr;": "\U0001d530", - "sfrown;": "\u2322", - "sharp;": "\u266f", - "shchcy;": "\u0449", - "shcy;": "\u0448", - "shortmid;": "\u2223", - "shortparallel;": "\u2225", - "shy": "\xad", - "shy;": "\xad", - "sigma;": "\u03c3", - "sigmaf;": "\u03c2", - "sigmav;": "\u03c2", - "sim;": "\u223c", - "simdot;": "\u2a6a", - "sime;": "\u2243", - "simeq;": "\u2243", - "simg;": "\u2a9e", - "simgE;": "\u2aa0", - "siml;": "\u2a9d", - "simlE;": "\u2a9f", - "simne;": "\u2246", - "simplus;": "\u2a24", - "simrarr;": "\u2972", - "slarr;": "\u2190", - "smallsetminus;": "\u2216", - "smashp;": "\u2a33", - "smeparsl;": "\u29e4", - "smid;": "\u2223", - "smile;": "\u2323", - "smt;": "\u2aaa", - "smte;": "\u2aac", - "smtes;": "\u2aac\ufe00", - "softcy;": "\u044c", - "sol;": "/", - "solb;": "\u29c4", - "solbar;": "\u233f", - "sopf;": "\U0001d564", - "spades;": "\u2660", - "spadesuit;": "\u2660", - "spar;": "\u2225", - "sqcap;": "\u2293", - "sqcaps;": "\u2293\ufe00", - "sqcup;": "\u2294", - "sqcups;": "\u2294\ufe00", - "sqsub;": "\u228f", - "sqsube;": "\u2291", - "sqsubset;": "\u228f", - "sqsubseteq;": "\u2291", - "sqsup;": "\u2290", - "sqsupe;": "\u2292", - "sqsupset;": "\u2290", - "sqsupseteq;": "\u2292", - "squ;": "\u25a1", - "square;": "\u25a1", - "squarf;": "\u25aa", - "squf;": "\u25aa", - "srarr;": "\u2192", - "sscr;": "\U0001d4c8", - "ssetmn;": "\u2216", - "ssmile;": "\u2323", - "sstarf;": "\u22c6", - "star;": "\u2606", - "starf;": "\u2605", - "straightepsilon;": "\u03f5", - "straightphi;": "\u03d5", - "strns;": "\xaf", - "sub;": "\u2282", - "subE;": "\u2ac5", - "subdot;": "\u2abd", - "sube;": "\u2286", - "subedot;": "\u2ac3", - "submult;": "\u2ac1", - "subnE;": "\u2acb", - "subne;": "\u228a", - "subplus;": "\u2abf", - "subrarr;": "\u2979", - "subset;": "\u2282", - "subseteq;": "\u2286", - "subseteqq;": "\u2ac5", - "subsetneq;": "\u228a", - "subsetneqq;": "\u2acb", - "subsim;": "\u2ac7", - "subsub;": "\u2ad5", - "subsup;": "\u2ad3", - "succ;": "\u227b", - "succapprox;": "\u2ab8", - "succcurlyeq;": "\u227d", - "succeq;": "\u2ab0", - "succnapprox;": "\u2aba", - "succneqq;": "\u2ab6", - "succnsim;": "\u22e9", - "succsim;": "\u227f", - "sum;": "\u2211", - "sung;": "\u266a", - "sup1": "\xb9", - "sup1;": "\xb9", - "sup2": "\xb2", - "sup2;": "\xb2", - "sup3": "\xb3", - "sup3;": "\xb3", - "sup;": "\u2283", - "supE;": "\u2ac6", - "supdot;": "\u2abe", - "supdsub;": "\u2ad8", - "supe;": "\u2287", - "supedot;": "\u2ac4", - "suphsol;": "\u27c9", - "suphsub;": "\u2ad7", - "suplarr;": "\u297b", - "supmult;": "\u2ac2", - "supnE;": "\u2acc", - "supne;": "\u228b", - "supplus;": "\u2ac0", - "supset;": "\u2283", - "supseteq;": "\u2287", - "supseteqq;": "\u2ac6", - "supsetneq;": "\u228b", - "supsetneqq;": "\u2acc", - "supsim;": "\u2ac8", - "supsub;": "\u2ad4", - "supsup;": "\u2ad6", - "swArr;": "\u21d9", - "swarhk;": "\u2926", - "swarr;": "\u2199", - "swarrow;": "\u2199", - "swnwar;": "\u292a", - "szlig": "\xdf", - "szlig;": "\xdf", - "target;": "\u2316", - "tau;": "\u03c4", - "tbrk;": "\u23b4", - "tcaron;": "\u0165", - "tcedil;": "\u0163", - "tcy;": "\u0442", - "tdot;": "\u20db", - "telrec;": "\u2315", - "tfr;": "\U0001d531", - "there4;": "\u2234", - "therefore;": "\u2234", - "theta;": "\u03b8", - "thetasym;": "\u03d1", - "thetav;": "\u03d1", - "thickapprox;": "\u2248", - "thicksim;": "\u223c", - "thinsp;": "\u2009", - "thkap;": "\u2248", - "thksim;": "\u223c", - "thorn": "\xfe", - "thorn;": "\xfe", - "tilde;": "\u02dc", - "times": "\xd7", - "times;": "\xd7", - "timesb;": "\u22a0", - "timesbar;": "\u2a31", - "timesd;": "\u2a30", - "tint;": "\u222d", - "toea;": "\u2928", - "top;": "\u22a4", - "topbot;": "\u2336", - "topcir;": "\u2af1", - "topf;": "\U0001d565", - "topfork;": "\u2ada", - "tosa;": "\u2929", - "tprime;": "\u2034", - "trade;": "\u2122", - "triangle;": "\u25b5", - "triangledown;": "\u25bf", - "triangleleft;": "\u25c3", - "trianglelefteq;": "\u22b4", - "triangleq;": "\u225c", - "triangleright;": "\u25b9", - "trianglerighteq;": "\u22b5", - "tridot;": "\u25ec", - "trie;": "\u225c", - "triminus;": "\u2a3a", - "triplus;": "\u2a39", - "trisb;": "\u29cd", - "tritime;": "\u2a3b", - "trpezium;": "\u23e2", - "tscr;": "\U0001d4c9", - "tscy;": "\u0446", - "tshcy;": "\u045b", - "tstrok;": "\u0167", - "twixt;": "\u226c", - "twoheadleftarrow;": "\u219e", - "twoheadrightarrow;": "\u21a0", - "uArr;": "\u21d1", - "uHar;": "\u2963", - "uacute": "\xfa", - "uacute;": "\xfa", - "uarr;": "\u2191", - "ubrcy;": "\u045e", - "ubreve;": "\u016d", - "ucirc": "\xfb", - "ucirc;": "\xfb", - "ucy;": "\u0443", - "udarr;": "\u21c5", - "udblac;": "\u0171", - "udhar;": "\u296e", - "ufisht;": "\u297e", - "ufr;": "\U0001d532", - "ugrave": "\xf9", - "ugrave;": "\xf9", - "uharl;": "\u21bf", - "uharr;": "\u21be", - "uhblk;": "\u2580", - "ulcorn;": "\u231c", - "ulcorner;": "\u231c", - "ulcrop;": "\u230f", - "ultri;": "\u25f8", - "umacr;": "\u016b", - "uml": "\xa8", - "uml;": "\xa8", - "uogon;": "\u0173", - "uopf;": "\U0001d566", - "uparrow;": "\u2191", - "updownarrow;": "\u2195", - "upharpoonleft;": "\u21bf", - "upharpoonright;": "\u21be", - "uplus;": "\u228e", - "upsi;": "\u03c5", - "upsih;": "\u03d2", - "upsilon;": "\u03c5", - "upuparrows;": "\u21c8", - "urcorn;": "\u231d", - "urcorner;": "\u231d", - "urcrop;": "\u230e", - "uring;": "\u016f", - "urtri;": "\u25f9", - "uscr;": "\U0001d4ca", - "utdot;": "\u22f0", - "utilde;": "\u0169", - "utri;": "\u25b5", - "utrif;": "\u25b4", - "uuarr;": "\u21c8", - "uuml": "\xfc", - "uuml;": "\xfc", - "uwangle;": "\u29a7", - "vArr;": "\u21d5", - "vBar;": "\u2ae8", - "vBarv;": "\u2ae9", - "vDash;": "\u22a8", - "vangrt;": "\u299c", - "varepsilon;": "\u03f5", - "varkappa;": "\u03f0", - "varnothing;": "\u2205", - "varphi;": "\u03d5", - "varpi;": "\u03d6", - "varpropto;": "\u221d", - "varr;": "\u2195", - "varrho;": "\u03f1", - "varsigma;": "\u03c2", - "varsubsetneq;": "\u228a\ufe00", - "varsubsetneqq;": "\u2acb\ufe00", - "varsupsetneq;": "\u228b\ufe00", - "varsupsetneqq;": "\u2acc\ufe00", - "vartheta;": "\u03d1", - "vartriangleleft;": "\u22b2", - "vartriangleright;": "\u22b3", - "vcy;": "\u0432", - "vdash;": "\u22a2", - "vee;": "\u2228", - "veebar;": "\u22bb", - "veeeq;": "\u225a", - "vellip;": "\u22ee", - "verbar;": "|", - "vert;": "|", - "vfr;": "\U0001d533", - "vltri;": "\u22b2", - "vnsub;": "\u2282\u20d2", - "vnsup;": "\u2283\u20d2", - "vopf;": "\U0001d567", - "vprop;": "\u221d", - "vrtri;": "\u22b3", - "vscr;": "\U0001d4cb", - "vsubnE;": "\u2acb\ufe00", - "vsubne;": "\u228a\ufe00", - "vsupnE;": "\u2acc\ufe00", - "vsupne;": "\u228b\ufe00", - "vzigzag;": "\u299a", - "wcirc;": "\u0175", - "wedbar;": "\u2a5f", - "wedge;": "\u2227", - "wedgeq;": "\u2259", - "weierp;": "\u2118", - "wfr;": "\U0001d534", - "wopf;": "\U0001d568", - "wp;": "\u2118", - "wr;": "\u2240", - "wreath;": "\u2240", - "wscr;": "\U0001d4cc", - "xcap;": "\u22c2", - "xcirc;": "\u25ef", - "xcup;": "\u22c3", - "xdtri;": "\u25bd", - "xfr;": "\U0001d535", - "xhArr;": "\u27fa", - "xharr;": "\u27f7", - "xi;": "\u03be", - "xlArr;": "\u27f8", - "xlarr;": "\u27f5", - "xmap;": "\u27fc", - "xnis;": "\u22fb", - "xodot;": "\u2a00", - "xopf;": "\U0001d569", - "xoplus;": "\u2a01", - "xotime;": "\u2a02", - "xrArr;": "\u27f9", - "xrarr;": "\u27f6", - "xscr;": "\U0001d4cd", - "xsqcup;": "\u2a06", - "xuplus;": "\u2a04", - "xutri;": "\u25b3", - "xvee;": "\u22c1", - "xwedge;": "\u22c0", - "yacute": "\xfd", - "yacute;": "\xfd", - "yacy;": "\u044f", - "ycirc;": "\u0177", - "ycy;": "\u044b", - "yen": "\xa5", - "yen;": "\xa5", - "yfr;": "\U0001d536", - "yicy;": "\u0457", - "yopf;": "\U0001d56a", - "yscr;": "\U0001d4ce", - "yucy;": "\u044e", - "yuml": "\xff", - "yuml;": "\xff", - "zacute;": "\u017a", - "zcaron;": "\u017e", - "zcy;": "\u0437", - "zdot;": "\u017c", - "zeetrf;": "\u2128", - "zeta;": "\u03b6", - "zfr;": "\U0001d537", - "zhcy;": "\u0436", - "zigrarr;": "\u21dd", - "zopf;": "\U0001d56b", - "zscr;": "\U0001d4cf", - "zwj;": "\u200d", - "zwnj;": "\u200c", -} - -replacementCharacters = { - 0x0: "\uFFFD", - 0x0d: "\u000D", - 0x80: "\u20AC", - 0x81: "\u0081", - 0x82: "\u201A", - 0x83: "\u0192", - 0x84: "\u201E", - 0x85: "\u2026", - 0x86: "\u2020", - 0x87: "\u2021", - 0x88: "\u02C6", - 0x89: "\u2030", - 0x8A: "\u0160", - 0x8B: "\u2039", - 0x8C: "\u0152", - 0x8D: "\u008D", - 0x8E: "\u017D", - 0x8F: "\u008F", - 0x90: "\u0090", - 0x91: "\u2018", - 0x92: "\u2019", - 0x93: "\u201C", - 0x94: "\u201D", - 0x95: "\u2022", - 0x96: "\u2013", - 0x97: "\u2014", - 0x98: "\u02DC", - 0x99: "\u2122", - 0x9A: "\u0161", - 0x9B: "\u203A", - 0x9C: "\u0153", - 0x9D: "\u009D", - 0x9E: "\u017E", - 0x9F: "\u0178", -} - -tokenTypes = { - "Doctype": 0, - "Characters": 1, - "SpaceCharacters": 2, - "StartTag": 3, - "EndTag": 4, - "EmptyTag": 5, - "Comment": 6, - "ParseError": 7 -} - -tagTokenTypes = frozenset([tokenTypes["StartTag"], tokenTypes["EndTag"], - tokenTypes["EmptyTag"]]) - - -prefixes = {v: k for k, v in namespaces.items()} -prefixes["http://www.w3.org/1998/Math/MathML"] = "math" - - -class DataLossWarning(UserWarning): - """Raised when the current tree is unable to represent the input data""" - pass - - -class _ReparseException(Exception): - pass diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 718e2e70bf2ce8b5ef9d1e61de9428309aebca01..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 228 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>U6e> z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk yFVfE_$;~m%$xPBu%giZBEh^TJkI&4@EQycTE2zB1VUwGmQks)$2Xf+PkXHcO;ywZZ diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-39.pyc deleted file mode 100644 index c2b49c9b2310db18662b205f1b6983c0b05a1c48..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1350 zcmYe~<>g{vU|^UdaWHi{GXuk85C<8vFfcGUFfcF_doeIDq%fo~<}l<kMlt3xMKR?v zM=>)pq%fs0=dk3mMzJ!2<XLjqa@nKU85vSoQ`lM<qBz_cQrJ^CS{PC|QdzS&o0+3H zQ#gYeG`U`aY|&)C#h;i|oS#!#k{X|xTaaH=a*HD+vn;bXGe7T^KxtlPa(+r`d`@Ob zYEfcN@k>Sq1_n*WTP#V5#i^Q%x48X_Qc{ajQ(Q8WOOioyATvQ2#Aaq-U~mSxT!w*x zp@t!aQ4)*`_)?glJZ4FTG^St%O_r*kL8&FBMR^K|c?yXI1x5J<MVW~usS4Stl?rM3 zMPT8QlA_F{(vnoLKyiLiNoHO;7ng#9f`TJVs#qZ-u`E>~Q6VoeH?_DRF*#MCBqOmz zAvrNmAt_ZMHM1lmwMZc$!7o2AH6cL(WUxYUNl|8Ax}HLKD%h;##60y9h2;F)g2W<_ z?o@@6@_dD))a1m{Vlcl_y(m>7B{MB8wJ0^OM4_azAhlRWp*UZmJXIk%Kd&scs03^f z+?JAjkn>Y>3rZ@XmMNrV78RH1K^$KM3aVQSMXU@A3@gE5n^;m(RK&@^zyKzGO?S46 z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk zFVfE_$;~m%$xPBu%giZBEh^Se%qhr7OiC@uOis)JxeOc!#d-ymw>aZL{P^tDN)Avg zGlAlrqlkxrfgu^hM8+UFa3YpqU|>jPh+<4(h+;}%jA8~Q-WG-^mK2s?22IvmY;Is% zt5h6ewpOJUD}bzlSPPE()ST4Z)Vz{nlmrI~J`e_3T^z%}z)-@F#khc}hG8M23q!0| zEn^KMH~})1F%$)qFgG*QGL^8@Fs3j|GAv+S$WX$T!qUs+!VoJE!&J*$%TmKq!&Jj; z!%%2e!vs=g!%)K*#=yu>$dkeVa;e`f7EsJ<GTq_`E=epZ2}w-9#o-EyV-SlaC9xz? zlkpaFc50<2dl4HbE_oRk7;bUI$AfZGe0&i*h|2~_#;GZ{STjpfbBn=2r^$MYr8qSw z?G|fEes*f!Emn}{i*K=jQuHm>vc#OyRB*C@5ZoY>g&7zaL_ski1PXFS0Y)B1Hbx#s zrvH3QT#OuyRs4`Z)q~mXr^yO(2*||v_*-1@@wxdar8%kb@wa&5;|og@bD%Qp@$o77 z$?@?;APXS&!Bb@s*k+KQK$69vLW+Ztg|P@E;-|?4GBvHVq_ikCKE4PP`9+|@pa`U_ z2$WdBL2`>bIX@>SHMt}+Kd%@ZAm9)Hn}N-`TO2kJm)e1{OfkqD5hflc9%c@10PFQ& AO8@`> diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-39.pyc deleted file mode 100644 index 237ff0f2f9385e15be45cdab5c341becd497d6ac..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 898 zcmYe~<>g{vU|^UdaWGYmk%8ech=Yt-7#J8F7#J9eH5eEeQW#Pga~N_NqZo6UqL^}- zqnH^P+!<1sQkYv9QkYX&nwg_mQ&@r-G+AGQ%+O@M#h;i|oS#!#k{X|xTaaH=a*HD+ zvn;bXGe7T^KxtlPa(+r`d`@ObYEfcNaWY5`GG>C=t-`>-kjfCnn8Fanl){+8)WQ(O zoWh*K(!vnMlERw8*1{0Qn!+B;pviHI%`G#hB(*3Rq!(ruhz-KdAb)_oTf<nx5YLdp z5X`WW(NB}{7F%(CX;E^jCetmJ;?$h9B6bD_hLsFOoD2*MzgnHGVnT~ki;81Xb5b&k zV*K+`U5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYs zbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F@{9B{N^)~db25|k z)4<*+)=x?-PSq=@yu}e8pP83g5+BbB@&w2?42)I$5YOtt<dPX-US?om0I@;p;Jz+l zsA0%rY-S8*C}Lw^U;z0R6!Ku-YBCmaFfc&84EA>sD4f8ymZTQN$Act`L8hVF3YNnN zYi0%p2C%I>3=9kqTWc7bnGp7}r>B-AmXs7htY!jReTyY8F*g-rHz&v`U<Yu=$3xY| z$8#h3TnO%SxU`=p8_2yNQ{v-qamB~y=BJeAq{heJ;)#zhEKSUT$P|H$DdGj$AOIr3 zb|DCmtwo?P1||GrP&jcgaxil+gT+8raK*=`m6ntirN+k>fdZrm<l7>U>RW92Nm;4M bC19mU9swH;GWQmT4a7}$ptu1CrwB6up<Ks; diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-39.pyc deleted file mode 100644 index cdbe4c7f8665fa6279cfcbffcbe17c0d1a25e0b8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1904 zcmYe~<>g{vU|^UdaWJ)!n}Ojmh=Yt-7#J8F7#J9e%@`OMQW#Pga~N_NqZo6UqL^}- zqnH^PQkYVhb69d&qgWXk+!<0>QdnCUQdm=2v)G!Mqu5f|f*CZ~UxG~3WWL3pm{gpf zQ(BT5pP5^bUsQ67BPFvevp6$9@0LJmUS@KBN@{#gW=U#MVovc(Mg|53O~zX+Nr}a& z$shxeF%!&L3JeSksSHt!DGX6eDU4CfAm_9&M6o~|62%H}z%4en%$$<cqAFX@ysXsZ zl46B~1e@H{l0=2%jKrei)Dl})KWBdzPd|6Ngan0>#B_zsypnu{jMT&wh5R&yl>Fq< z+|<01WM(8cfY_kWaR!Bs1Oo#@2}2g+0;U><8pef8j0`nQH4O30DU87knoLzC&PAz- zC8@;<i3$*haB(R>fmLErx<YY&X;E^jl|o5IDwM5IlAoQLr%+r{l$w}}raCn*IX@*c zFCC&D##1QCS13*`L8$f9WGP}}U|=X>XJBBs#StH$nU`4-AAgGjrbCnY7E5tzPTDOt zi2X&J3=9k_8H#uq7#My{akh#HElw>ej!Df)$t;TT&r5YF$}CG&&{YWa^9*wh3ib?f z3|8>;bMg0c4fb@533l~$4GwV)QZS1N2=IwXG||n;PtPna$;^&P%`1!X$xMnV&MZmQ zEl5nxPE1cNjw#42(2p-m%}dEI($6T#%`wf%OwvyS$5XL>CODqrL2(ohjU&B+$|4R1 z1_lr=28BEW2Onb<KO{i)VBSjxr5ji@fzmc82tetl_!1)nLkeRpV+}(VLkdGFLoHJ} zLoIU&V;0i_<{E~Dj4lil7-QGevedAoFiA4hvevMsFlRFr`P8taut+j2U|GnJ!kW!g z<dMQw%Q%5CFQtYxg*}^T0%MUEk_wJ&rlKDyoV9E<EGb-)3=3EnGPp3rM#M11Fx9fx za@2Cxu%|GTG8Xj}mKB!OaDYwa&Somw267cdPYrtwM;en2LkdqV6C*?6H;}p%-fX6# zvKmgXdOi?4g{PLSu&joy=vxXuL|++0(YF)<kU3%u5Rnvqh$(piNG@aryLm$m(*(xi z4JphitWdRrbC|;z7#UL7Q#ewDK&E6erohC6Q&>|(<}iWfd1{#o<?_;MSW|?dCZUAS z1jeEbHOvrl0b7dbLPn4-ux*pDnGIIEqJ|lvb^>GJB#_@z#A+F97*p85wj8TrUcg?% zvXGIHp-`@d1!QKSTna-lgQmD&6h}c(YCI^j-eM`KEJ(e@5nPg3R1%Vyev2h9F*o%V z3rH@CJu?rYh{H9vprjHk4N6~bw^&jVOA>FfL(^GE6<0<{Nr7%^VQFSr6;E=0UP)?R zi7v=wO(wrv>`;L!(UR1P5^&13h8H8M#hT1Te4tDx03t*{Wf+rRktiq!vbpA^ge0bG zG9f7dCDtg;g8bqVu+ua-z<CfY+m@sj#mC=b&B-rMExN^;S(2Jte2cjtzu*>IVnIP_ zUWz7H5h$VGVl6I7EJ=;x0(mMvEx$A`<rX_gJ~J=<7Av?s0oxoUosn1^5AtF>*o*N{ z55<Fgc#9JhV#NiC$*DykFWh1+OUx-v1(yjBf*0g5P<bZ|D){0+S&fl}k&BUqNr;hy zk%Liyk%NhgQGkhsQG$_!k%f_mQHYU+k&RJ=k&Q`!QHYU^NrH)mk?lVR6AL59e-0)d zMixdECN4$^CLTsMMu-?2qX1NthY2}{gG0hklMPgwf!rA%e~T+VJ~uz5G$%Da{uWPs zd|_!~4pfFcK0YNsIX)g-XcU254DkS{c!RLOUICSkpfaKuM1UO3!3{1k{WRG@hNqR5 tloqAN#}|RBoFY)6Uj!<9ZZRMt31S$kv9~yEAkMM_MKQRz5@F(D1^^vF=Ai%p diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-39.pyc deleted file mode 100644 index 746c84a71069f3a21ac8990b00eb8980f522a672..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2646 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 diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-39.pyc deleted file mode 100644 index 97f1209672b7a0a158cbf078c5fbe40d3f56c5f0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2791 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 diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-39.pyc deleted file mode 100644 index 022692f3c500ebfdf162965f9026031a50e7d8be..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16914 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 Z0WLl+AudBMEiP^@DK0J!ZkDesd;kW?^cesE diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-39.pyc deleted file mode 100644 index 9758153889e21c84531717e3fdf67b592ef860de..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1396 zcmYe~<>g{vU|^UdaWHis3j@Pr5C<8vFfcGUFfcF_=P@uaq%fo~<}l<kMlt3xMKR?v zM=>*k#F%neqF7RxQ&@6XbJ?QU7#UJnQ`mCYb2*|oayg?o85vU87jUI=E@X`2Ol4WX zox+jIDaNpnF^b2XA%!!AtA!zjE0ryax0yMLH-$Ter-dPkFNG<XL6i3-$R(Q0xA+s2 zit}?yOH$)Aa|`l|N^WtaWR_(XXXfYK5-82fOwLb9jnBy}Ni9muDfWBG$iTp$$#{z; zDX}>9B@>9lbc?SjIVG_q(KRPEH#M)M_!fV0L1J>Mb4FrOVsc4pQSmK?D%NP#;#lou zkd??79soKF3=F9ZQH&`JQA{a}QOv0<DNHHM=}f7tscg-R;tb7<QS2!!DXc9FQ5-33 z!3>)0x7ge=b4pT+svMp3b8-?3ic^af$}=)cQo)uhq*f%S7L+Jt<|z~urRpe@q*jz9 z7NsWYC?w{kC=@3bWfqhuq{1A`Tu_vHivy-68RSQpD?u&<VUW{{=YXP#v6iufA&YSV zQw_sHMi++IwpykdrW7VghFazt<`m{^rXq(L#$vM?rW6)Qh8l(}<}wD5ND8YtLoH)o zKn-&WTQ*ZsSPdfxr?6UpM6GHVi%V*lQ`obaib`sjQaB_Tib_&AK`a}FJeeBC;t4g( zDO}l1MH5O`K%$Zi&5R)0hM|TjjDeA%P#}dNm_d`<uL$J$TP!7&1*x|<f=d#MN<tFT zZ?WVh=B5_0GB7aQVsp()0SWO3qeT)6C=P!yD%|2i#GEE;5gP*oLlHMfCr5ldC>g}Z z-x39faX?XOacWUnDk9#Kp)nB;mM_+1xy4ePnv-^mqX4S(7Hdg<c4}S`9|Hr!N`@jC z1_p*--Og4qp~b01#WATlDVaqv{&}e`MVV!(3c3oRex6~jLBXCOj=>6^elGrguECy; zF~P3BuE8O$K?-Iu0RcWSi6*)^`RSR(C7IbVsd;5FKAA}|#hE3kx&?{J*@@|?#W4k$ z1^V%2sd*{+Mfw>fxjCjenMwL-;M7yBk4Q6m1(ii&3=9kcpd6_HN&t*3i~@`tj2w(i z|Ctzh{xdOgG4U{RF^Pa_0j4T`ND|b81&p62=Pi!-cu-)+$KT?LkI&6dDa}cZkH5te zA75CSm;;qzkB?8uPmYhj#hF%=UzM6yoLX{=B`34Eq=*9)+TtJr<PvZIArZ152~b?{ zfSd@584gAkMiC}({GcRTP$~c=TW63$km?eK1&k?-H4F<ud7sIzNCc8~d4dBRon3?D zgIwKRBW^JlmnMNSHz+5dTPwl9z@Q2;4V38_7>huBO@5Fk(@IN9i&Ep`i$F3(%pf;{ ztiHumlv)HT|G-J;7H4vPUU5lcUP&>;lboO=#gdhunRkmlIX|}`Gbgo31*8|`Kd|XY mE&wHzB9QNIao9k@)DGmsVo*8~Vd7xoVH9BGV&Y>Kk^}%{M`Vux diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py deleted file mode 100644 index 5ba926e3..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py +++ /dev/null @@ -1,29 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from . import base - -from collections import OrderedDict - - -def _attr_key(attr): - """Return an appropriate key for an attribute for sorting - - Attributes have a namespace that can be either ``None`` or a string. We - can't compare the two because they're different types, so we convert - ``None`` to an empty string first. - - """ - return (attr[0][0] or ''), attr[0][1] - - -class Filter(base.Filter): - """Alphabetizes attributes for elements""" - def __iter__(self): - for token in base.Filter.__iter__(self): - if token["type"] in ("StartTag", "EmptyTag"): - attrs = OrderedDict() - for name, value in sorted(token["data"].items(), - key=_attr_key): - attrs[name] = value - token["data"] = attrs - yield token diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/base.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/base.py deleted file mode 100644 index c7dbaed0..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/base.py +++ /dev/null @@ -1,12 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - - -class Filter(object): - def __init__(self, source): - self.source = source - - def __iter__(self): - return iter(self.source) - - def __getattr__(self, name): - return getattr(self.source, name) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py deleted file mode 100644 index aefb5c84..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py +++ /dev/null @@ -1,73 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from . import base - - -class Filter(base.Filter): - """Injects ``<meta charset=ENCODING>`` tag into head of document""" - def __init__(self, source, encoding): - """Creates a Filter - - :arg source: the source token stream - - :arg encoding: the encoding to set - - """ - base.Filter.__init__(self, source) - self.encoding = encoding - - def __iter__(self): - state = "pre_head" - meta_found = (self.encoding is None) - pending = [] - - for token in base.Filter.__iter__(self): - type = token["type"] - if type == "StartTag": - if token["name"].lower() == "head": - state = "in_head" - - elif type == "EmptyTag": - if token["name"].lower() == "meta": - # replace charset with actual encoding - has_http_equiv_content_type = False - for (namespace, name), value in token["data"].items(): - if namespace is not None: - continue - elif name.lower() == 'charset': - token["data"][(namespace, name)] = self.encoding - meta_found = True - break - elif name == 'http-equiv' and value.lower() == 'content-type': - has_http_equiv_content_type = True - else: - if has_http_equiv_content_type and (None, "content") in token["data"]: - token["data"][(None, "content")] = 'text/html; charset=%s' % self.encoding - meta_found = True - - elif token["name"].lower() == "head" and not meta_found: - # insert meta into empty head - yield {"type": "StartTag", "name": "head", - "data": token["data"]} - yield {"type": "EmptyTag", "name": "meta", - "data": {(None, "charset"): self.encoding}} - yield {"type": "EndTag", "name": "head"} - meta_found = True - continue - - elif type == "EndTag": - if token["name"].lower() == "head" and pending: - # insert meta into head (if necessary) and flush pending queue - yield pending.pop(0) - if not meta_found: - yield {"type": "EmptyTag", "name": "meta", - "data": {(None, "charset"): self.encoding}} - while pending: - yield pending.pop(0) - meta_found = True - state = "post_head" - - if state == "in_head": - pending.append(token) - else: - yield token diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/lint.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/lint.py deleted file mode 100644 index fcc07eec..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/lint.py +++ /dev/null @@ -1,93 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from pip._vendor.six import text_type - -from . import base -from ..constants import namespaces, voidElements - -from ..constants import spaceCharacters -spaceCharacters = "".join(spaceCharacters) - - -class Filter(base.Filter): - """Lints the token stream for errors - - If it finds any errors, it'll raise an ``AssertionError``. - - """ - def __init__(self, source, require_matching_tags=True): - """Creates a Filter - - :arg source: the source token stream - - :arg require_matching_tags: whether or not to require matching tags - - """ - super(Filter, self).__init__(source) - self.require_matching_tags = require_matching_tags - - def __iter__(self): - open_elements = [] - for token in base.Filter.__iter__(self): - type = token["type"] - if type in ("StartTag", "EmptyTag"): - namespace = token["namespace"] - name = token["name"] - assert namespace is None or isinstance(namespace, text_type) - assert namespace != "" - assert isinstance(name, text_type) - assert name != "" - assert isinstance(token["data"], dict) - if (not namespace or namespace == namespaces["html"]) and name in voidElements: - assert type == "EmptyTag" - else: - assert type == "StartTag" - if type == "StartTag" and self.require_matching_tags: - open_elements.append((namespace, name)) - for (namespace, name), value in token["data"].items(): - assert namespace is None or isinstance(namespace, text_type) - assert namespace != "" - assert isinstance(name, text_type) - assert name != "" - assert isinstance(value, text_type) - - elif type == "EndTag": - namespace = token["namespace"] - name = token["name"] - assert namespace is None or isinstance(namespace, text_type) - assert namespace != "" - assert isinstance(name, text_type) - assert name != "" - if (not namespace or namespace == namespaces["html"]) and name in voidElements: - assert False, "Void element reported as EndTag token: %(tag)s" % {"tag": name} - elif self.require_matching_tags: - start = open_elements.pop() - assert start == (namespace, name) - - elif type == "Comment": - data = token["data"] - assert isinstance(data, text_type) - - elif type in ("Characters", "SpaceCharacters"): - data = token["data"] - assert isinstance(data, text_type) - assert data != "" - if type == "SpaceCharacters": - assert data.strip(spaceCharacters) == "" - - elif type == "Doctype": - name = token["name"] - assert name is None or isinstance(name, text_type) - assert token["publicId"] is None or isinstance(name, text_type) - assert token["systemId"] is None or isinstance(name, text_type) - - elif type == "Entity": - assert isinstance(token["name"], text_type) - - elif type == "SerializerError": - assert isinstance(token["data"], text_type) - - else: - assert False, "Unknown token type: %(type)s" % {"type": type} - - yield token diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/optionaltags.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/optionaltags.py deleted file mode 100644 index 4a865012..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/optionaltags.py +++ /dev/null @@ -1,207 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from . import base - - -class Filter(base.Filter): - """Removes optional tags from the token stream""" - def slider(self): - previous1 = previous2 = None - for token in self.source: - if previous1 is not None: - yield previous2, previous1, token - previous2 = previous1 - previous1 = token - if previous1 is not None: - yield previous2, previous1, None - - def __iter__(self): - for previous, token, next in self.slider(): - type = token["type"] - if type == "StartTag": - if (token["data"] or - not self.is_optional_start(token["name"], previous, next)): - yield token - elif type == "EndTag": - if not self.is_optional_end(token["name"], next): - yield token - else: - yield token - - def is_optional_start(self, tagname, previous, next): - type = next and next["type"] or None - if tagname in 'html': - # An html element's start tag may be omitted if the first thing - # inside the html element is not a space character or a comment. - return type not in ("Comment", "SpaceCharacters") - elif tagname == 'head': - # A head element's start tag may be omitted if the first thing - # inside the head element is an element. - # XXX: we also omit the start tag if the head element is empty - if type in ("StartTag", "EmptyTag"): - return True - elif type == "EndTag": - return next["name"] == "head" - elif tagname == 'body': - # A body element's start tag may be omitted if the first thing - # inside the body element is not a space character or a comment, - # except if the first thing inside the body element is a script - # or style element and the node immediately preceding the body - # element is a head element whose end tag has been omitted. - if type in ("Comment", "SpaceCharacters"): - return False - elif type == "StartTag": - # XXX: we do not look at the preceding event, so we never omit - # the body element's start tag if it's followed by a script or - # a style element. - return next["name"] not in ('script', 'style') - else: - return True - elif tagname == 'colgroup': - # A colgroup element's start tag may be omitted if the first thing - # inside the colgroup element is a col element, and if the element - # is not immediately preceded by another colgroup element whose - # end tag has been omitted. - if type in ("StartTag", "EmptyTag"): - # XXX: we do not look at the preceding event, so instead we never - # omit the colgroup element's end tag when it is immediately - # followed by another colgroup element. See is_optional_end. - return next["name"] == "col" - else: - return False - elif tagname == 'tbody': - # A tbody element's start tag may be omitted if the first thing - # inside the tbody element is a tr element, and if the element is - # not immediately preceded by a tbody, thead, or tfoot element - # whose end tag has been omitted. - if type == "StartTag": - # omit the thead and tfoot elements' end tag when they are - # immediately followed by a tbody element. See is_optional_end. - if previous and previous['type'] == 'EndTag' and \ - previous['name'] in ('tbody', 'thead', 'tfoot'): - return False - return next["name"] == 'tr' - else: - return False - return False - - def is_optional_end(self, tagname, next): - type = next and next["type"] or None - if tagname in ('html', 'head', 'body'): - # An html element's end tag may be omitted if the html element - # is not immediately followed by a space character or a comment. - return type not in ("Comment", "SpaceCharacters") - elif tagname in ('li', 'optgroup', 'tr'): - # A li element's end tag may be omitted if the li element is - # immediately followed by another li element or if there is - # no more content in the parent element. - # An optgroup element's end tag may be omitted if the optgroup - # element is immediately followed by another optgroup element, - # or if there is no more content in the parent element. - # A tr element's end tag may be omitted if the tr element is - # immediately followed by another tr element, or if there is - # no more content in the parent element. - if type == "StartTag": - return next["name"] == tagname - else: - return type == "EndTag" or type is None - elif tagname in ('dt', 'dd'): - # A dt element's end tag may be omitted if the dt element is - # immediately followed by another dt element or a dd element. - # A dd element's end tag may be omitted if the dd element is - # immediately followed by another dd element or a dt element, - # or if there is no more content in the parent element. - if type == "StartTag": - return next["name"] in ('dt', 'dd') - elif tagname == 'dd': - return type == "EndTag" or type is None - else: - return False - elif tagname == 'p': - # A p element's end tag may be omitted if the p element is - # immediately followed by an address, article, aside, - # blockquote, datagrid, dialog, dir, div, dl, fieldset, - # footer, form, h1, h2, h3, h4, h5, h6, header, hr, menu, - # nav, ol, p, pre, section, table, or ul, element, or if - # there is no more content in the parent element. - if type in ("StartTag", "EmptyTag"): - return next["name"] in ('address', 'article', 'aside', - 'blockquote', 'datagrid', 'dialog', - 'dir', 'div', 'dl', 'fieldset', 'footer', - 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', - 'header', 'hr', 'menu', 'nav', 'ol', - 'p', 'pre', 'section', 'table', 'ul') - else: - return type == "EndTag" or type is None - elif tagname == 'option': - # An option element's end tag may be omitted if the option - # element is immediately followed by another option element, - # or if it is immediately followed by an <code>optgroup</code> - # element, or if there is no more content in the parent - # element. - if type == "StartTag": - return next["name"] in ('option', 'optgroup') - else: - return type == "EndTag" or type is None - elif tagname in ('rt', 'rp'): - # An rt element's end tag may be omitted if the rt element is - # immediately followed by an rt or rp element, or if there is - # no more content in the parent element. - # An rp element's end tag may be omitted if the rp element is - # immediately followed by an rt or rp element, or if there is - # no more content in the parent element. - if type == "StartTag": - return next["name"] in ('rt', 'rp') - else: - return type == "EndTag" or type is None - elif tagname == 'colgroup': - # A colgroup element's end tag may be omitted if the colgroup - # element is not immediately followed by a space character or - # a comment. - if type in ("Comment", "SpaceCharacters"): - return False - elif type == "StartTag": - # XXX: we also look for an immediately following colgroup - # element. See is_optional_start. - return next["name"] != 'colgroup' - else: - return True - elif tagname in ('thead', 'tbody'): - # A thead element's end tag may be omitted if the thead element - # is immediately followed by a tbody or tfoot element. - # A tbody element's end tag may be omitted if the tbody element - # is immediately followed by a tbody or tfoot element, or if - # there is no more content in the parent element. - # A tfoot element's end tag may be omitted if the tfoot element - # is immediately followed by a tbody element, or if there is no - # more content in the parent element. - # XXX: we never omit the end tag when the following element is - # a tbody. See is_optional_start. - if type == "StartTag": - return next["name"] in ['tbody', 'tfoot'] - elif tagname == 'tbody': - return type == "EndTag" or type is None - else: - return False - elif tagname == 'tfoot': - # A tfoot element's end tag may be omitted if the tfoot element - # is immediately followed by a tbody element, or if there is no - # more content in the parent element. - # XXX: we never omit the end tag when the following element is - # a tbody. See is_optional_start. - if type == "StartTag": - return next["name"] == 'tbody' - else: - return type == "EndTag" or type is None - elif tagname in ('td', 'th'): - # A td element's end tag may be omitted if the td element is - # immediately followed by a td or th element, or if there is - # no more content in the parent element. - # A th element's end tag may be omitted if the th element is - # immediately followed by a td or th element, or if there is - # no more content in the parent element. - if type == "StartTag": - return next["name"] in ('td', 'th') - else: - return type == "EndTag" or type is None - return False diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/sanitizer.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/sanitizer.py deleted file mode 100644 index aa7431d1..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/sanitizer.py +++ /dev/null @@ -1,916 +0,0 @@ -"""Deprecated from html5lib 1.1. - -See `here <https://github.com/html5lib/html5lib-python/issues/443>`_ for -information about its deprecation; `Bleach <https://github.com/mozilla/bleach>`_ -is recommended as a replacement. Please let us know in the aforementioned issue -if Bleach is unsuitable for your needs. - -""" -from __future__ import absolute_import, division, unicode_literals - -import re -import warnings -from xml.sax.saxutils import escape, unescape - -from pip._vendor.six.moves import urllib_parse as urlparse - -from . import base -from ..constants import namespaces, prefixes - -__all__ = ["Filter"] - - -_deprecation_msg = ( - "html5lib's sanitizer is deprecated; see " + - "https://github.com/html5lib/html5lib-python/issues/443 and please let " + - "us know if Bleach is unsuitable for your needs" -) - -warnings.warn(_deprecation_msg, DeprecationWarning) - -allowed_elements = frozenset(( - (namespaces['html'], 'a'), - (namespaces['html'], 'abbr'), - (namespaces['html'], 'acronym'), - (namespaces['html'], 'address'), - (namespaces['html'], 'area'), - (namespaces['html'], 'article'), - (namespaces['html'], 'aside'), - (namespaces['html'], 'audio'), - (namespaces['html'], 'b'), - (namespaces['html'], 'big'), - (namespaces['html'], 'blockquote'), - (namespaces['html'], 'br'), - (namespaces['html'], 'button'), - (namespaces['html'], 'canvas'), - (namespaces['html'], 'caption'), - (namespaces['html'], 'center'), - (namespaces['html'], 'cite'), - (namespaces['html'], 'code'), - (namespaces['html'], 'col'), - (namespaces['html'], 'colgroup'), - (namespaces['html'], 'command'), - (namespaces['html'], 'datagrid'), - (namespaces['html'], 'datalist'), - (namespaces['html'], 'dd'), - (namespaces['html'], 'del'), - (namespaces['html'], 'details'), - (namespaces['html'], 'dfn'), - (namespaces['html'], 'dialog'), - (namespaces['html'], 'dir'), - (namespaces['html'], 'div'), - (namespaces['html'], 'dl'), - (namespaces['html'], 'dt'), - (namespaces['html'], 'em'), - (namespaces['html'], 'event-source'), - (namespaces['html'], 'fieldset'), - (namespaces['html'], 'figcaption'), - (namespaces['html'], 'figure'), - (namespaces['html'], 'footer'), - (namespaces['html'], 'font'), - (namespaces['html'], 'form'), - (namespaces['html'], 'header'), - (namespaces['html'], 'h1'), - (namespaces['html'], 'h2'), - (namespaces['html'], 'h3'), - (namespaces['html'], 'h4'), - (namespaces['html'], 'h5'), - (namespaces['html'], 'h6'), - (namespaces['html'], 'hr'), - (namespaces['html'], 'i'), - (namespaces['html'], 'img'), - (namespaces['html'], 'input'), - (namespaces['html'], 'ins'), - (namespaces['html'], 'keygen'), - (namespaces['html'], 'kbd'), - (namespaces['html'], 'label'), - (namespaces['html'], 'legend'), - (namespaces['html'], 'li'), - (namespaces['html'], 'm'), - (namespaces['html'], 'map'), - (namespaces['html'], 'menu'), - (namespaces['html'], 'meter'), - (namespaces['html'], 'multicol'), - (namespaces['html'], 'nav'), - (namespaces['html'], 'nextid'), - (namespaces['html'], 'ol'), - (namespaces['html'], 'output'), - (namespaces['html'], 'optgroup'), - (namespaces['html'], 'option'), - (namespaces['html'], 'p'), - (namespaces['html'], 'pre'), - (namespaces['html'], 'progress'), - (namespaces['html'], 'q'), - (namespaces['html'], 's'), - (namespaces['html'], 'samp'), - (namespaces['html'], 'section'), - (namespaces['html'], 'select'), - (namespaces['html'], 'small'), - (namespaces['html'], 'sound'), - (namespaces['html'], 'source'), - (namespaces['html'], 'spacer'), - (namespaces['html'], 'span'), - (namespaces['html'], 'strike'), - (namespaces['html'], 'strong'), - (namespaces['html'], 'sub'), - (namespaces['html'], 'sup'), - (namespaces['html'], 'table'), - (namespaces['html'], 'tbody'), - (namespaces['html'], 'td'), - (namespaces['html'], 'textarea'), - (namespaces['html'], 'time'), - (namespaces['html'], 'tfoot'), - (namespaces['html'], 'th'), - (namespaces['html'], 'thead'), - (namespaces['html'], 'tr'), - (namespaces['html'], 'tt'), - (namespaces['html'], 'u'), - (namespaces['html'], 'ul'), - (namespaces['html'], 'var'), - (namespaces['html'], 'video'), - (namespaces['mathml'], 'maction'), - (namespaces['mathml'], 'math'), - (namespaces['mathml'], 'merror'), - (namespaces['mathml'], 'mfrac'), - (namespaces['mathml'], 'mi'), - (namespaces['mathml'], 'mmultiscripts'), - (namespaces['mathml'], 'mn'), - (namespaces['mathml'], 'mo'), - (namespaces['mathml'], 'mover'), - (namespaces['mathml'], 'mpadded'), - (namespaces['mathml'], 'mphantom'), - (namespaces['mathml'], 'mprescripts'), - (namespaces['mathml'], 'mroot'), - (namespaces['mathml'], 'mrow'), - (namespaces['mathml'], 'mspace'), - (namespaces['mathml'], 'msqrt'), - (namespaces['mathml'], 'mstyle'), - (namespaces['mathml'], 'msub'), - (namespaces['mathml'], 'msubsup'), - (namespaces['mathml'], 'msup'), - (namespaces['mathml'], 'mtable'), - (namespaces['mathml'], 'mtd'), - (namespaces['mathml'], 'mtext'), - (namespaces['mathml'], 'mtr'), - (namespaces['mathml'], 'munder'), - (namespaces['mathml'], 'munderover'), - (namespaces['mathml'], 'none'), - (namespaces['svg'], 'a'), - (namespaces['svg'], 'animate'), - (namespaces['svg'], 'animateColor'), - (namespaces['svg'], 'animateMotion'), - (namespaces['svg'], 'animateTransform'), - (namespaces['svg'], 'clipPath'), - (namespaces['svg'], 'circle'), - (namespaces['svg'], 'defs'), - (namespaces['svg'], 'desc'), - (namespaces['svg'], 'ellipse'), - (namespaces['svg'], 'font-face'), - (namespaces['svg'], 'font-face-name'), - (namespaces['svg'], 'font-face-src'), - (namespaces['svg'], 'g'), - (namespaces['svg'], 'glyph'), - (namespaces['svg'], 'hkern'), - (namespaces['svg'], 'linearGradient'), - (namespaces['svg'], 'line'), - (namespaces['svg'], 'marker'), - (namespaces['svg'], 'metadata'), - (namespaces['svg'], 'missing-glyph'), - (namespaces['svg'], 'mpath'), - (namespaces['svg'], 'path'), - (namespaces['svg'], 'polygon'), - (namespaces['svg'], 'polyline'), - (namespaces['svg'], 'radialGradient'), - (namespaces['svg'], 'rect'), - (namespaces['svg'], 'set'), - (namespaces['svg'], 'stop'), - (namespaces['svg'], 'svg'), - (namespaces['svg'], 'switch'), - (namespaces['svg'], 'text'), - (namespaces['svg'], 'title'), - (namespaces['svg'], 'tspan'), - (namespaces['svg'], 'use'), -)) - -allowed_attributes = frozenset(( - # HTML attributes - (None, 'abbr'), - (None, 'accept'), - (None, 'accept-charset'), - (None, 'accesskey'), - (None, 'action'), - (None, 'align'), - (None, 'alt'), - (None, 'autocomplete'), - (None, 'autofocus'), - (None, 'axis'), - (None, 'background'), - (None, 'balance'), - (None, 'bgcolor'), - (None, 'bgproperties'), - (None, 'border'), - (None, 'bordercolor'), - (None, 'bordercolordark'), - (None, 'bordercolorlight'), - (None, 'bottompadding'), - (None, 'cellpadding'), - (None, 'cellspacing'), - (None, 'ch'), - (None, 'challenge'), - (None, 'char'), - (None, 'charoff'), - (None, 'choff'), - (None, 'charset'), - (None, 'checked'), - (None, 'cite'), - (None, 'class'), - (None, 'clear'), - (None, 'color'), - (None, 'cols'), - (None, 'colspan'), - (None, 'compact'), - (None, 'contenteditable'), - (None, 'controls'), - (None, 'coords'), - (None, 'data'), - (None, 'datafld'), - (None, 'datapagesize'), - (None, 'datasrc'), - (None, 'datetime'), - (None, 'default'), - (None, 'delay'), - (None, 'dir'), - (None, 'disabled'), - (None, 'draggable'), - (None, 'dynsrc'), - (None, 'enctype'), - (None, 'end'), - (None, 'face'), - (None, 'for'), - (None, 'form'), - (None, 'frame'), - (None, 'galleryimg'), - (None, 'gutter'), - (None, 'headers'), - (None, 'height'), - (None, 'hidefocus'), - (None, 'hidden'), - (None, 'high'), - (None, 'href'), - (None, 'hreflang'), - (None, 'hspace'), - (None, 'icon'), - (None, 'id'), - (None, 'inputmode'), - (None, 'ismap'), - (None, 'keytype'), - (None, 'label'), - (None, 'leftspacing'), - (None, 'lang'), - (None, 'list'), - (None, 'longdesc'), - (None, 'loop'), - (None, 'loopcount'), - (None, 'loopend'), - (None, 'loopstart'), - (None, 'low'), - (None, 'lowsrc'), - (None, 'max'), - (None, 'maxlength'), - (None, 'media'), - (None, 'method'), - (None, 'min'), - (None, 'multiple'), - (None, 'name'), - (None, 'nohref'), - (None, 'noshade'), - (None, 'nowrap'), - (None, 'open'), - (None, 'optimum'), - (None, 'pattern'), - (None, 'ping'), - (None, 'point-size'), - (None, 'poster'), - (None, 'pqg'), - (None, 'preload'), - (None, 'prompt'), - (None, 'radiogroup'), - (None, 'readonly'), - (None, 'rel'), - (None, 'repeat-max'), - (None, 'repeat-min'), - (None, 'replace'), - (None, 'required'), - (None, 'rev'), - (None, 'rightspacing'), - (None, 'rows'), - (None, 'rowspan'), - (None, 'rules'), - (None, 'scope'), - (None, 'selected'), - (None, 'shape'), - (None, 'size'), - (None, 'span'), - (None, 'src'), - (None, 'start'), - (None, 'step'), - (None, 'style'), - (None, 'summary'), - (None, 'suppress'), - (None, 'tabindex'), - (None, 'target'), - (None, 'template'), - (None, 'title'), - (None, 'toppadding'), - (None, 'type'), - (None, 'unselectable'), - (None, 'usemap'), - (None, 'urn'), - (None, 'valign'), - (None, 'value'), - (None, 'variable'), - (None, 'volume'), - (None, 'vspace'), - (None, 'vrml'), - (None, 'width'), - (None, 'wrap'), - (namespaces['xml'], 'lang'), - # MathML attributes - (None, 'actiontype'), - (None, 'align'), - (None, 'columnalign'), - (None, 'columnalign'), - (None, 'columnalign'), - (None, 'columnlines'), - (None, 'columnspacing'), - (None, 'columnspan'), - (None, 'depth'), - (None, 'display'), - (None, 'displaystyle'), - (None, 'equalcolumns'), - (None, 'equalrows'), - (None, 'fence'), - (None, 'fontstyle'), - (None, 'fontweight'), - (None, 'frame'), - (None, 'height'), - (None, 'linethickness'), - (None, 'lspace'), - (None, 'mathbackground'), - (None, 'mathcolor'), - (None, 'mathvariant'), - (None, 'mathvariant'), - (None, 'maxsize'), - (None, 'minsize'), - (None, 'other'), - (None, 'rowalign'), - (None, 'rowalign'), - (None, 'rowalign'), - (None, 'rowlines'), - (None, 'rowspacing'), - (None, 'rowspan'), - (None, 'rspace'), - (None, 'scriptlevel'), - (None, 'selection'), - (None, 'separator'), - (None, 'stretchy'), - (None, 'width'), - (None, 'width'), - (namespaces['xlink'], 'href'), - (namespaces['xlink'], 'show'), - (namespaces['xlink'], 'type'), - # SVG attributes - (None, 'accent-height'), - (None, 'accumulate'), - (None, 'additive'), - (None, 'alphabetic'), - (None, 'arabic-form'), - (None, 'ascent'), - (None, 'attributeName'), - (None, 'attributeType'), - (None, 'baseProfile'), - (None, 'bbox'), - (None, 'begin'), - (None, 'by'), - (None, 'calcMode'), - (None, 'cap-height'), - (None, 'class'), - (None, 'clip-path'), - (None, 'color'), - (None, 'color-rendering'), - (None, 'content'), - (None, 'cx'), - (None, 'cy'), - (None, 'd'), - (None, 'dx'), - (None, 'dy'), - (None, 'descent'), - (None, 'display'), - (None, 'dur'), - (None, 'end'), - (None, 'fill'), - (None, 'fill-opacity'), - (None, 'fill-rule'), - (None, 'font-family'), - (None, 'font-size'), - (None, 'font-stretch'), - (None, 'font-style'), - (None, 'font-variant'), - (None, 'font-weight'), - (None, 'from'), - (None, 'fx'), - (None, 'fy'), - (None, 'g1'), - (None, 'g2'), - (None, 'glyph-name'), - (None, 'gradientUnits'), - (None, 'hanging'), - (None, 'height'), - (None, 'horiz-adv-x'), - (None, 'horiz-origin-x'), - (None, 'id'), - (None, 'ideographic'), - (None, 'k'), - (None, 'keyPoints'), - (None, 'keySplines'), - (None, 'keyTimes'), - (None, 'lang'), - (None, 'marker-end'), - (None, 'marker-mid'), - (None, 'marker-start'), - (None, 'markerHeight'), - (None, 'markerUnits'), - (None, 'markerWidth'), - (None, 'mathematical'), - (None, 'max'), - (None, 'min'), - (None, 'name'), - (None, 'offset'), - (None, 'opacity'), - (None, 'orient'), - (None, 'origin'), - (None, 'overline-position'), - (None, 'overline-thickness'), - (None, 'panose-1'), - (None, 'path'), - (None, 'pathLength'), - (None, 'points'), - (None, 'preserveAspectRatio'), - (None, 'r'), - (None, 'refX'), - (None, 'refY'), - (None, 'repeatCount'), - (None, 'repeatDur'), - (None, 'requiredExtensions'), - (None, 'requiredFeatures'), - (None, 'restart'), - (None, 'rotate'), - (None, 'rx'), - (None, 'ry'), - (None, 'slope'), - (None, 'stemh'), - (None, 'stemv'), - (None, 'stop-color'), - (None, 'stop-opacity'), - (None, 'strikethrough-position'), - (None, 'strikethrough-thickness'), - (None, 'stroke'), - (None, 'stroke-dasharray'), - (None, 'stroke-dashoffset'), - (None, 'stroke-linecap'), - (None, 'stroke-linejoin'), - (None, 'stroke-miterlimit'), - (None, 'stroke-opacity'), - (None, 'stroke-width'), - (None, 'systemLanguage'), - (None, 'target'), - (None, 'text-anchor'), - (None, 'to'), - (None, 'transform'), - (None, 'type'), - (None, 'u1'), - (None, 'u2'), - (None, 'underline-position'), - (None, 'underline-thickness'), - (None, 'unicode'), - (None, 'unicode-range'), - (None, 'units-per-em'), - (None, 'values'), - (None, 'version'), - (None, 'viewBox'), - (None, 'visibility'), - (None, 'width'), - (None, 'widths'), - (None, 'x'), - (None, 'x-height'), - (None, 'x1'), - (None, 'x2'), - (namespaces['xlink'], 'actuate'), - (namespaces['xlink'], 'arcrole'), - (namespaces['xlink'], 'href'), - (namespaces['xlink'], 'role'), - (namespaces['xlink'], 'show'), - (namespaces['xlink'], 'title'), - (namespaces['xlink'], 'type'), - (namespaces['xml'], 'base'), - (namespaces['xml'], 'lang'), - (namespaces['xml'], 'space'), - (None, 'y'), - (None, 'y1'), - (None, 'y2'), - (None, 'zoomAndPan'), -)) - -attr_val_is_uri = frozenset(( - (None, 'href'), - (None, 'src'), - (None, 'cite'), - (None, 'action'), - (None, 'longdesc'), - (None, 'poster'), - (None, 'background'), - (None, 'datasrc'), - (None, 'dynsrc'), - (None, 'lowsrc'), - (None, 'ping'), - (namespaces['xlink'], 'href'), - (namespaces['xml'], 'base'), -)) - -svg_attr_val_allows_ref = frozenset(( - (None, 'clip-path'), - (None, 'color-profile'), - (None, 'cursor'), - (None, 'fill'), - (None, 'filter'), - (None, 'marker'), - (None, 'marker-start'), - (None, 'marker-mid'), - (None, 'marker-end'), - (None, 'mask'), - (None, 'stroke'), -)) - -svg_allow_local_href = frozenset(( - (None, 'altGlyph'), - (None, 'animate'), - (None, 'animateColor'), - (None, 'animateMotion'), - (None, 'animateTransform'), - (None, 'cursor'), - (None, 'feImage'), - (None, 'filter'), - (None, 'linearGradient'), - (None, 'pattern'), - (None, 'radialGradient'), - (None, 'textpath'), - (None, 'tref'), - (None, 'set'), - (None, 'use') -)) - -allowed_css_properties = frozenset(( - 'azimuth', - 'background-color', - 'border-bottom-color', - 'border-collapse', - 'border-color', - 'border-left-color', - 'border-right-color', - 'border-top-color', - 'clear', - 'color', - 'cursor', - 'direction', - 'display', - 'elevation', - 'float', - 'font', - 'font-family', - 'font-size', - 'font-style', - 'font-variant', - 'font-weight', - 'height', - 'letter-spacing', - 'line-height', - 'overflow', - 'pause', - 'pause-after', - 'pause-before', - 'pitch', - 'pitch-range', - 'richness', - 'speak', - 'speak-header', - 'speak-numeral', - 'speak-punctuation', - 'speech-rate', - 'stress', - 'text-align', - 'text-decoration', - 'text-indent', - 'unicode-bidi', - 'vertical-align', - 'voice-family', - 'volume', - 'white-space', - 'width', -)) - -allowed_css_keywords = frozenset(( - 'auto', - 'aqua', - 'black', - 'block', - 'blue', - 'bold', - 'both', - 'bottom', - 'brown', - 'center', - 'collapse', - 'dashed', - 'dotted', - 'fuchsia', - 'gray', - 'green', - '!important', - 'italic', - 'left', - 'lime', - 'maroon', - 'medium', - 'none', - 'navy', - 'normal', - 'nowrap', - 'olive', - 'pointer', - 'purple', - 'red', - 'right', - 'solid', - 'silver', - 'teal', - 'top', - 'transparent', - 'underline', - 'white', - 'yellow', -)) - -allowed_svg_properties = frozenset(( - 'fill', - 'fill-opacity', - 'fill-rule', - 'stroke', - 'stroke-width', - 'stroke-linecap', - 'stroke-linejoin', - 'stroke-opacity', -)) - -allowed_protocols = frozenset(( - 'ed2k', - 'ftp', - 'http', - 'https', - 'irc', - 'mailto', - 'news', - 'gopher', - 'nntp', - 'telnet', - 'webcal', - 'xmpp', - 'callto', - 'feed', - 'urn', - 'aim', - 'rsync', - 'tag', - 'ssh', - 'sftp', - 'rtsp', - 'afs', - 'data', -)) - -allowed_content_types = frozenset(( - 'image/png', - 'image/jpeg', - 'image/gif', - 'image/webp', - 'image/bmp', - 'text/plain', -)) - - -data_content_type = re.compile(r''' - ^ - # Match a content type <application>/<type> - (?P<content_type>[-a-zA-Z0-9.]+/[-a-zA-Z0-9.]+) - # Match any character set and encoding - (?:(?:;charset=(?:[-a-zA-Z0-9]+)(?:;(?:base64))?) - |(?:;(?:base64))?(?:;charset=(?:[-a-zA-Z0-9]+))?) - # Assume the rest is data - ,.* - $ - ''', - re.VERBOSE) - - -class Filter(base.Filter): - """Sanitizes token stream of XHTML+MathML+SVG and of inline style attributes""" - def __init__(self, - source, - allowed_elements=allowed_elements, - allowed_attributes=allowed_attributes, - allowed_css_properties=allowed_css_properties, - allowed_css_keywords=allowed_css_keywords, - allowed_svg_properties=allowed_svg_properties, - allowed_protocols=allowed_protocols, - allowed_content_types=allowed_content_types, - attr_val_is_uri=attr_val_is_uri, - svg_attr_val_allows_ref=svg_attr_val_allows_ref, - svg_allow_local_href=svg_allow_local_href): - """Creates a Filter - - :arg allowed_elements: set of elements to allow--everything else will - be escaped - - :arg allowed_attributes: set of attributes to allow in - elements--everything else will be stripped - - :arg allowed_css_properties: set of CSS properties to allow--everything - else will be stripped - - :arg allowed_css_keywords: set of CSS keywords to allow--everything - else will be stripped - - :arg allowed_svg_properties: set of SVG properties to allow--everything - else will be removed - - :arg allowed_protocols: set of allowed protocols for URIs - - :arg allowed_content_types: set of allowed content types for ``data`` URIs. - - :arg attr_val_is_uri: set of attributes that have URI values--values - that have a scheme not listed in ``allowed_protocols`` are removed - - :arg svg_attr_val_allows_ref: set of SVG attributes that can have - references - - :arg svg_allow_local_href: set of SVG elements that can have local - hrefs--these are removed - - """ - super(Filter, self).__init__(source) - - warnings.warn(_deprecation_msg, DeprecationWarning) - - self.allowed_elements = allowed_elements - self.allowed_attributes = allowed_attributes - self.allowed_css_properties = allowed_css_properties - self.allowed_css_keywords = allowed_css_keywords - self.allowed_svg_properties = allowed_svg_properties - self.allowed_protocols = allowed_protocols - self.allowed_content_types = allowed_content_types - self.attr_val_is_uri = attr_val_is_uri - self.svg_attr_val_allows_ref = svg_attr_val_allows_ref - self.svg_allow_local_href = svg_allow_local_href - - def __iter__(self): - for token in base.Filter.__iter__(self): - token = self.sanitize_token(token) - if token: - yield token - - # Sanitize the +html+, escaping all elements not in ALLOWED_ELEMENTS, and - # stripping out all attributes not in ALLOWED_ATTRIBUTES. Style attributes - # are parsed, and a restricted set, specified by ALLOWED_CSS_PROPERTIES and - # ALLOWED_CSS_KEYWORDS, are allowed through. attributes in ATTR_VAL_IS_URI - # are scanned, and only URI schemes specified in ALLOWED_PROTOCOLS are - # allowed. - # - # sanitize_html('<script> do_nasty_stuff() </script>') - # => <script> do_nasty_stuff() </script> - # sanitize_html('<a href="javascript: sucker();">Click here for $100</a>') - # => <a>Click here for $100</a> - def sanitize_token(self, token): - - # accommodate filters which use token_type differently - token_type = token["type"] - if token_type in ("StartTag", "EndTag", "EmptyTag"): - name = token["name"] - namespace = token["namespace"] - if ((namespace, name) in self.allowed_elements or - (namespace is None and - (namespaces["html"], name) in self.allowed_elements)): - return self.allowed_token(token) - else: - return self.disallowed_token(token) - elif token_type == "Comment": - pass - else: - return token - - def allowed_token(self, token): - if "data" in token: - attrs = token["data"] - attr_names = set(attrs.keys()) - - # Remove forbidden attributes - for to_remove in (attr_names - self.allowed_attributes): - del token["data"][to_remove] - attr_names.remove(to_remove) - - # Remove attributes with disallowed URL values - for attr in (attr_names & self.attr_val_is_uri): - assert attr in attrs - # I don't have a clue where this regexp comes from or why it matches those - # characters, nor why we call unescape. I just know it's always been here. - # Should you be worried by this comment in a sanitizer? Yes. On the other hand, all - # this will do is remove *more* than it otherwise would. - val_unescaped = re.sub("[`\x00-\x20\x7f-\xa0\\s]+", '', - unescape(attrs[attr])).lower() - # remove replacement characters from unescaped characters - val_unescaped = val_unescaped.replace("\ufffd", "") - try: - uri = urlparse.urlparse(val_unescaped) - except ValueError: - uri = None - del attrs[attr] - if uri and uri.scheme: - if uri.scheme not in self.allowed_protocols: - del attrs[attr] - if uri.scheme == 'data': - m = data_content_type.match(uri.path) - if not m: - del attrs[attr] - elif m.group('content_type') not in self.allowed_content_types: - del attrs[attr] - - for attr in self.svg_attr_val_allows_ref: - if attr in attrs: - attrs[attr] = re.sub(r'url\s*\(\s*[^#\s][^)]+?\)', - ' ', - unescape(attrs[attr])) - if (token["name"] in self.svg_allow_local_href and - (namespaces['xlink'], 'href') in attrs and re.search(r'^\s*[^#\s].*', - attrs[(namespaces['xlink'], 'href')])): - del attrs[(namespaces['xlink'], 'href')] - if (None, 'style') in attrs: - attrs[(None, 'style')] = self.sanitize_css(attrs[(None, 'style')]) - token["data"] = attrs - return token - - def disallowed_token(self, token): - token_type = token["type"] - if token_type == "EndTag": - token["data"] = "</%s>" % token["name"] - elif token["data"]: - assert token_type in ("StartTag", "EmptyTag") - attrs = [] - for (ns, name), v in token["data"].items(): - attrs.append(' %s="%s"' % (name if ns is None else "%s:%s" % (prefixes[ns], name), escape(v))) - token["data"] = "<%s%s>" % (token["name"], ''.join(attrs)) - else: - token["data"] = "<%s>" % token["name"] - if token.get("selfClosing"): - token["data"] = token["data"][:-1] + "/>" - - token["type"] = "Characters" - - del token["name"] - return token - - def sanitize_css(self, style): - # disallow urls - style = re.compile(r'url\s*\(\s*[^\s)]+?\s*\)\s*').sub(' ', style) - - # gauntlet - if not re.match(r"""^([:,;#%.\sa-zA-Z0-9!]|\w-\w|'[\s\w]+'|"[\s\w]+"|\([\d,\s]+\))*$""", style): - return '' - if not re.match(r"^\s*([-\w]+\s*:[^:;]*(;\s*|$))*$", style): - return '' - - clean = [] - for prop, value in re.findall(r"([-\w]+)\s*:\s*([^:;]*)", style): - if not value: - continue - if prop.lower() in self.allowed_css_properties: - clean.append(prop + ': ' + value + ';') - elif prop.split('-')[0].lower() in ['background', 'border', 'margin', - 'padding']: - for keyword in value.split(): - if keyword not in self.allowed_css_keywords and \ - not re.match(r"^(#[0-9a-fA-F]+|rgb\(\d+%?,\d*%?,?\d*%?\)?|\d{0,2}\.?\d{0,2}(cm|em|ex|in|mm|pc|pt|px|%|,|\))?)$", keyword): # noqa - break - else: - clean.append(prop + ': ' + value + ';') - elif prop.lower() in self.allowed_svg_properties: - clean.append(prop + ': ' + value + ';') - - return ' '.join(clean) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py deleted file mode 100644 index 0d12584b..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py +++ /dev/null @@ -1,38 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -import re - -from . import base -from ..constants import rcdataElements, spaceCharacters -spaceCharacters = "".join(spaceCharacters) - -SPACES_REGEX = re.compile("[%s]+" % spaceCharacters) - - -class Filter(base.Filter): - """Collapses whitespace except in pre, textarea, and script elements""" - spacePreserveElements = frozenset(["pre", "textarea"] + list(rcdataElements)) - - def __iter__(self): - preserve = 0 - for token in base.Filter.__iter__(self): - type = token["type"] - if type == "StartTag" \ - and (preserve or token["name"] in self.spacePreserveElements): - preserve += 1 - - elif type == "EndTag" and preserve: - preserve -= 1 - - elif not preserve and type == "SpaceCharacters" and token["data"]: - # Test on token["data"] above to not introduce spaces where there were not - token["data"] = " " - - elif not preserve and type == "Characters": - token["data"] = collapse_spaces(token["data"]) - - yield token - - -def collapse_spaces(text): - return SPACES_REGEX.sub(' ', text) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/html5parser.py b/env/Lib/site-packages/pip/_vendor/html5lib/html5parser.py deleted file mode 100644 index d06784f3..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/html5parser.py +++ /dev/null @@ -1,2795 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals -from pip._vendor.six import with_metaclass, viewkeys - -import types - -from . import _inputstream -from . import _tokenizer - -from . import treebuilders -from .treebuilders.base import Marker - -from . import _utils -from .constants import ( - spaceCharacters, asciiUpper2Lower, - specialElements, headingElements, cdataElements, rcdataElements, - tokenTypes, tagTokenTypes, - namespaces, - htmlIntegrationPointElements, mathmlTextIntegrationPointElements, - adjustForeignAttributes as adjustForeignAttributesMap, - adjustMathMLAttributes, adjustSVGAttributes, - E, - _ReparseException -) - - -def parse(doc, treebuilder="etree", namespaceHTMLElements=True, **kwargs): - """Parse an HTML document as a string or file-like object into a tree - - :arg doc: the document to parse as a string or file-like object - - :arg treebuilder: the treebuilder to use when parsing - - :arg namespaceHTMLElements: whether or not to namespace HTML elements - - :returns: parsed tree - - Example: - - >>> from html5lib.html5parser import parse - >>> parse('<html><body><p>This is a doc</p></body></html>') - <Element u'{http://www.w3.org/1999/xhtml}html' at 0x7feac4909db0> - - """ - tb = treebuilders.getTreeBuilder(treebuilder) - p = HTMLParser(tb, namespaceHTMLElements=namespaceHTMLElements) - return p.parse(doc, **kwargs) - - -def parseFragment(doc, container="div", treebuilder="etree", namespaceHTMLElements=True, **kwargs): - """Parse an HTML fragment as a string or file-like object into a tree - - :arg doc: the fragment to parse as a string or file-like object - - :arg container: the container context to parse the fragment in - - :arg treebuilder: the treebuilder to use when parsing - - :arg namespaceHTMLElements: whether or not to namespace HTML elements - - :returns: parsed tree - - Example: - - >>> from html5lib.html5libparser import parseFragment - >>> parseFragment('<b>this is a fragment</b>') - <Element u'DOCUMENT_FRAGMENT' at 0x7feac484b090> - - """ - tb = treebuilders.getTreeBuilder(treebuilder) - p = HTMLParser(tb, namespaceHTMLElements=namespaceHTMLElements) - return p.parseFragment(doc, container=container, **kwargs) - - -def method_decorator_metaclass(function): - class Decorated(type): - def __new__(meta, classname, bases, classDict): - for attributeName, attribute in classDict.items(): - if isinstance(attribute, types.FunctionType): - attribute = function(attribute) - - classDict[attributeName] = attribute - return type.__new__(meta, classname, bases, classDict) - return Decorated - - -class HTMLParser(object): - """HTML parser - - Generates a tree structure from a stream of (possibly malformed) HTML. - - """ - - def __init__(self, tree=None, strict=False, namespaceHTMLElements=True, debug=False): - """ - :arg tree: a treebuilder class controlling the type of tree that will be - returned. Built in treebuilders can be accessed through - html5lib.treebuilders.getTreeBuilder(treeType) - - :arg strict: raise an exception when a parse error is encountered - - :arg namespaceHTMLElements: whether or not to namespace HTML elements - - :arg debug: whether or not to enable debug mode which logs things - - Example: - - >>> from html5lib.html5parser import HTMLParser - >>> parser = HTMLParser() # generates parser with etree builder - >>> parser = HTMLParser('lxml', strict=True) # generates parser with lxml builder which is strict - - """ - - # Raise an exception on the first error encountered - self.strict = strict - - if tree is None: - tree = treebuilders.getTreeBuilder("etree") - self.tree = tree(namespaceHTMLElements) - self.errors = [] - - self.phases = {name: cls(self, self.tree) for name, cls in - getPhases(debug).items()} - - def _parse(self, stream, innerHTML=False, container="div", scripting=False, **kwargs): - - self.innerHTMLMode = innerHTML - self.container = container - self.scripting = scripting - self.tokenizer = _tokenizer.HTMLTokenizer(stream, parser=self, **kwargs) - self.reset() - - try: - self.mainLoop() - except _ReparseException: - self.reset() - self.mainLoop() - - def reset(self): - self.tree.reset() - self.firstStartTag = False - self.errors = [] - self.log = [] # only used with debug mode - # "quirks" / "limited quirks" / "no quirks" - self.compatMode = "no quirks" - - if self.innerHTMLMode: - self.innerHTML = self.container.lower() - - if self.innerHTML in cdataElements: - self.tokenizer.state = self.tokenizer.rcdataState - elif self.innerHTML in rcdataElements: - self.tokenizer.state = self.tokenizer.rawtextState - elif self.innerHTML == 'plaintext': - self.tokenizer.state = self.tokenizer.plaintextState - else: - # state already is data state - # self.tokenizer.state = self.tokenizer.dataState - pass - self.phase = self.phases["beforeHtml"] - self.phase.insertHtmlElement() - self.resetInsertionMode() - else: - self.innerHTML = False # pylint:disable=redefined-variable-type - self.phase = self.phases["initial"] - - self.lastPhase = None - - self.beforeRCDataPhase = None - - self.framesetOK = True - - @property - def documentEncoding(self): - """Name of the character encoding that was used to decode the input stream, or - :obj:`None` if that is not determined yet - - """ - if not hasattr(self, 'tokenizer'): - return None - return self.tokenizer.stream.charEncoding[0].name - - def isHTMLIntegrationPoint(self, element): - if (element.name == "annotation-xml" and - element.namespace == namespaces["mathml"]): - return ("encoding" in element.attributes and - element.attributes["encoding"].translate( - asciiUpper2Lower) in - ("text/html", "application/xhtml+xml")) - else: - return (element.namespace, element.name) in htmlIntegrationPointElements - - def isMathMLTextIntegrationPoint(self, element): - return (element.namespace, element.name) in mathmlTextIntegrationPointElements - - def mainLoop(self): - CharactersToken = tokenTypes["Characters"] - SpaceCharactersToken = tokenTypes["SpaceCharacters"] - StartTagToken = tokenTypes["StartTag"] - EndTagToken = tokenTypes["EndTag"] - CommentToken = tokenTypes["Comment"] - DoctypeToken = tokenTypes["Doctype"] - ParseErrorToken = tokenTypes["ParseError"] - - for token in self.tokenizer: - prev_token = None - new_token = token - while new_token is not None: - prev_token = new_token - currentNode = self.tree.openElements[-1] if self.tree.openElements else None - currentNodeNamespace = currentNode.namespace if currentNode else None - currentNodeName = currentNode.name if currentNode else None - - type = new_token["type"] - - if type == ParseErrorToken: - self.parseError(new_token["data"], new_token.get("datavars", {})) - new_token = None - else: - if (len(self.tree.openElements) == 0 or - currentNodeNamespace == self.tree.defaultNamespace or - (self.isMathMLTextIntegrationPoint(currentNode) and - ((type == StartTagToken and - token["name"] not in frozenset(["mglyph", "malignmark"])) or - type in (CharactersToken, SpaceCharactersToken))) or - (currentNodeNamespace == namespaces["mathml"] and - currentNodeName == "annotation-xml" and - type == StartTagToken and - token["name"] == "svg") or - (self.isHTMLIntegrationPoint(currentNode) and - type in (StartTagToken, CharactersToken, SpaceCharactersToken))): - phase = self.phase - else: - phase = self.phases["inForeignContent"] - - if type == CharactersToken: - new_token = phase.processCharacters(new_token) - elif type == SpaceCharactersToken: - new_token = phase.processSpaceCharacters(new_token) - elif type == StartTagToken: - new_token = phase.processStartTag(new_token) - elif type == EndTagToken: - new_token = phase.processEndTag(new_token) - elif type == CommentToken: - new_token = phase.processComment(new_token) - elif type == DoctypeToken: - new_token = phase.processDoctype(new_token) - - if (type == StartTagToken and prev_token["selfClosing"] and - not prev_token["selfClosingAcknowledged"]): - self.parseError("non-void-element-with-trailing-solidus", - {"name": prev_token["name"]}) - - # When the loop finishes it's EOF - reprocess = True - phases = [] - while reprocess: - phases.append(self.phase) - reprocess = self.phase.processEOF() - if reprocess: - assert self.phase not in phases - - def parse(self, stream, *args, **kwargs): - """Parse a HTML document into a well-formed tree - - :arg stream: a file-like object or string containing the HTML to be parsed - - The optional encoding parameter must be a string that indicates - the encoding. If specified, that encoding will be used, - regardless of any BOM or later declaration (such as in a meta - element). - - :arg scripting: treat noscript elements as if JavaScript was turned on - - :returns: parsed tree - - Example: - - >>> from html5lib.html5parser import HTMLParser - >>> parser = HTMLParser() - >>> parser.parse('<html><body><p>This is a doc</p></body></html>') - <Element u'{http://www.w3.org/1999/xhtml}html' at 0x7feac4909db0> - - """ - self._parse(stream, False, None, *args, **kwargs) - return self.tree.getDocument() - - def parseFragment(self, stream, *args, **kwargs): - """Parse a HTML fragment into a well-formed tree fragment - - :arg container: name of the element we're setting the innerHTML - property if set to None, default to 'div' - - :arg stream: a file-like object or string containing the HTML to be parsed - - The optional encoding parameter must be a string that indicates - the encoding. If specified, that encoding will be used, - regardless of any BOM or later declaration (such as in a meta - element) - - :arg scripting: treat noscript elements as if JavaScript was turned on - - :returns: parsed tree - - Example: - - >>> from html5lib.html5libparser import HTMLParser - >>> parser = HTMLParser() - >>> parser.parseFragment('<b>this is a fragment</b>') - <Element u'DOCUMENT_FRAGMENT' at 0x7feac484b090> - - """ - self._parse(stream, True, *args, **kwargs) - return self.tree.getFragment() - - def parseError(self, errorcode="XXX-undefined-error", datavars=None): - # XXX The idea is to make errorcode mandatory. - if datavars is None: - datavars = {} - self.errors.append((self.tokenizer.stream.position(), errorcode, datavars)) - if self.strict: - raise ParseError(E[errorcode] % datavars) - - def adjustMathMLAttributes(self, token): - adjust_attributes(token, adjustMathMLAttributes) - - def adjustSVGAttributes(self, token): - adjust_attributes(token, adjustSVGAttributes) - - def adjustForeignAttributes(self, token): - adjust_attributes(token, adjustForeignAttributesMap) - - def reparseTokenNormal(self, token): - # pylint:disable=unused-argument - self.parser.phase() - - def resetInsertionMode(self): - # The name of this method is mostly historical. (It's also used in the - # specification.) - last = False - newModes = { - "select": "inSelect", - "td": "inCell", - "th": "inCell", - "tr": "inRow", - "tbody": "inTableBody", - "thead": "inTableBody", - "tfoot": "inTableBody", - "caption": "inCaption", - "colgroup": "inColumnGroup", - "table": "inTable", - "head": "inBody", - "body": "inBody", - "frameset": "inFrameset", - "html": "beforeHead" - } - for node in self.tree.openElements[::-1]: - nodeName = node.name - new_phase = None - if node == self.tree.openElements[0]: - assert self.innerHTML - last = True - nodeName = self.innerHTML - # Check for conditions that should only happen in the innerHTML - # case - if nodeName in ("select", "colgroup", "head", "html"): - assert self.innerHTML - - if not last and node.namespace != self.tree.defaultNamespace: - continue - - if nodeName in newModes: - new_phase = self.phases[newModes[nodeName]] - break - elif last: - new_phase = self.phases["inBody"] - break - - self.phase = new_phase - - def parseRCDataRawtext(self, token, contentType): - # Generic RCDATA/RAWTEXT Parsing algorithm - assert contentType in ("RAWTEXT", "RCDATA") - - self.tree.insertElement(token) - - if contentType == "RAWTEXT": - self.tokenizer.state = self.tokenizer.rawtextState - else: - self.tokenizer.state = self.tokenizer.rcdataState - - self.originalPhase = self.phase - - self.phase = self.phases["text"] - - -@_utils.memoize -def getPhases(debug): - def log(function): - """Logger that records which phase processes each token""" - type_names = {value: key for key, value in tokenTypes.items()} - - def wrapped(self, *args, **kwargs): - if function.__name__.startswith("process") and len(args) > 0: - token = args[0] - info = {"type": type_names[token['type']]} - if token['type'] in tagTokenTypes: - info["name"] = token['name'] - - self.parser.log.append((self.parser.tokenizer.state.__name__, - self.parser.phase.__class__.__name__, - self.__class__.__name__, - function.__name__, - info)) - return function(self, *args, **kwargs) - else: - return function(self, *args, **kwargs) - return wrapped - - def getMetaclass(use_metaclass, metaclass_func): - if use_metaclass: - return method_decorator_metaclass(metaclass_func) - else: - return type - - # pylint:disable=unused-argument - class Phase(with_metaclass(getMetaclass(debug, log))): - """Base class for helper object that implements each phase of processing - """ - __slots__ = ("parser", "tree", "__startTagCache", "__endTagCache") - - def __init__(self, parser, tree): - self.parser = parser - self.tree = tree - self.__startTagCache = {} - self.__endTagCache = {} - - def processEOF(self): - raise NotImplementedError - - def processComment(self, token): - # For most phases the following is correct. Where it's not it will be - # overridden. - self.tree.insertComment(token, self.tree.openElements[-1]) - - def processDoctype(self, token): - self.parser.parseError("unexpected-doctype") - - def processCharacters(self, token): - self.tree.insertText(token["data"]) - - def processSpaceCharacters(self, token): - self.tree.insertText(token["data"]) - - def processStartTag(self, token): - # Note the caching is done here rather than BoundMethodDispatcher as doing it there - # requires a circular reference to the Phase, and this ends up with a significant - # (CPython 2.7, 3.8) GC cost when parsing many short inputs - name = token["name"] - # In Py2, using `in` is quicker in general than try/except KeyError - # In Py3, `in` is quicker when there are few cache hits (typically short inputs) - if name in self.__startTagCache: - func = self.__startTagCache[name] - else: - func = self.__startTagCache[name] = self.startTagHandler[name] - # bound the cache size in case we get loads of unknown tags - while len(self.__startTagCache) > len(self.startTagHandler) * 1.1: - # this makes the eviction policy random on Py < 3.7 and FIFO >= 3.7 - self.__startTagCache.pop(next(iter(self.__startTagCache))) - return func(token) - - def startTagHtml(self, token): - if not self.parser.firstStartTag and token["name"] == "html": - self.parser.parseError("non-html-root") - # XXX Need a check here to see if the first start tag token emitted is - # this token... If it's not, invoke self.parser.parseError(). - for attr, value in token["data"].items(): - if attr not in self.tree.openElements[0].attributes: - self.tree.openElements[0].attributes[attr] = value - self.parser.firstStartTag = False - - def processEndTag(self, token): - # Note the caching is done here rather than BoundMethodDispatcher as doing it there - # requires a circular reference to the Phase, and this ends up with a significant - # (CPython 2.7, 3.8) GC cost when parsing many short inputs - name = token["name"] - # In Py2, using `in` is quicker in general than try/except KeyError - # In Py3, `in` is quicker when there are few cache hits (typically short inputs) - if name in self.__endTagCache: - func = self.__endTagCache[name] - else: - func = self.__endTagCache[name] = self.endTagHandler[name] - # bound the cache size in case we get loads of unknown tags - while len(self.__endTagCache) > len(self.endTagHandler) * 1.1: - # this makes the eviction policy random on Py < 3.7 and FIFO >= 3.7 - self.__endTagCache.pop(next(iter(self.__endTagCache))) - return func(token) - - class InitialPhase(Phase): - __slots__ = tuple() - - def processSpaceCharacters(self, token): - pass - - def processComment(self, token): - self.tree.insertComment(token, self.tree.document) - - def processDoctype(self, token): - name = token["name"] - publicId = token["publicId"] - systemId = token["systemId"] - correct = token["correct"] - - if (name != "html" or publicId is not None or - systemId is not None and systemId != "about:legacy-compat"): - self.parser.parseError("unknown-doctype") - - if publicId is None: - publicId = "" - - self.tree.insertDoctype(token) - - if publicId != "": - publicId = publicId.translate(asciiUpper2Lower) - - if (not correct or token["name"] != "html" or - publicId.startswith( - ("+//silmaril//dtd html pro v0r11 19970101//", - "-//advasoft ltd//dtd html 3.0 aswedit + extensions//", - "-//as//dtd html 3.0 aswedit + extensions//", - "-//ietf//dtd html 2.0 level 1//", - "-//ietf//dtd html 2.0 level 2//", - "-//ietf//dtd html 2.0 strict level 1//", - "-//ietf//dtd html 2.0 strict level 2//", - "-//ietf//dtd html 2.0 strict//", - "-//ietf//dtd html 2.0//", - "-//ietf//dtd html 2.1e//", - "-//ietf//dtd html 3.0//", - "-//ietf//dtd html 3.2 final//", - "-//ietf//dtd html 3.2//", - "-//ietf//dtd html 3//", - "-//ietf//dtd html level 0//", - "-//ietf//dtd html level 1//", - "-//ietf//dtd html level 2//", - "-//ietf//dtd html level 3//", - "-//ietf//dtd html strict level 0//", - "-//ietf//dtd html strict level 1//", - "-//ietf//dtd html strict level 2//", - "-//ietf//dtd html strict level 3//", - "-//ietf//dtd html strict//", - "-//ietf//dtd html//", - "-//metrius//dtd metrius presentational//", - "-//microsoft//dtd internet explorer 2.0 html strict//", - "-//microsoft//dtd internet explorer 2.0 html//", - "-//microsoft//dtd internet explorer 2.0 tables//", - "-//microsoft//dtd internet explorer 3.0 html strict//", - "-//microsoft//dtd internet explorer 3.0 html//", - "-//microsoft//dtd internet explorer 3.0 tables//", - "-//netscape comm. corp.//dtd html//", - "-//netscape comm. corp.//dtd strict html//", - "-//o'reilly and associates//dtd html 2.0//", - "-//o'reilly and associates//dtd html extended 1.0//", - "-//o'reilly and associates//dtd html extended relaxed 1.0//", - "-//softquad software//dtd hotmetal pro 6.0::19990601::extensions to html 4.0//", - "-//softquad//dtd hotmetal pro 4.0::19971010::extensions to html 4.0//", - "-//spyglass//dtd html 2.0 extended//", - "-//sq//dtd html 2.0 hotmetal + extensions//", - "-//sun microsystems corp.//dtd hotjava html//", - "-//sun microsystems corp.//dtd hotjava strict html//", - "-//w3c//dtd html 3 1995-03-24//", - "-//w3c//dtd html 3.2 draft//", - "-//w3c//dtd html 3.2 final//", - "-//w3c//dtd html 3.2//", - "-//w3c//dtd html 3.2s draft//", - "-//w3c//dtd html 4.0 frameset//", - "-//w3c//dtd html 4.0 transitional//", - "-//w3c//dtd html experimental 19960712//", - "-//w3c//dtd html experimental 970421//", - "-//w3c//dtd w3 html//", - "-//w3o//dtd w3 html 3.0//", - "-//webtechs//dtd mozilla html 2.0//", - "-//webtechs//dtd mozilla html//")) or - publicId in ("-//w3o//dtd w3 html strict 3.0//en//", - "-/w3c/dtd html 4.0 transitional/en", - "html") or - publicId.startswith( - ("-//w3c//dtd html 4.01 frameset//", - "-//w3c//dtd html 4.01 transitional//")) and - systemId is None or - systemId and systemId.lower() == "http://www.ibm.com/data/dtd/v11/ibmxhtml1-transitional.dtd"): - self.parser.compatMode = "quirks" - elif (publicId.startswith( - ("-//w3c//dtd xhtml 1.0 frameset//", - "-//w3c//dtd xhtml 1.0 transitional//")) or - publicId.startswith( - ("-//w3c//dtd html 4.01 frameset//", - "-//w3c//dtd html 4.01 transitional//")) and - systemId is not None): - self.parser.compatMode = "limited quirks" - - self.parser.phase = self.parser.phases["beforeHtml"] - - def anythingElse(self): - self.parser.compatMode = "quirks" - self.parser.phase = self.parser.phases["beforeHtml"] - - def processCharacters(self, token): - self.parser.parseError("expected-doctype-but-got-chars") - self.anythingElse() - return token - - def processStartTag(self, token): - self.parser.parseError("expected-doctype-but-got-start-tag", - {"name": token["name"]}) - self.anythingElse() - return token - - def processEndTag(self, token): - self.parser.parseError("expected-doctype-but-got-end-tag", - {"name": token["name"]}) - self.anythingElse() - return token - - def processEOF(self): - self.parser.parseError("expected-doctype-but-got-eof") - self.anythingElse() - return True - - class BeforeHtmlPhase(Phase): - __slots__ = tuple() - - # helper methods - def insertHtmlElement(self): - self.tree.insertRoot(impliedTagToken("html", "StartTag")) - self.parser.phase = self.parser.phases["beforeHead"] - - # other - def processEOF(self): - self.insertHtmlElement() - return True - - def processComment(self, token): - self.tree.insertComment(token, self.tree.document) - - def processSpaceCharacters(self, token): - pass - - def processCharacters(self, token): - self.insertHtmlElement() - return token - - def processStartTag(self, token): - if token["name"] == "html": - self.parser.firstStartTag = True - self.insertHtmlElement() - return token - - def processEndTag(self, token): - if token["name"] not in ("head", "body", "html", "br"): - self.parser.parseError("unexpected-end-tag-before-html", - {"name": token["name"]}) - else: - self.insertHtmlElement() - return token - - class BeforeHeadPhase(Phase): - __slots__ = tuple() - - def processEOF(self): - self.startTagHead(impliedTagToken("head", "StartTag")) - return True - - def processSpaceCharacters(self, token): - pass - - def processCharacters(self, token): - self.startTagHead(impliedTagToken("head", "StartTag")) - return token - - def startTagHtml(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def startTagHead(self, token): - self.tree.insertElement(token) - self.tree.headPointer = self.tree.openElements[-1] - self.parser.phase = self.parser.phases["inHead"] - - def startTagOther(self, token): - self.startTagHead(impliedTagToken("head", "StartTag")) - return token - - def endTagImplyHead(self, token): - self.startTagHead(impliedTagToken("head", "StartTag")) - return token - - def endTagOther(self, token): - self.parser.parseError("end-tag-after-implied-root", - {"name": token["name"]}) - - startTagHandler = _utils.MethodDispatcher([ - ("html", startTagHtml), - ("head", startTagHead) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - (("head", "body", "html", "br"), endTagImplyHead) - ]) - endTagHandler.default = endTagOther - - class InHeadPhase(Phase): - __slots__ = tuple() - - # the real thing - def processEOF(self): - self.anythingElse() - return True - - def processCharacters(self, token): - self.anythingElse() - return token - - def startTagHtml(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def startTagHead(self, token): - self.parser.parseError("two-heads-are-not-better-than-one") - - def startTagBaseLinkCommand(self, token): - self.tree.insertElement(token) - self.tree.openElements.pop() - token["selfClosingAcknowledged"] = True - - def startTagMeta(self, token): - self.tree.insertElement(token) - self.tree.openElements.pop() - token["selfClosingAcknowledged"] = True - - attributes = token["data"] - if self.parser.tokenizer.stream.charEncoding[1] == "tentative": - if "charset" in attributes: - self.parser.tokenizer.stream.changeEncoding(attributes["charset"]) - elif ("content" in attributes and - "http-equiv" in attributes and - attributes["http-equiv"].lower() == "content-type"): - # Encoding it as UTF-8 here is a hack, as really we should pass - # the abstract Unicode string, and just use the - # ContentAttrParser on that, but using UTF-8 allows all chars - # to be encoded and as a ASCII-superset works. - data = _inputstream.EncodingBytes(attributes["content"].encode("utf-8")) - parser = _inputstream.ContentAttrParser(data) - codec = parser.parse() - self.parser.tokenizer.stream.changeEncoding(codec) - - def startTagTitle(self, token): - self.parser.parseRCDataRawtext(token, "RCDATA") - - def startTagNoFramesStyle(self, token): - # Need to decide whether to implement the scripting-disabled case - self.parser.parseRCDataRawtext(token, "RAWTEXT") - - def startTagNoscript(self, token): - if self.parser.scripting: - self.parser.parseRCDataRawtext(token, "RAWTEXT") - else: - self.tree.insertElement(token) - self.parser.phase = self.parser.phases["inHeadNoscript"] - - def startTagScript(self, token): - self.tree.insertElement(token) - self.parser.tokenizer.state = self.parser.tokenizer.scriptDataState - self.parser.originalPhase = self.parser.phase - self.parser.phase = self.parser.phases["text"] - - def startTagOther(self, token): - self.anythingElse() - return token - - def endTagHead(self, token): - node = self.parser.tree.openElements.pop() - assert node.name == "head", "Expected head got %s" % node.name - self.parser.phase = self.parser.phases["afterHead"] - - def endTagHtmlBodyBr(self, token): - self.anythingElse() - return token - - def endTagOther(self, token): - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - - def anythingElse(self): - self.endTagHead(impliedTagToken("head")) - - startTagHandler = _utils.MethodDispatcher([ - ("html", startTagHtml), - ("title", startTagTitle), - (("noframes", "style"), startTagNoFramesStyle), - ("noscript", startTagNoscript), - ("script", startTagScript), - (("base", "basefont", "bgsound", "command", "link"), - startTagBaseLinkCommand), - ("meta", startTagMeta), - ("head", startTagHead) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("head", endTagHead), - (("br", "html", "body"), endTagHtmlBodyBr) - ]) - endTagHandler.default = endTagOther - - class InHeadNoscriptPhase(Phase): - __slots__ = tuple() - - def processEOF(self): - self.parser.parseError("eof-in-head-noscript") - self.anythingElse() - return True - - def processComment(self, token): - return self.parser.phases["inHead"].processComment(token) - - def processCharacters(self, token): - self.parser.parseError("char-in-head-noscript") - self.anythingElse() - return token - - def processSpaceCharacters(self, token): - return self.parser.phases["inHead"].processSpaceCharacters(token) - - def startTagHtml(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def startTagBaseLinkCommand(self, token): - return self.parser.phases["inHead"].processStartTag(token) - - def startTagHeadNoscript(self, token): - self.parser.parseError("unexpected-start-tag", {"name": token["name"]}) - - def startTagOther(self, token): - self.parser.parseError("unexpected-inhead-noscript-tag", {"name": token["name"]}) - self.anythingElse() - return token - - def endTagNoscript(self, token): - node = self.parser.tree.openElements.pop() - assert node.name == "noscript", "Expected noscript got %s" % node.name - self.parser.phase = self.parser.phases["inHead"] - - def endTagBr(self, token): - self.parser.parseError("unexpected-inhead-noscript-tag", {"name": token["name"]}) - self.anythingElse() - return token - - def endTagOther(self, token): - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - - def anythingElse(self): - # Caller must raise parse error first! - self.endTagNoscript(impliedTagToken("noscript")) - - startTagHandler = _utils.MethodDispatcher([ - ("html", startTagHtml), - (("basefont", "bgsound", "link", "meta", "noframes", "style"), startTagBaseLinkCommand), - (("head", "noscript"), startTagHeadNoscript), - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("noscript", endTagNoscript), - ("br", endTagBr), - ]) - endTagHandler.default = endTagOther - - class AfterHeadPhase(Phase): - __slots__ = tuple() - - def processEOF(self): - self.anythingElse() - return True - - def processCharacters(self, token): - self.anythingElse() - return token - - def startTagHtml(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def startTagBody(self, token): - self.parser.framesetOK = False - self.tree.insertElement(token) - self.parser.phase = self.parser.phases["inBody"] - - def startTagFrameset(self, token): - self.tree.insertElement(token) - self.parser.phase = self.parser.phases["inFrameset"] - - def startTagFromHead(self, token): - self.parser.parseError("unexpected-start-tag-out-of-my-head", - {"name": token["name"]}) - self.tree.openElements.append(self.tree.headPointer) - self.parser.phases["inHead"].processStartTag(token) - for node in self.tree.openElements[::-1]: - if node.name == "head": - self.tree.openElements.remove(node) - break - - def startTagHead(self, token): - self.parser.parseError("unexpected-start-tag", {"name": token["name"]}) - - def startTagOther(self, token): - self.anythingElse() - return token - - def endTagHtmlBodyBr(self, token): - self.anythingElse() - return token - - def endTagOther(self, token): - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - - def anythingElse(self): - self.tree.insertElement(impliedTagToken("body", "StartTag")) - self.parser.phase = self.parser.phases["inBody"] - self.parser.framesetOK = True - - startTagHandler = _utils.MethodDispatcher([ - ("html", startTagHtml), - ("body", startTagBody), - ("frameset", startTagFrameset), - (("base", "basefont", "bgsound", "link", "meta", "noframes", "script", - "style", "title"), - startTagFromHead), - ("head", startTagHead) - ]) - startTagHandler.default = startTagOther - endTagHandler = _utils.MethodDispatcher([(("body", "html", "br"), - endTagHtmlBodyBr)]) - endTagHandler.default = endTagOther - - class InBodyPhase(Phase): - # http://www.whatwg.org/specs/web-apps/current-work/#parsing-main-inbody - # the really-really-really-very crazy mode - __slots__ = ("processSpaceCharacters",) - - def __init__(self, *args, **kwargs): - super(InBodyPhase, self).__init__(*args, **kwargs) - # Set this to the default handler - self.processSpaceCharacters = self.processSpaceCharactersNonPre - - def isMatchingFormattingElement(self, node1, node2): - return (node1.name == node2.name and - node1.namespace == node2.namespace and - node1.attributes == node2.attributes) - - # helper - def addFormattingElement(self, token): - self.tree.insertElement(token) - element = self.tree.openElements[-1] - - matchingElements = [] - for node in self.tree.activeFormattingElements[::-1]: - if node is Marker: - break - elif self.isMatchingFormattingElement(node, element): - matchingElements.append(node) - - assert len(matchingElements) <= 3 - if len(matchingElements) == 3: - self.tree.activeFormattingElements.remove(matchingElements[-1]) - self.tree.activeFormattingElements.append(element) - - # the real deal - def processEOF(self): - allowed_elements = frozenset(("dd", "dt", "li", "p", "tbody", "td", - "tfoot", "th", "thead", "tr", "body", - "html")) - for node in self.tree.openElements[::-1]: - if node.name not in allowed_elements: - self.parser.parseError("expected-closing-tag-but-got-eof") - break - # Stop parsing - - def processSpaceCharactersDropNewline(self, token): - # Sometimes (start of <pre>, <listing>, and <textarea> blocks) we - # want to drop leading newlines - data = token["data"] - self.processSpaceCharacters = self.processSpaceCharactersNonPre - if (data.startswith("\n") and - self.tree.openElements[-1].name in ("pre", "listing", "textarea") and - not self.tree.openElements[-1].hasContent()): - data = data[1:] - if data: - self.tree.reconstructActiveFormattingElements() - self.tree.insertText(data) - - def processCharacters(self, token): - if token["data"] == "\u0000": - # The tokenizer should always emit null on its own - return - self.tree.reconstructActiveFormattingElements() - self.tree.insertText(token["data"]) - # This must be bad for performance - if (self.parser.framesetOK and - any([char not in spaceCharacters - for char in token["data"]])): - self.parser.framesetOK = False - - def processSpaceCharactersNonPre(self, token): - self.tree.reconstructActiveFormattingElements() - self.tree.insertText(token["data"]) - - def startTagProcessInHead(self, token): - return self.parser.phases["inHead"].processStartTag(token) - - def startTagBody(self, token): - self.parser.parseError("unexpected-start-tag", {"name": "body"}) - if (len(self.tree.openElements) == 1 or - self.tree.openElements[1].name != "body"): - assert self.parser.innerHTML - else: - self.parser.framesetOK = False - for attr, value in token["data"].items(): - if attr not in self.tree.openElements[1].attributes: - self.tree.openElements[1].attributes[attr] = value - - def startTagFrameset(self, token): - self.parser.parseError("unexpected-start-tag", {"name": "frameset"}) - if (len(self.tree.openElements) == 1 or self.tree.openElements[1].name != "body"): - assert self.parser.innerHTML - elif not self.parser.framesetOK: - pass - else: - if self.tree.openElements[1].parent: - self.tree.openElements[1].parent.removeChild(self.tree.openElements[1]) - while self.tree.openElements[-1].name != "html": - self.tree.openElements.pop() - self.tree.insertElement(token) - self.parser.phase = self.parser.phases["inFrameset"] - - def startTagCloseP(self, token): - if self.tree.elementInScope("p", variant="button"): - self.endTagP(impliedTagToken("p")) - self.tree.insertElement(token) - - def startTagPreListing(self, token): - if self.tree.elementInScope("p", variant="button"): - self.endTagP(impliedTagToken("p")) - self.tree.insertElement(token) - self.parser.framesetOK = False - self.processSpaceCharacters = self.processSpaceCharactersDropNewline - - def startTagForm(self, token): - if self.tree.formPointer: - self.parser.parseError("unexpected-start-tag", {"name": "form"}) - else: - if self.tree.elementInScope("p", variant="button"): - self.endTagP(impliedTagToken("p")) - self.tree.insertElement(token) - self.tree.formPointer = self.tree.openElements[-1] - - def startTagListItem(self, token): - self.parser.framesetOK = False - - stopNamesMap = {"li": ["li"], - "dt": ["dt", "dd"], - "dd": ["dt", "dd"]} - stopNames = stopNamesMap[token["name"]] - for node in reversed(self.tree.openElements): - if node.name in stopNames: - self.parser.phase.processEndTag( - impliedTagToken(node.name, "EndTag")) - break - if (node.nameTuple in specialElements and - node.name not in ("address", "div", "p")): - break - - if self.tree.elementInScope("p", variant="button"): - self.parser.phase.processEndTag( - impliedTagToken("p", "EndTag")) - - self.tree.insertElement(token) - - def startTagPlaintext(self, token): - if self.tree.elementInScope("p", variant="button"): - self.endTagP(impliedTagToken("p")) - self.tree.insertElement(token) - self.parser.tokenizer.state = self.parser.tokenizer.plaintextState - - def startTagHeading(self, token): - if self.tree.elementInScope("p", variant="button"): - self.endTagP(impliedTagToken("p")) - if self.tree.openElements[-1].name in headingElements: - self.parser.parseError("unexpected-start-tag", {"name": token["name"]}) - self.tree.openElements.pop() - self.tree.insertElement(token) - - def startTagA(self, token): - afeAElement = self.tree.elementInActiveFormattingElements("a") - if afeAElement: - self.parser.parseError("unexpected-start-tag-implies-end-tag", - {"startName": "a", "endName": "a"}) - self.endTagFormatting(impliedTagToken("a")) - if afeAElement in self.tree.openElements: - self.tree.openElements.remove(afeAElement) - if afeAElement in self.tree.activeFormattingElements: - self.tree.activeFormattingElements.remove(afeAElement) - self.tree.reconstructActiveFormattingElements() - self.addFormattingElement(token) - - def startTagFormatting(self, token): - self.tree.reconstructActiveFormattingElements() - self.addFormattingElement(token) - - def startTagNobr(self, token): - self.tree.reconstructActiveFormattingElements() - if self.tree.elementInScope("nobr"): - self.parser.parseError("unexpected-start-tag-implies-end-tag", - {"startName": "nobr", "endName": "nobr"}) - self.processEndTag(impliedTagToken("nobr")) - # XXX Need tests that trigger the following - self.tree.reconstructActiveFormattingElements() - self.addFormattingElement(token) - - def startTagButton(self, token): - if self.tree.elementInScope("button"): - self.parser.parseError("unexpected-start-tag-implies-end-tag", - {"startName": "button", "endName": "button"}) - self.processEndTag(impliedTagToken("button")) - return token - else: - self.tree.reconstructActiveFormattingElements() - self.tree.insertElement(token) - self.parser.framesetOK = False - - def startTagAppletMarqueeObject(self, token): - self.tree.reconstructActiveFormattingElements() - self.tree.insertElement(token) - self.tree.activeFormattingElements.append(Marker) - self.parser.framesetOK = False - - def startTagXmp(self, token): - if self.tree.elementInScope("p", variant="button"): - self.endTagP(impliedTagToken("p")) - self.tree.reconstructActiveFormattingElements() - self.parser.framesetOK = False - self.parser.parseRCDataRawtext(token, "RAWTEXT") - - def startTagTable(self, token): - if self.parser.compatMode != "quirks": - if self.tree.elementInScope("p", variant="button"): - self.processEndTag(impliedTagToken("p")) - self.tree.insertElement(token) - self.parser.framesetOK = False - self.parser.phase = self.parser.phases["inTable"] - - def startTagVoidFormatting(self, token): - self.tree.reconstructActiveFormattingElements() - self.tree.insertElement(token) - self.tree.openElements.pop() - token["selfClosingAcknowledged"] = True - self.parser.framesetOK = False - - def startTagInput(self, token): - framesetOK = self.parser.framesetOK - self.startTagVoidFormatting(token) - if ("type" in token["data"] and - token["data"]["type"].translate(asciiUpper2Lower) == "hidden"): - # input type=hidden doesn't change framesetOK - self.parser.framesetOK = framesetOK - - def startTagParamSource(self, token): - self.tree.insertElement(token) - self.tree.openElements.pop() - token["selfClosingAcknowledged"] = True - - def startTagHr(self, token): - if self.tree.elementInScope("p", variant="button"): - self.endTagP(impliedTagToken("p")) - self.tree.insertElement(token) - self.tree.openElements.pop() - token["selfClosingAcknowledged"] = True - self.parser.framesetOK = False - - def startTagImage(self, token): - # No really... - self.parser.parseError("unexpected-start-tag-treated-as", - {"originalName": "image", "newName": "img"}) - self.processStartTag(impliedTagToken("img", "StartTag", - attributes=token["data"], - selfClosing=token["selfClosing"])) - - def startTagIsIndex(self, token): - self.parser.parseError("deprecated-tag", {"name": "isindex"}) - if self.tree.formPointer: - return - form_attrs = {} - if "action" in token["data"]: - form_attrs["action"] = token["data"]["action"] - self.processStartTag(impliedTagToken("form", "StartTag", - attributes=form_attrs)) - self.processStartTag(impliedTagToken("hr", "StartTag")) - self.processStartTag(impliedTagToken("label", "StartTag")) - # XXX Localization ... - if "prompt" in token["data"]: - prompt = token["data"]["prompt"] - else: - prompt = "This is a searchable index. Enter search keywords: " - self.processCharacters( - {"type": tokenTypes["Characters"], "data": prompt}) - attributes = token["data"].copy() - if "action" in attributes: - del attributes["action"] - if "prompt" in attributes: - del attributes["prompt"] - attributes["name"] = "isindex" - self.processStartTag(impliedTagToken("input", "StartTag", - attributes=attributes, - selfClosing=token["selfClosing"])) - self.processEndTag(impliedTagToken("label")) - self.processStartTag(impliedTagToken("hr", "StartTag")) - self.processEndTag(impliedTagToken("form")) - - def startTagTextarea(self, token): - self.tree.insertElement(token) - self.parser.tokenizer.state = self.parser.tokenizer.rcdataState - self.processSpaceCharacters = self.processSpaceCharactersDropNewline - self.parser.framesetOK = False - - def startTagIFrame(self, token): - self.parser.framesetOK = False - self.startTagRawtext(token) - - def startTagNoscript(self, token): - if self.parser.scripting: - self.startTagRawtext(token) - else: - self.startTagOther(token) - - def startTagRawtext(self, token): - """iframe, noembed noframes, noscript(if scripting enabled)""" - self.parser.parseRCDataRawtext(token, "RAWTEXT") - - def startTagOpt(self, token): - if self.tree.openElements[-1].name == "option": - self.parser.phase.processEndTag(impliedTagToken("option")) - self.tree.reconstructActiveFormattingElements() - self.parser.tree.insertElement(token) - - def startTagSelect(self, token): - self.tree.reconstructActiveFormattingElements() - self.tree.insertElement(token) - self.parser.framesetOK = False - if self.parser.phase in (self.parser.phases["inTable"], - self.parser.phases["inCaption"], - self.parser.phases["inColumnGroup"], - self.parser.phases["inTableBody"], - self.parser.phases["inRow"], - self.parser.phases["inCell"]): - self.parser.phase = self.parser.phases["inSelectInTable"] - else: - self.parser.phase = self.parser.phases["inSelect"] - - def startTagRpRt(self, token): - if self.tree.elementInScope("ruby"): - self.tree.generateImpliedEndTags() - if self.tree.openElements[-1].name != "ruby": - self.parser.parseError() - self.tree.insertElement(token) - - def startTagMath(self, token): - self.tree.reconstructActiveFormattingElements() - self.parser.adjustMathMLAttributes(token) - self.parser.adjustForeignAttributes(token) - token["namespace"] = namespaces["mathml"] - self.tree.insertElement(token) - # Need to get the parse error right for the case where the token - # has a namespace not equal to the xmlns attribute - if token["selfClosing"]: - self.tree.openElements.pop() - token["selfClosingAcknowledged"] = True - - def startTagSvg(self, token): - self.tree.reconstructActiveFormattingElements() - self.parser.adjustSVGAttributes(token) - self.parser.adjustForeignAttributes(token) - token["namespace"] = namespaces["svg"] - self.tree.insertElement(token) - # Need to get the parse error right for the case where the token - # has a namespace not equal to the xmlns attribute - if token["selfClosing"]: - self.tree.openElements.pop() - token["selfClosingAcknowledged"] = True - - def startTagMisplaced(self, token): - """ Elements that should be children of other elements that have a - different insertion mode; here they are ignored - "caption", "col", "colgroup", "frame", "frameset", "head", - "option", "optgroup", "tbody", "td", "tfoot", "th", "thead", - "tr", "noscript" - """ - self.parser.parseError("unexpected-start-tag-ignored", {"name": token["name"]}) - - def startTagOther(self, token): - self.tree.reconstructActiveFormattingElements() - self.tree.insertElement(token) - - def endTagP(self, token): - if not self.tree.elementInScope("p", variant="button"): - self.startTagCloseP(impliedTagToken("p", "StartTag")) - self.parser.parseError("unexpected-end-tag", {"name": "p"}) - self.endTagP(impliedTagToken("p", "EndTag")) - else: - self.tree.generateImpliedEndTags("p") - if self.tree.openElements[-1].name != "p": - self.parser.parseError("unexpected-end-tag", {"name": "p"}) - node = self.tree.openElements.pop() - while node.name != "p": - node = self.tree.openElements.pop() - - def endTagBody(self, token): - if not self.tree.elementInScope("body"): - self.parser.parseError() - return - elif self.tree.openElements[-1].name != "body": - for node in self.tree.openElements[2:]: - if node.name not in frozenset(("dd", "dt", "li", "optgroup", - "option", "p", "rp", "rt", - "tbody", "td", "tfoot", - "th", "thead", "tr", "body", - "html")): - # Not sure this is the correct name for the parse error - self.parser.parseError( - "expected-one-end-tag-but-got-another", - {"gotName": "body", "expectedName": node.name}) - break - self.parser.phase = self.parser.phases["afterBody"] - - def endTagHtml(self, token): - # We repeat the test for the body end tag token being ignored here - if self.tree.elementInScope("body"): - self.endTagBody(impliedTagToken("body")) - return token - - def endTagBlock(self, token): - # Put us back in the right whitespace handling mode - if token["name"] == "pre": - self.processSpaceCharacters = self.processSpaceCharactersNonPre - inScope = self.tree.elementInScope(token["name"]) - if inScope: - self.tree.generateImpliedEndTags() - if self.tree.openElements[-1].name != token["name"]: - self.parser.parseError("end-tag-too-early", {"name": token["name"]}) - if inScope: - node = self.tree.openElements.pop() - while node.name != token["name"]: - node = self.tree.openElements.pop() - - def endTagForm(self, token): - node = self.tree.formPointer - self.tree.formPointer = None - if node is None or not self.tree.elementInScope(node): - self.parser.parseError("unexpected-end-tag", - {"name": "form"}) - else: - self.tree.generateImpliedEndTags() - if self.tree.openElements[-1] != node: - self.parser.parseError("end-tag-too-early-ignored", - {"name": "form"}) - self.tree.openElements.remove(node) - - def endTagListItem(self, token): - if token["name"] == "li": - variant = "list" - else: - variant = None - if not self.tree.elementInScope(token["name"], variant=variant): - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - else: - self.tree.generateImpliedEndTags(exclude=token["name"]) - if self.tree.openElements[-1].name != token["name"]: - self.parser.parseError( - "end-tag-too-early", - {"name": token["name"]}) - node = self.tree.openElements.pop() - while node.name != token["name"]: - node = self.tree.openElements.pop() - - def endTagHeading(self, token): - for item in headingElements: - if self.tree.elementInScope(item): - self.tree.generateImpliedEndTags() - break - if self.tree.openElements[-1].name != token["name"]: - self.parser.parseError("end-tag-too-early", {"name": token["name"]}) - - for item in headingElements: - if self.tree.elementInScope(item): - item = self.tree.openElements.pop() - while item.name not in headingElements: - item = self.tree.openElements.pop() - break - - def endTagFormatting(self, token): - """The much-feared adoption agency algorithm""" - # http://svn.whatwg.org/webapps/complete.html#adoptionAgency revision 7867 - # XXX Better parseError messages appreciated. - - # Step 1 - outerLoopCounter = 0 - - # Step 2 - while outerLoopCounter < 8: - - # Step 3 - outerLoopCounter += 1 - - # Step 4: - - # Let the formatting element be the last element in - # the list of active formatting elements that: - # - is between the end of the list and the last scope - # marker in the list, if any, or the start of the list - # otherwise, and - # - has the same tag name as the token. - formattingElement = self.tree.elementInActiveFormattingElements( - token["name"]) - if (not formattingElement or - (formattingElement in self.tree.openElements and - not self.tree.elementInScope(formattingElement.name))): - # If there is no such node, then abort these steps - # and instead act as described in the "any other - # end tag" entry below. - self.endTagOther(token) - return - - # Otherwise, if there is such a node, but that node is - # not in the stack of open elements, then this is a - # parse error; remove the element from the list, and - # abort these steps. - elif formattingElement not in self.tree.openElements: - self.parser.parseError("adoption-agency-1.2", {"name": token["name"]}) - self.tree.activeFormattingElements.remove(formattingElement) - return - - # Otherwise, if there is such a node, and that node is - # also in the stack of open elements, but the element - # is not in scope, then this is a parse error; ignore - # the token, and abort these steps. - elif not self.tree.elementInScope(formattingElement.name): - self.parser.parseError("adoption-agency-4.4", {"name": token["name"]}) - return - - # Otherwise, there is a formatting element and that - # element is in the stack and is in scope. If the - # element is not the current node, this is a parse - # error. In any case, proceed with the algorithm as - # written in the following steps. - else: - if formattingElement != self.tree.openElements[-1]: - self.parser.parseError("adoption-agency-1.3", {"name": token["name"]}) - - # Step 5: - - # Let the furthest block be the topmost node in the - # stack of open elements that is lower in the stack - # than the formatting element, and is an element in - # the special category. There might not be one. - afeIndex = self.tree.openElements.index(formattingElement) - furthestBlock = None - for element in self.tree.openElements[afeIndex:]: - if element.nameTuple in specialElements: - furthestBlock = element - break - - # Step 6: - - # If there is no furthest block, then the UA must - # first pop all the nodes from the bottom of the stack - # of open elements, from the current node up to and - # including the formatting element, then remove the - # formatting element from the list of active - # formatting elements, and finally abort these steps. - if furthestBlock is None: - element = self.tree.openElements.pop() - while element != formattingElement: - element = self.tree.openElements.pop() - self.tree.activeFormattingElements.remove(element) - return - - # Step 7 - commonAncestor = self.tree.openElements[afeIndex - 1] - - # Step 8: - # The bookmark is supposed to help us identify where to reinsert - # nodes in step 15. We have to ensure that we reinsert nodes after - # the node before the active formatting element. Note the bookmark - # can move in step 9.7 - bookmark = self.tree.activeFormattingElements.index(formattingElement) - - # Step 9 - lastNode = node = furthestBlock - innerLoopCounter = 0 - - index = self.tree.openElements.index(node) - while innerLoopCounter < 3: - innerLoopCounter += 1 - # Node is element before node in open elements - index -= 1 - node = self.tree.openElements[index] - if node not in self.tree.activeFormattingElements: - self.tree.openElements.remove(node) - continue - # Step 9.6 - if node == formattingElement: - break - # Step 9.7 - if lastNode == furthestBlock: - bookmark = self.tree.activeFormattingElements.index(node) + 1 - # Step 9.8 - clone = node.cloneNode() - # Replace node with clone - self.tree.activeFormattingElements[ - self.tree.activeFormattingElements.index(node)] = clone - self.tree.openElements[ - self.tree.openElements.index(node)] = clone - node = clone - # Step 9.9 - # Remove lastNode from its parents, if any - if lastNode.parent: - lastNode.parent.removeChild(lastNode) - node.appendChild(lastNode) - # Step 9.10 - lastNode = node - - # Step 10 - # Foster parent lastNode if commonAncestor is a - # table, tbody, tfoot, thead, or tr we need to foster - # parent the lastNode - if lastNode.parent: - lastNode.parent.removeChild(lastNode) - - if commonAncestor.name in frozenset(("table", "tbody", "tfoot", "thead", "tr")): - parent, insertBefore = self.tree.getTableMisnestedNodePosition() - parent.insertBefore(lastNode, insertBefore) - else: - commonAncestor.appendChild(lastNode) - - # Step 11 - clone = formattingElement.cloneNode() - - # Step 12 - furthestBlock.reparentChildren(clone) - - # Step 13 - furthestBlock.appendChild(clone) - - # Step 14 - self.tree.activeFormattingElements.remove(formattingElement) - self.tree.activeFormattingElements.insert(bookmark, clone) - - # Step 15 - self.tree.openElements.remove(formattingElement) - self.tree.openElements.insert( - self.tree.openElements.index(furthestBlock) + 1, clone) - - def endTagAppletMarqueeObject(self, token): - if self.tree.elementInScope(token["name"]): - self.tree.generateImpliedEndTags() - if self.tree.openElements[-1].name != token["name"]: - self.parser.parseError("end-tag-too-early", {"name": token["name"]}) - - if self.tree.elementInScope(token["name"]): - element = self.tree.openElements.pop() - while element.name != token["name"]: - element = self.tree.openElements.pop() - self.tree.clearActiveFormattingElements() - - def endTagBr(self, token): - self.parser.parseError("unexpected-end-tag-treated-as", - {"originalName": "br", "newName": "br element"}) - self.tree.reconstructActiveFormattingElements() - self.tree.insertElement(impliedTagToken("br", "StartTag")) - self.tree.openElements.pop() - - def endTagOther(self, token): - for node in self.tree.openElements[::-1]: - if node.name == token["name"]: - self.tree.generateImpliedEndTags(exclude=token["name"]) - if self.tree.openElements[-1].name != token["name"]: - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - while self.tree.openElements.pop() != node: - pass - break - else: - if node.nameTuple in specialElements: - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - break - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - (("base", "basefont", "bgsound", "command", "link", "meta", - "script", "style", "title"), - startTagProcessInHead), - ("body", startTagBody), - ("frameset", startTagFrameset), - (("address", "article", "aside", "blockquote", "center", "details", - "dir", "div", "dl", "fieldset", "figcaption", "figure", - "footer", "header", "hgroup", "main", "menu", "nav", "ol", "p", - "section", "summary", "ul"), - startTagCloseP), - (headingElements, startTagHeading), - (("pre", "listing"), startTagPreListing), - ("form", startTagForm), - (("li", "dd", "dt"), startTagListItem), - ("plaintext", startTagPlaintext), - ("a", startTagA), - (("b", "big", "code", "em", "font", "i", "s", "small", "strike", - "strong", "tt", "u"), startTagFormatting), - ("nobr", startTagNobr), - ("button", startTagButton), - (("applet", "marquee", "object"), startTagAppletMarqueeObject), - ("xmp", startTagXmp), - ("table", startTagTable), - (("area", "br", "embed", "img", "keygen", "wbr"), - startTagVoidFormatting), - (("param", "source", "track"), startTagParamSource), - ("input", startTagInput), - ("hr", startTagHr), - ("image", startTagImage), - ("isindex", startTagIsIndex), - ("textarea", startTagTextarea), - ("iframe", startTagIFrame), - ("noscript", startTagNoscript), - (("noembed", "noframes"), startTagRawtext), - ("select", startTagSelect), - (("rp", "rt"), startTagRpRt), - (("option", "optgroup"), startTagOpt), - (("math"), startTagMath), - (("svg"), startTagSvg), - (("caption", "col", "colgroup", "frame", "head", - "tbody", "td", "tfoot", "th", "thead", - "tr"), startTagMisplaced) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("body", endTagBody), - ("html", endTagHtml), - (("address", "article", "aside", "blockquote", "button", "center", - "details", "dialog", "dir", "div", "dl", "fieldset", "figcaption", "figure", - "footer", "header", "hgroup", "listing", "main", "menu", "nav", "ol", "pre", - "section", "summary", "ul"), endTagBlock), - ("form", endTagForm), - ("p", endTagP), - (("dd", "dt", "li"), endTagListItem), - (headingElements, endTagHeading), - (("a", "b", "big", "code", "em", "font", "i", "nobr", "s", "small", - "strike", "strong", "tt", "u"), endTagFormatting), - (("applet", "marquee", "object"), endTagAppletMarqueeObject), - ("br", endTagBr), - ]) - endTagHandler.default = endTagOther - - class TextPhase(Phase): - __slots__ = tuple() - - def processCharacters(self, token): - self.tree.insertText(token["data"]) - - def processEOF(self): - self.parser.parseError("expected-named-closing-tag-but-got-eof", - {"name": self.tree.openElements[-1].name}) - self.tree.openElements.pop() - self.parser.phase = self.parser.originalPhase - return True - - def startTagOther(self, token): - assert False, "Tried to process start tag %s in RCDATA/RAWTEXT mode" % token['name'] - - def endTagScript(self, token): - node = self.tree.openElements.pop() - assert node.name == "script" - self.parser.phase = self.parser.originalPhase - # The rest of this method is all stuff that only happens if - # document.write works - - def endTagOther(self, token): - self.tree.openElements.pop() - self.parser.phase = self.parser.originalPhase - - startTagHandler = _utils.MethodDispatcher([]) - startTagHandler.default = startTagOther - endTagHandler = _utils.MethodDispatcher([ - ("script", endTagScript)]) - endTagHandler.default = endTagOther - - class InTablePhase(Phase): - # http://www.whatwg.org/specs/web-apps/current-work/#in-table - __slots__ = tuple() - - # helper methods - def clearStackToTableContext(self): - # "clear the stack back to a table context" - while self.tree.openElements[-1].name not in ("table", "html"): - # self.parser.parseError("unexpected-implied-end-tag-in-table", - # {"name": self.tree.openElements[-1].name}) - self.tree.openElements.pop() - # When the current node is <html> it's an innerHTML case - - # processing methods - def processEOF(self): - if self.tree.openElements[-1].name != "html": - self.parser.parseError("eof-in-table") - else: - assert self.parser.innerHTML - # Stop parsing - - def processSpaceCharacters(self, token): - originalPhase = self.parser.phase - self.parser.phase = self.parser.phases["inTableText"] - self.parser.phase.originalPhase = originalPhase - self.parser.phase.processSpaceCharacters(token) - - def processCharacters(self, token): - originalPhase = self.parser.phase - self.parser.phase = self.parser.phases["inTableText"] - self.parser.phase.originalPhase = originalPhase - self.parser.phase.processCharacters(token) - - def insertText(self, token): - # If we get here there must be at least one non-whitespace character - # Do the table magic! - self.tree.insertFromTable = True - self.parser.phases["inBody"].processCharacters(token) - self.tree.insertFromTable = False - - def startTagCaption(self, token): - self.clearStackToTableContext() - self.tree.activeFormattingElements.append(Marker) - self.tree.insertElement(token) - self.parser.phase = self.parser.phases["inCaption"] - - def startTagColgroup(self, token): - self.clearStackToTableContext() - self.tree.insertElement(token) - self.parser.phase = self.parser.phases["inColumnGroup"] - - def startTagCol(self, token): - self.startTagColgroup(impliedTagToken("colgroup", "StartTag")) - return token - - def startTagRowGroup(self, token): - self.clearStackToTableContext() - self.tree.insertElement(token) - self.parser.phase = self.parser.phases["inTableBody"] - - def startTagImplyTbody(self, token): - self.startTagRowGroup(impliedTagToken("tbody", "StartTag")) - return token - - def startTagTable(self, token): - self.parser.parseError("unexpected-start-tag-implies-end-tag", - {"startName": "table", "endName": "table"}) - self.parser.phase.processEndTag(impliedTagToken("table")) - if not self.parser.innerHTML: - return token - - def startTagStyleScript(self, token): - return self.parser.phases["inHead"].processStartTag(token) - - def startTagInput(self, token): - if ("type" in token["data"] and - token["data"]["type"].translate(asciiUpper2Lower) == "hidden"): - self.parser.parseError("unexpected-hidden-input-in-table") - self.tree.insertElement(token) - # XXX associate with form - self.tree.openElements.pop() - else: - self.startTagOther(token) - - def startTagForm(self, token): - self.parser.parseError("unexpected-form-in-table") - if self.tree.formPointer is None: - self.tree.insertElement(token) - self.tree.formPointer = self.tree.openElements[-1] - self.tree.openElements.pop() - - def startTagOther(self, token): - self.parser.parseError("unexpected-start-tag-implies-table-voodoo", {"name": token["name"]}) - # Do the table magic! - self.tree.insertFromTable = True - self.parser.phases["inBody"].processStartTag(token) - self.tree.insertFromTable = False - - def endTagTable(self, token): - if self.tree.elementInScope("table", variant="table"): - self.tree.generateImpliedEndTags() - if self.tree.openElements[-1].name != "table": - self.parser.parseError("end-tag-too-early-named", - {"gotName": "table", - "expectedName": self.tree.openElements[-1].name}) - while self.tree.openElements[-1].name != "table": - self.tree.openElements.pop() - self.tree.openElements.pop() - self.parser.resetInsertionMode() - else: - # innerHTML case - assert self.parser.innerHTML - self.parser.parseError() - - def endTagIgnore(self, token): - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - - def endTagOther(self, token): - self.parser.parseError("unexpected-end-tag-implies-table-voodoo", {"name": token["name"]}) - # Do the table magic! - self.tree.insertFromTable = True - self.parser.phases["inBody"].processEndTag(token) - self.tree.insertFromTable = False - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - ("caption", startTagCaption), - ("colgroup", startTagColgroup), - ("col", startTagCol), - (("tbody", "tfoot", "thead"), startTagRowGroup), - (("td", "th", "tr"), startTagImplyTbody), - ("table", startTagTable), - (("style", "script"), startTagStyleScript), - ("input", startTagInput), - ("form", startTagForm) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("table", endTagTable), - (("body", "caption", "col", "colgroup", "html", "tbody", "td", - "tfoot", "th", "thead", "tr"), endTagIgnore) - ]) - endTagHandler.default = endTagOther - - class InTableTextPhase(Phase): - __slots__ = ("originalPhase", "characterTokens") - - def __init__(self, *args, **kwargs): - super(InTableTextPhase, self).__init__(*args, **kwargs) - self.originalPhase = None - self.characterTokens = [] - - def flushCharacters(self): - data = "".join([item["data"] for item in self.characterTokens]) - if any([item not in spaceCharacters for item in data]): - token = {"type": tokenTypes["Characters"], "data": data} - self.parser.phases["inTable"].insertText(token) - elif data: - self.tree.insertText(data) - self.characterTokens = [] - - def processComment(self, token): - self.flushCharacters() - self.parser.phase = self.originalPhase - return token - - def processEOF(self): - self.flushCharacters() - self.parser.phase = self.originalPhase - return True - - def processCharacters(self, token): - if token["data"] == "\u0000": - return - self.characterTokens.append(token) - - def processSpaceCharacters(self, token): - # pretty sure we should never reach here - self.characterTokens.append(token) - # assert False - - def processStartTag(self, token): - self.flushCharacters() - self.parser.phase = self.originalPhase - return token - - def processEndTag(self, token): - self.flushCharacters() - self.parser.phase = self.originalPhase - return token - - class InCaptionPhase(Phase): - # http://www.whatwg.org/specs/web-apps/current-work/#in-caption - __slots__ = tuple() - - def ignoreEndTagCaption(self): - return not self.tree.elementInScope("caption", variant="table") - - def processEOF(self): - self.parser.phases["inBody"].processEOF() - - def processCharacters(self, token): - return self.parser.phases["inBody"].processCharacters(token) - - def startTagTableElement(self, token): - self.parser.parseError() - # XXX Have to duplicate logic here to find out if the tag is ignored - ignoreEndTag = self.ignoreEndTagCaption() - self.parser.phase.processEndTag(impliedTagToken("caption")) - if not ignoreEndTag: - return token - - def startTagOther(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def endTagCaption(self, token): - if not self.ignoreEndTagCaption(): - # AT this code is quite similar to endTagTable in "InTable" - self.tree.generateImpliedEndTags() - if self.tree.openElements[-1].name != "caption": - self.parser.parseError("expected-one-end-tag-but-got-another", - {"gotName": "caption", - "expectedName": self.tree.openElements[-1].name}) - while self.tree.openElements[-1].name != "caption": - self.tree.openElements.pop() - self.tree.openElements.pop() - self.tree.clearActiveFormattingElements() - self.parser.phase = self.parser.phases["inTable"] - else: - # innerHTML case - assert self.parser.innerHTML - self.parser.parseError() - - def endTagTable(self, token): - self.parser.parseError() - ignoreEndTag = self.ignoreEndTagCaption() - self.parser.phase.processEndTag(impliedTagToken("caption")) - if not ignoreEndTag: - return token - - def endTagIgnore(self, token): - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - - def endTagOther(self, token): - return self.parser.phases["inBody"].processEndTag(token) - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - (("caption", "col", "colgroup", "tbody", "td", "tfoot", "th", - "thead", "tr"), startTagTableElement) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("caption", endTagCaption), - ("table", endTagTable), - (("body", "col", "colgroup", "html", "tbody", "td", "tfoot", "th", - "thead", "tr"), endTagIgnore) - ]) - endTagHandler.default = endTagOther - - class InColumnGroupPhase(Phase): - # http://www.whatwg.org/specs/web-apps/current-work/#in-column - __slots__ = tuple() - - def ignoreEndTagColgroup(self): - return self.tree.openElements[-1].name == "html" - - def processEOF(self): - if self.tree.openElements[-1].name == "html": - assert self.parser.innerHTML - return - else: - ignoreEndTag = self.ignoreEndTagColgroup() - self.endTagColgroup(impliedTagToken("colgroup")) - if not ignoreEndTag: - return True - - def processCharacters(self, token): - ignoreEndTag = self.ignoreEndTagColgroup() - self.endTagColgroup(impliedTagToken("colgroup")) - if not ignoreEndTag: - return token - - def startTagCol(self, token): - self.tree.insertElement(token) - self.tree.openElements.pop() - token["selfClosingAcknowledged"] = True - - def startTagOther(self, token): - ignoreEndTag = self.ignoreEndTagColgroup() - self.endTagColgroup(impliedTagToken("colgroup")) - if not ignoreEndTag: - return token - - def endTagColgroup(self, token): - if self.ignoreEndTagColgroup(): - # innerHTML case - assert self.parser.innerHTML - self.parser.parseError() - else: - self.tree.openElements.pop() - self.parser.phase = self.parser.phases["inTable"] - - def endTagCol(self, token): - self.parser.parseError("no-end-tag", {"name": "col"}) - - def endTagOther(self, token): - ignoreEndTag = self.ignoreEndTagColgroup() - self.endTagColgroup(impliedTagToken("colgroup")) - if not ignoreEndTag: - return token - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - ("col", startTagCol) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("colgroup", endTagColgroup), - ("col", endTagCol) - ]) - endTagHandler.default = endTagOther - - class InTableBodyPhase(Phase): - # http://www.whatwg.org/specs/web-apps/current-work/#in-table0 - __slots__ = tuple() - - # helper methods - def clearStackToTableBodyContext(self): - while self.tree.openElements[-1].name not in ("tbody", "tfoot", - "thead", "html"): - # self.parser.parseError("unexpected-implied-end-tag-in-table", - # {"name": self.tree.openElements[-1].name}) - self.tree.openElements.pop() - if self.tree.openElements[-1].name == "html": - assert self.parser.innerHTML - - # the rest - def processEOF(self): - self.parser.phases["inTable"].processEOF() - - def processSpaceCharacters(self, token): - return self.parser.phases["inTable"].processSpaceCharacters(token) - - def processCharacters(self, token): - return self.parser.phases["inTable"].processCharacters(token) - - def startTagTr(self, token): - self.clearStackToTableBodyContext() - self.tree.insertElement(token) - self.parser.phase = self.parser.phases["inRow"] - - def startTagTableCell(self, token): - self.parser.parseError("unexpected-cell-in-table-body", - {"name": token["name"]}) - self.startTagTr(impliedTagToken("tr", "StartTag")) - return token - - def startTagTableOther(self, token): - # XXX AT Any ideas on how to share this with endTagTable? - if (self.tree.elementInScope("tbody", variant="table") or - self.tree.elementInScope("thead", variant="table") or - self.tree.elementInScope("tfoot", variant="table")): - self.clearStackToTableBodyContext() - self.endTagTableRowGroup( - impliedTagToken(self.tree.openElements[-1].name)) - return token - else: - # innerHTML case - assert self.parser.innerHTML - self.parser.parseError() - - def startTagOther(self, token): - return self.parser.phases["inTable"].processStartTag(token) - - def endTagTableRowGroup(self, token): - if self.tree.elementInScope(token["name"], variant="table"): - self.clearStackToTableBodyContext() - self.tree.openElements.pop() - self.parser.phase = self.parser.phases["inTable"] - else: - self.parser.parseError("unexpected-end-tag-in-table-body", - {"name": token["name"]}) - - def endTagTable(self, token): - if (self.tree.elementInScope("tbody", variant="table") or - self.tree.elementInScope("thead", variant="table") or - self.tree.elementInScope("tfoot", variant="table")): - self.clearStackToTableBodyContext() - self.endTagTableRowGroup( - impliedTagToken(self.tree.openElements[-1].name)) - return token - else: - # innerHTML case - assert self.parser.innerHTML - self.parser.parseError() - - def endTagIgnore(self, token): - self.parser.parseError("unexpected-end-tag-in-table-body", - {"name": token["name"]}) - - def endTagOther(self, token): - return self.parser.phases["inTable"].processEndTag(token) - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - ("tr", startTagTr), - (("td", "th"), startTagTableCell), - (("caption", "col", "colgroup", "tbody", "tfoot", "thead"), - startTagTableOther) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - (("tbody", "tfoot", "thead"), endTagTableRowGroup), - ("table", endTagTable), - (("body", "caption", "col", "colgroup", "html", "td", "th", - "tr"), endTagIgnore) - ]) - endTagHandler.default = endTagOther - - class InRowPhase(Phase): - # http://www.whatwg.org/specs/web-apps/current-work/#in-row - __slots__ = tuple() - - # helper methods (XXX unify this with other table helper methods) - def clearStackToTableRowContext(self): - while self.tree.openElements[-1].name not in ("tr", "html"): - self.parser.parseError("unexpected-implied-end-tag-in-table-row", - {"name": self.tree.openElements[-1].name}) - self.tree.openElements.pop() - - def ignoreEndTagTr(self): - return not self.tree.elementInScope("tr", variant="table") - - # the rest - def processEOF(self): - self.parser.phases["inTable"].processEOF() - - def processSpaceCharacters(self, token): - return self.parser.phases["inTable"].processSpaceCharacters(token) - - def processCharacters(self, token): - return self.parser.phases["inTable"].processCharacters(token) - - def startTagTableCell(self, token): - self.clearStackToTableRowContext() - self.tree.insertElement(token) - self.parser.phase = self.parser.phases["inCell"] - self.tree.activeFormattingElements.append(Marker) - - def startTagTableOther(self, token): - ignoreEndTag = self.ignoreEndTagTr() - self.endTagTr(impliedTagToken("tr")) - # XXX how are we sure it's always ignored in the innerHTML case? - if not ignoreEndTag: - return token - - def startTagOther(self, token): - return self.parser.phases["inTable"].processStartTag(token) - - def endTagTr(self, token): - if not self.ignoreEndTagTr(): - self.clearStackToTableRowContext() - self.tree.openElements.pop() - self.parser.phase = self.parser.phases["inTableBody"] - else: - # innerHTML case - assert self.parser.innerHTML - self.parser.parseError() - - def endTagTable(self, token): - ignoreEndTag = self.ignoreEndTagTr() - self.endTagTr(impliedTagToken("tr")) - # Reprocess the current tag if the tr end tag was not ignored - # XXX how are we sure it's always ignored in the innerHTML case? - if not ignoreEndTag: - return token - - def endTagTableRowGroup(self, token): - if self.tree.elementInScope(token["name"], variant="table"): - self.endTagTr(impliedTagToken("tr")) - return token - else: - self.parser.parseError() - - def endTagIgnore(self, token): - self.parser.parseError("unexpected-end-tag-in-table-row", - {"name": token["name"]}) - - def endTagOther(self, token): - return self.parser.phases["inTable"].processEndTag(token) - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - (("td", "th"), startTagTableCell), - (("caption", "col", "colgroup", "tbody", "tfoot", "thead", - "tr"), startTagTableOther) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("tr", endTagTr), - ("table", endTagTable), - (("tbody", "tfoot", "thead"), endTagTableRowGroup), - (("body", "caption", "col", "colgroup", "html", "td", "th"), - endTagIgnore) - ]) - endTagHandler.default = endTagOther - - class InCellPhase(Phase): - # http://www.whatwg.org/specs/web-apps/current-work/#in-cell - __slots__ = tuple() - - # helper - def closeCell(self): - if self.tree.elementInScope("td", variant="table"): - self.endTagTableCell(impliedTagToken("td")) - elif self.tree.elementInScope("th", variant="table"): - self.endTagTableCell(impliedTagToken("th")) - - # the rest - def processEOF(self): - self.parser.phases["inBody"].processEOF() - - def processCharacters(self, token): - return self.parser.phases["inBody"].processCharacters(token) - - def startTagTableOther(self, token): - if (self.tree.elementInScope("td", variant="table") or - self.tree.elementInScope("th", variant="table")): - self.closeCell() - return token - else: - # innerHTML case - assert self.parser.innerHTML - self.parser.parseError() - - def startTagOther(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def endTagTableCell(self, token): - if self.tree.elementInScope(token["name"], variant="table"): - self.tree.generateImpliedEndTags(token["name"]) - if self.tree.openElements[-1].name != token["name"]: - self.parser.parseError("unexpected-cell-end-tag", - {"name": token["name"]}) - while True: - node = self.tree.openElements.pop() - if node.name == token["name"]: - break - else: - self.tree.openElements.pop() - self.tree.clearActiveFormattingElements() - self.parser.phase = self.parser.phases["inRow"] - else: - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - - def endTagIgnore(self, token): - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - - def endTagImply(self, token): - if self.tree.elementInScope(token["name"], variant="table"): - self.closeCell() - return token - else: - # sometimes innerHTML case - self.parser.parseError() - - def endTagOther(self, token): - return self.parser.phases["inBody"].processEndTag(token) - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - (("caption", "col", "colgroup", "tbody", "td", "tfoot", "th", - "thead", "tr"), startTagTableOther) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - (("td", "th"), endTagTableCell), - (("body", "caption", "col", "colgroup", "html"), endTagIgnore), - (("table", "tbody", "tfoot", "thead", "tr"), endTagImply) - ]) - endTagHandler.default = endTagOther - - class InSelectPhase(Phase): - __slots__ = tuple() - - # http://www.whatwg.org/specs/web-apps/current-work/#in-select - def processEOF(self): - if self.tree.openElements[-1].name != "html": - self.parser.parseError("eof-in-select") - else: - assert self.parser.innerHTML - - def processCharacters(self, token): - if token["data"] == "\u0000": - return - self.tree.insertText(token["data"]) - - def startTagOption(self, token): - # We need to imply </option> if <option> is the current node. - if self.tree.openElements[-1].name == "option": - self.tree.openElements.pop() - self.tree.insertElement(token) - - def startTagOptgroup(self, token): - if self.tree.openElements[-1].name == "option": - self.tree.openElements.pop() - if self.tree.openElements[-1].name == "optgroup": - self.tree.openElements.pop() - self.tree.insertElement(token) - - def startTagSelect(self, token): - self.parser.parseError("unexpected-select-in-select") - self.endTagSelect(impliedTagToken("select")) - - def startTagInput(self, token): - self.parser.parseError("unexpected-input-in-select") - if self.tree.elementInScope("select", variant="select"): - self.endTagSelect(impliedTagToken("select")) - return token - else: - assert self.parser.innerHTML - - def startTagScript(self, token): - return self.parser.phases["inHead"].processStartTag(token) - - def startTagOther(self, token): - self.parser.parseError("unexpected-start-tag-in-select", - {"name": token["name"]}) - - def endTagOption(self, token): - if self.tree.openElements[-1].name == "option": - self.tree.openElements.pop() - else: - self.parser.parseError("unexpected-end-tag-in-select", - {"name": "option"}) - - def endTagOptgroup(self, token): - # </optgroup> implicitly closes <option> - if (self.tree.openElements[-1].name == "option" and - self.tree.openElements[-2].name == "optgroup"): - self.tree.openElements.pop() - # It also closes </optgroup> - if self.tree.openElements[-1].name == "optgroup": - self.tree.openElements.pop() - # But nothing else - else: - self.parser.parseError("unexpected-end-tag-in-select", - {"name": "optgroup"}) - - def endTagSelect(self, token): - if self.tree.elementInScope("select", variant="select"): - node = self.tree.openElements.pop() - while node.name != "select": - node = self.tree.openElements.pop() - self.parser.resetInsertionMode() - else: - # innerHTML case - assert self.parser.innerHTML - self.parser.parseError() - - def endTagOther(self, token): - self.parser.parseError("unexpected-end-tag-in-select", - {"name": token["name"]}) - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - ("option", startTagOption), - ("optgroup", startTagOptgroup), - ("select", startTagSelect), - (("input", "keygen", "textarea"), startTagInput), - ("script", startTagScript) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("option", endTagOption), - ("optgroup", endTagOptgroup), - ("select", endTagSelect) - ]) - endTagHandler.default = endTagOther - - class InSelectInTablePhase(Phase): - __slots__ = tuple() - - def processEOF(self): - self.parser.phases["inSelect"].processEOF() - - def processCharacters(self, token): - return self.parser.phases["inSelect"].processCharacters(token) - - def startTagTable(self, token): - self.parser.parseError("unexpected-table-element-start-tag-in-select-in-table", {"name": token["name"]}) - self.endTagOther(impliedTagToken("select")) - return token - - def startTagOther(self, token): - return self.parser.phases["inSelect"].processStartTag(token) - - def endTagTable(self, token): - self.parser.parseError("unexpected-table-element-end-tag-in-select-in-table", {"name": token["name"]}) - if self.tree.elementInScope(token["name"], variant="table"): - self.endTagOther(impliedTagToken("select")) - return token - - def endTagOther(self, token): - return self.parser.phases["inSelect"].processEndTag(token) - - startTagHandler = _utils.MethodDispatcher([ - (("caption", "table", "tbody", "tfoot", "thead", "tr", "td", "th"), - startTagTable) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - (("caption", "table", "tbody", "tfoot", "thead", "tr", "td", "th"), - endTagTable) - ]) - endTagHandler.default = endTagOther - - class InForeignContentPhase(Phase): - __slots__ = tuple() - - breakoutElements = frozenset(["b", "big", "blockquote", "body", "br", - "center", "code", "dd", "div", "dl", "dt", - "em", "embed", "h1", "h2", "h3", - "h4", "h5", "h6", "head", "hr", "i", "img", - "li", "listing", "menu", "meta", "nobr", - "ol", "p", "pre", "ruby", "s", "small", - "span", "strong", "strike", "sub", "sup", - "table", "tt", "u", "ul", "var"]) - - def adjustSVGTagNames(self, token): - replacements = {"altglyph": "altGlyph", - "altglyphdef": "altGlyphDef", - "altglyphitem": "altGlyphItem", - "animatecolor": "animateColor", - "animatemotion": "animateMotion", - "animatetransform": "animateTransform", - "clippath": "clipPath", - "feblend": "feBlend", - "fecolormatrix": "feColorMatrix", - "fecomponenttransfer": "feComponentTransfer", - "fecomposite": "feComposite", - "feconvolvematrix": "feConvolveMatrix", - "fediffuselighting": "feDiffuseLighting", - "fedisplacementmap": "feDisplacementMap", - "fedistantlight": "feDistantLight", - "feflood": "feFlood", - "fefunca": "feFuncA", - "fefuncb": "feFuncB", - "fefuncg": "feFuncG", - "fefuncr": "feFuncR", - "fegaussianblur": "feGaussianBlur", - "feimage": "feImage", - "femerge": "feMerge", - "femergenode": "feMergeNode", - "femorphology": "feMorphology", - "feoffset": "feOffset", - "fepointlight": "fePointLight", - "fespecularlighting": "feSpecularLighting", - "fespotlight": "feSpotLight", - "fetile": "feTile", - "feturbulence": "feTurbulence", - "foreignobject": "foreignObject", - "glyphref": "glyphRef", - "lineargradient": "linearGradient", - "radialgradient": "radialGradient", - "textpath": "textPath"} - - if token["name"] in replacements: - token["name"] = replacements[token["name"]] - - def processCharacters(self, token): - if token["data"] == "\u0000": - token["data"] = "\uFFFD" - elif (self.parser.framesetOK and - any(char not in spaceCharacters for char in token["data"])): - self.parser.framesetOK = False - Phase.processCharacters(self, token) - - def processStartTag(self, token): - currentNode = self.tree.openElements[-1] - if (token["name"] in self.breakoutElements or - (token["name"] == "font" and - set(token["data"].keys()) & {"color", "face", "size"})): - self.parser.parseError("unexpected-html-element-in-foreign-content", - {"name": token["name"]}) - while (self.tree.openElements[-1].namespace != - self.tree.defaultNamespace and - not self.parser.isHTMLIntegrationPoint(self.tree.openElements[-1]) and - not self.parser.isMathMLTextIntegrationPoint(self.tree.openElements[-1])): - self.tree.openElements.pop() - return token - - else: - if currentNode.namespace == namespaces["mathml"]: - self.parser.adjustMathMLAttributes(token) - elif currentNode.namespace == namespaces["svg"]: - self.adjustSVGTagNames(token) - self.parser.adjustSVGAttributes(token) - self.parser.adjustForeignAttributes(token) - token["namespace"] = currentNode.namespace - self.tree.insertElement(token) - if token["selfClosing"]: - self.tree.openElements.pop() - token["selfClosingAcknowledged"] = True - - def processEndTag(self, token): - nodeIndex = len(self.tree.openElements) - 1 - node = self.tree.openElements[-1] - if node.name.translate(asciiUpper2Lower) != token["name"]: - self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) - - while True: - if node.name.translate(asciiUpper2Lower) == token["name"]: - # XXX this isn't in the spec but it seems necessary - if self.parser.phase == self.parser.phases["inTableText"]: - self.parser.phase.flushCharacters() - self.parser.phase = self.parser.phase.originalPhase - while self.tree.openElements.pop() != node: - assert self.tree.openElements - new_token = None - break - nodeIndex -= 1 - - node = self.tree.openElements[nodeIndex] - if node.namespace != self.tree.defaultNamespace: - continue - else: - new_token = self.parser.phase.processEndTag(token) - break - return new_token - - class AfterBodyPhase(Phase): - __slots__ = tuple() - - def processEOF(self): - # Stop parsing - pass - - def processComment(self, token): - # This is needed because data is to be appended to the <html> element - # here and not to whatever is currently open. - self.tree.insertComment(token, self.tree.openElements[0]) - - def processCharacters(self, token): - self.parser.parseError("unexpected-char-after-body") - self.parser.phase = self.parser.phases["inBody"] - return token - - def startTagHtml(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def startTagOther(self, token): - self.parser.parseError("unexpected-start-tag-after-body", - {"name": token["name"]}) - self.parser.phase = self.parser.phases["inBody"] - return token - - def endTagHtml(self, name): - if self.parser.innerHTML: - self.parser.parseError("unexpected-end-tag-after-body-innerhtml") - else: - self.parser.phase = self.parser.phases["afterAfterBody"] - - def endTagOther(self, token): - self.parser.parseError("unexpected-end-tag-after-body", - {"name": token["name"]}) - self.parser.phase = self.parser.phases["inBody"] - return token - - startTagHandler = _utils.MethodDispatcher([ - ("html", startTagHtml) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([("html", endTagHtml)]) - endTagHandler.default = endTagOther - - class InFramesetPhase(Phase): - # http://www.whatwg.org/specs/web-apps/current-work/#in-frameset - __slots__ = tuple() - - def processEOF(self): - if self.tree.openElements[-1].name != "html": - self.parser.parseError("eof-in-frameset") - else: - assert self.parser.innerHTML - - def processCharacters(self, token): - self.parser.parseError("unexpected-char-in-frameset") - - def startTagFrameset(self, token): - self.tree.insertElement(token) - - def startTagFrame(self, token): - self.tree.insertElement(token) - self.tree.openElements.pop() - - def startTagNoframes(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def startTagOther(self, token): - self.parser.parseError("unexpected-start-tag-in-frameset", - {"name": token["name"]}) - - def endTagFrameset(self, token): - if self.tree.openElements[-1].name == "html": - # innerHTML case - self.parser.parseError("unexpected-frameset-in-frameset-innerhtml") - else: - self.tree.openElements.pop() - if (not self.parser.innerHTML and - self.tree.openElements[-1].name != "frameset"): - # If we're not in innerHTML mode and the current node is not a - # "frameset" element (anymore) then switch. - self.parser.phase = self.parser.phases["afterFrameset"] - - def endTagOther(self, token): - self.parser.parseError("unexpected-end-tag-in-frameset", - {"name": token["name"]}) - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - ("frameset", startTagFrameset), - ("frame", startTagFrame), - ("noframes", startTagNoframes) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("frameset", endTagFrameset) - ]) - endTagHandler.default = endTagOther - - class AfterFramesetPhase(Phase): - # http://www.whatwg.org/specs/web-apps/current-work/#after3 - __slots__ = tuple() - - def processEOF(self): - # Stop parsing - pass - - def processCharacters(self, token): - self.parser.parseError("unexpected-char-after-frameset") - - def startTagNoframes(self, token): - return self.parser.phases["inHead"].processStartTag(token) - - def startTagOther(self, token): - self.parser.parseError("unexpected-start-tag-after-frameset", - {"name": token["name"]}) - - def endTagHtml(self, token): - self.parser.phase = self.parser.phases["afterAfterFrameset"] - - def endTagOther(self, token): - self.parser.parseError("unexpected-end-tag-after-frameset", - {"name": token["name"]}) - - startTagHandler = _utils.MethodDispatcher([ - ("html", Phase.startTagHtml), - ("noframes", startTagNoframes) - ]) - startTagHandler.default = startTagOther - - endTagHandler = _utils.MethodDispatcher([ - ("html", endTagHtml) - ]) - endTagHandler.default = endTagOther - - class AfterAfterBodyPhase(Phase): - __slots__ = tuple() - - def processEOF(self): - pass - - def processComment(self, token): - self.tree.insertComment(token, self.tree.document) - - def processSpaceCharacters(self, token): - return self.parser.phases["inBody"].processSpaceCharacters(token) - - def processCharacters(self, token): - self.parser.parseError("expected-eof-but-got-char") - self.parser.phase = self.parser.phases["inBody"] - return token - - def startTagHtml(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def startTagOther(self, token): - self.parser.parseError("expected-eof-but-got-start-tag", - {"name": token["name"]}) - self.parser.phase = self.parser.phases["inBody"] - return token - - def processEndTag(self, token): - self.parser.parseError("expected-eof-but-got-end-tag", - {"name": token["name"]}) - self.parser.phase = self.parser.phases["inBody"] - return token - - startTagHandler = _utils.MethodDispatcher([ - ("html", startTagHtml) - ]) - startTagHandler.default = startTagOther - - class AfterAfterFramesetPhase(Phase): - __slots__ = tuple() - - def processEOF(self): - pass - - def processComment(self, token): - self.tree.insertComment(token, self.tree.document) - - def processSpaceCharacters(self, token): - return self.parser.phases["inBody"].processSpaceCharacters(token) - - def processCharacters(self, token): - self.parser.parseError("expected-eof-but-got-char") - - def startTagHtml(self, token): - return self.parser.phases["inBody"].processStartTag(token) - - def startTagNoFrames(self, token): - return self.parser.phases["inHead"].processStartTag(token) - - def startTagOther(self, token): - self.parser.parseError("expected-eof-but-got-start-tag", - {"name": token["name"]}) - - def processEndTag(self, token): - self.parser.parseError("expected-eof-but-got-end-tag", - {"name": token["name"]}) - - startTagHandler = _utils.MethodDispatcher([ - ("html", startTagHtml), - ("noframes", startTagNoFrames) - ]) - startTagHandler.default = startTagOther - - # pylint:enable=unused-argument - - return { - "initial": InitialPhase, - "beforeHtml": BeforeHtmlPhase, - "beforeHead": BeforeHeadPhase, - "inHead": InHeadPhase, - "inHeadNoscript": InHeadNoscriptPhase, - "afterHead": AfterHeadPhase, - "inBody": InBodyPhase, - "text": TextPhase, - "inTable": InTablePhase, - "inTableText": InTableTextPhase, - "inCaption": InCaptionPhase, - "inColumnGroup": InColumnGroupPhase, - "inTableBody": InTableBodyPhase, - "inRow": InRowPhase, - "inCell": InCellPhase, - "inSelect": InSelectPhase, - "inSelectInTable": InSelectInTablePhase, - "inForeignContent": InForeignContentPhase, - "afterBody": AfterBodyPhase, - "inFrameset": InFramesetPhase, - "afterFrameset": AfterFramesetPhase, - "afterAfterBody": AfterAfterBodyPhase, - "afterAfterFrameset": AfterAfterFramesetPhase, - # XXX after after frameset - } - - -def adjust_attributes(token, replacements): - needs_adjustment = viewkeys(token['data']) & viewkeys(replacements) - if needs_adjustment: - token['data'] = type(token['data'])((replacements.get(k, k), v) - for k, v in token['data'].items()) - - -def impliedTagToken(name, type="EndTag", attributes=None, - selfClosing=False): - if attributes is None: - attributes = {} - return {"type": tokenTypes[type], "name": name, "data": attributes, - "selfClosing": selfClosing} - - -class ParseError(Exception): - """Error in parsed document""" - pass diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/serializer.py b/env/Lib/site-packages/pip/_vendor/html5lib/serializer.py deleted file mode 100644 index d5669d8c..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/serializer.py +++ /dev/null @@ -1,409 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals -from pip._vendor.six import text_type - -import re - -from codecs import register_error, xmlcharrefreplace_errors - -from .constants import voidElements, booleanAttributes, spaceCharacters -from .constants import rcdataElements, entities, xmlEntities -from . import treewalkers, _utils -from xml.sax.saxutils import escape - -_quoteAttributeSpecChars = "".join(spaceCharacters) + "\"'=<>`" -_quoteAttributeSpec = re.compile("[" + _quoteAttributeSpecChars + "]") -_quoteAttributeLegacy = re.compile("[" + _quoteAttributeSpecChars + - "\x00\x01\x02\x03\x04\x05\x06\x07\x08\t\n" - "\x0b\x0c\r\x0e\x0f\x10\x11\x12\x13\x14\x15" - "\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f" - "\x20\x2f\x60\xa0\u1680\u180e\u180f\u2000" - "\u2001\u2002\u2003\u2004\u2005\u2006\u2007" - "\u2008\u2009\u200a\u2028\u2029\u202f\u205f" - "\u3000]") - - -_encode_entity_map = {} -_is_ucs4 = len("\U0010FFFF") == 1 -for k, v in list(entities.items()): - # skip multi-character entities - if ((_is_ucs4 and len(v) > 1) or - (not _is_ucs4 and len(v) > 2)): - continue - if v != "&": - if len(v) == 2: - v = _utils.surrogatePairToCodepoint(v) - else: - v = ord(v) - if v not in _encode_entity_map or k.islower(): - # prefer < over < and similarly for &, >, etc. - _encode_entity_map[v] = k - - -def htmlentityreplace_errors(exc): - if isinstance(exc, (UnicodeEncodeError, UnicodeTranslateError)): - res = [] - codepoints = [] - skip = False - for i, c in enumerate(exc.object[exc.start:exc.end]): - if skip: - skip = False - continue - index = i + exc.start - if _utils.isSurrogatePair(exc.object[index:min([exc.end, index + 2])]): - codepoint = _utils.surrogatePairToCodepoint(exc.object[index:index + 2]) - skip = True - else: - codepoint = ord(c) - codepoints.append(codepoint) - for cp in codepoints: - e = _encode_entity_map.get(cp) - if e: - res.append("&") - res.append(e) - if not e.endswith(";"): - res.append(";") - else: - res.append("&#x%s;" % (hex(cp)[2:])) - return ("".join(res), exc.end) - else: - return xmlcharrefreplace_errors(exc) - - -register_error("htmlentityreplace", htmlentityreplace_errors) - - -def serialize(input, tree="etree", encoding=None, **serializer_opts): - """Serializes the input token stream using the specified treewalker - - :arg input: the token stream to serialize - - :arg tree: the treewalker to use - - :arg encoding: the encoding to use - - :arg serializer_opts: any options to pass to the - :py:class:`html5lib.serializer.HTMLSerializer` that gets created - - :returns: the tree serialized as a string - - Example: - - >>> from html5lib.html5parser import parse - >>> from html5lib.serializer import serialize - >>> token_stream = parse('<html><body><p>Hi!</p></body></html>') - >>> serialize(token_stream, omit_optional_tags=False) - '<html><head></head><body><p>Hi!</p></body></html>' - - """ - # XXX: Should we cache this? - walker = treewalkers.getTreeWalker(tree) - s = HTMLSerializer(**serializer_opts) - return s.render(walker(input), encoding) - - -class HTMLSerializer(object): - - # attribute quoting options - quote_attr_values = "legacy" # be secure by default - quote_char = '"' - use_best_quote_char = True - - # tag syntax options - omit_optional_tags = True - minimize_boolean_attributes = True - use_trailing_solidus = False - space_before_trailing_solidus = True - - # escaping options - escape_lt_in_attrs = False - escape_rcdata = False - resolve_entities = True - - # miscellaneous options - alphabetical_attributes = False - inject_meta_charset = True - strip_whitespace = False - sanitize = False - - options = ("quote_attr_values", "quote_char", "use_best_quote_char", - "omit_optional_tags", "minimize_boolean_attributes", - "use_trailing_solidus", "space_before_trailing_solidus", - "escape_lt_in_attrs", "escape_rcdata", "resolve_entities", - "alphabetical_attributes", "inject_meta_charset", - "strip_whitespace", "sanitize") - - def __init__(self, **kwargs): - """Initialize HTMLSerializer - - :arg inject_meta_charset: Whether or not to inject the meta charset. - - Defaults to ``True``. - - :arg quote_attr_values: Whether to quote attribute values that don't - require quoting per legacy browser behavior (``"legacy"``), when - required by the standard (``"spec"``), or always (``"always"``). - - Defaults to ``"legacy"``. - - :arg quote_char: Use given quote character for attribute quoting. - - Defaults to ``"`` which will use double quotes unless attribute - value contains a double quote, in which case single quotes are - used. - - :arg escape_lt_in_attrs: Whether or not to escape ``<`` in attribute - values. - - Defaults to ``False``. - - :arg escape_rcdata: Whether to escape characters that need to be - escaped within normal elements within rcdata elements such as - style. - - Defaults to ``False``. - - :arg resolve_entities: Whether to resolve named character entities that - appear in the source tree. The XML predefined entities < > - & " ' are unaffected by this setting. - - Defaults to ``True``. - - :arg strip_whitespace: Whether to remove semantically meaningless - whitespace. (This compresses all whitespace to a single space - except within ``pre``.) - - Defaults to ``False``. - - :arg minimize_boolean_attributes: Shortens boolean attributes to give - just the attribute value, for example:: - - <input disabled="disabled"> - - becomes:: - - <input disabled> - - Defaults to ``True``. - - :arg use_trailing_solidus: Includes a close-tag slash at the end of the - start tag of void elements (empty elements whose end tag is - forbidden). E.g. ``<hr/>``. - - Defaults to ``False``. - - :arg space_before_trailing_solidus: Places a space immediately before - the closing slash in a tag using a trailing solidus. E.g. - ``<hr />``. Requires ``use_trailing_solidus=True``. - - Defaults to ``True``. - - :arg sanitize: Strip all unsafe or unknown constructs from output. - See :py:class:`html5lib.filters.sanitizer.Filter`. - - Defaults to ``False``. - - :arg omit_optional_tags: Omit start/end tags that are optional. - - Defaults to ``True``. - - :arg alphabetical_attributes: Reorder attributes to be in alphabetical order. - - Defaults to ``False``. - - """ - unexpected_args = frozenset(kwargs) - frozenset(self.options) - if len(unexpected_args) > 0: - raise TypeError("__init__() got an unexpected keyword argument '%s'" % next(iter(unexpected_args))) - if 'quote_char' in kwargs: - self.use_best_quote_char = False - for attr in self.options: - setattr(self, attr, kwargs.get(attr, getattr(self, attr))) - self.errors = [] - self.strict = False - - def encode(self, string): - assert(isinstance(string, text_type)) - if self.encoding: - return string.encode(self.encoding, "htmlentityreplace") - else: - return string - - def encodeStrict(self, string): - assert(isinstance(string, text_type)) - if self.encoding: - return string.encode(self.encoding, "strict") - else: - return string - - def serialize(self, treewalker, encoding=None): - # pylint:disable=too-many-nested-blocks - self.encoding = encoding - in_cdata = False - self.errors = [] - - if encoding and self.inject_meta_charset: - from .filters.inject_meta_charset import Filter - treewalker = Filter(treewalker, encoding) - # Alphabetical attributes is here under the assumption that none of - # the later filters add or change order of attributes; it needs to be - # before the sanitizer so escaped elements come out correctly - if self.alphabetical_attributes: - from .filters.alphabeticalattributes import Filter - treewalker = Filter(treewalker) - # WhitespaceFilter should be used before OptionalTagFilter - # for maximum efficiently of this latter filter - if self.strip_whitespace: - from .filters.whitespace import Filter - treewalker = Filter(treewalker) - if self.sanitize: - from .filters.sanitizer import Filter - treewalker = Filter(treewalker) - if self.omit_optional_tags: - from .filters.optionaltags import Filter - treewalker = Filter(treewalker) - - for token in treewalker: - type = token["type"] - if type == "Doctype": - doctype = "<!DOCTYPE %s" % token["name"] - - if token["publicId"]: - doctype += ' PUBLIC "%s"' % token["publicId"] - elif token["systemId"]: - doctype += " SYSTEM" - if token["systemId"]: - if token["systemId"].find('"') >= 0: - if token["systemId"].find("'") >= 0: - self.serializeError("System identifier contains both single and double quote characters") - quote_char = "'" - else: - quote_char = '"' - doctype += " %s%s%s" % (quote_char, token["systemId"], quote_char) - - doctype += ">" - yield self.encodeStrict(doctype) - - elif type in ("Characters", "SpaceCharacters"): - if type == "SpaceCharacters" or in_cdata: - if in_cdata and token["data"].find("</") >= 0: - self.serializeError("Unexpected </ in CDATA") - yield self.encode(token["data"]) - else: - yield self.encode(escape(token["data"])) - - elif type in ("StartTag", "EmptyTag"): - name = token["name"] - yield self.encodeStrict("<%s" % name) - if name in rcdataElements and not self.escape_rcdata: - in_cdata = True - elif in_cdata: - self.serializeError("Unexpected child element of a CDATA element") - for (_, attr_name), attr_value in token["data"].items(): - # TODO: Add namespace support here - k = attr_name - v = attr_value - yield self.encodeStrict(' ') - - yield self.encodeStrict(k) - if not self.minimize_boolean_attributes or \ - (k not in booleanAttributes.get(name, tuple()) and - k not in booleanAttributes.get("", tuple())): - yield self.encodeStrict("=") - if self.quote_attr_values == "always" or len(v) == 0: - quote_attr = True - elif self.quote_attr_values == "spec": - quote_attr = _quoteAttributeSpec.search(v) is not None - elif self.quote_attr_values == "legacy": - quote_attr = _quoteAttributeLegacy.search(v) is not None - else: - raise ValueError("quote_attr_values must be one of: " - "'always', 'spec', or 'legacy'") - v = v.replace("&", "&") - if self.escape_lt_in_attrs: - v = v.replace("<", "<") - if quote_attr: - quote_char = self.quote_char - if self.use_best_quote_char: - if "'" in v and '"' not in v: - quote_char = '"' - elif '"' in v and "'" not in v: - quote_char = "'" - if quote_char == "'": - v = v.replace("'", "'") - else: - v = v.replace('"', """) - yield self.encodeStrict(quote_char) - yield self.encode(v) - yield self.encodeStrict(quote_char) - else: - yield self.encode(v) - if name in voidElements and self.use_trailing_solidus: - if self.space_before_trailing_solidus: - yield self.encodeStrict(" /") - else: - yield self.encodeStrict("/") - yield self.encode(">") - - elif type == "EndTag": - name = token["name"] - if name in rcdataElements: - in_cdata = False - elif in_cdata: - self.serializeError("Unexpected child element of a CDATA element") - yield self.encodeStrict("</%s>" % name) - - elif type == "Comment": - data = token["data"] - if data.find("--") >= 0: - self.serializeError("Comment contains --") - yield self.encodeStrict("<!--%s-->" % token["data"]) - - elif type == "Entity": - name = token["name"] - key = name + ";" - if key not in entities: - self.serializeError("Entity %s not recognized" % name) - if self.resolve_entities and key not in xmlEntities: - data = entities[key] - else: - data = "&%s;" % name - yield self.encodeStrict(data) - - else: - self.serializeError(token["data"]) - - def render(self, treewalker, encoding=None): - """Serializes the stream from the treewalker into a string - - :arg treewalker: the treewalker to serialize - - :arg encoding: the string encoding to use - - :returns: the serialized tree - - Example: - - >>> from html5lib import parse, getTreeWalker - >>> from html5lib.serializer import HTMLSerializer - >>> token_stream = parse('<html><body>Hi!</body></html>') - >>> walker = getTreeWalker('etree') - >>> serializer = HTMLSerializer(omit_optional_tags=False) - >>> serializer.render(walker(token_stream)) - '<html><head></head><body>Hi!</body></html>' - - """ - if encoding: - return b"".join(list(self.serialize(treewalker, encoding))) - else: - return "".join(list(self.serialize(treewalker))) - - def serializeError(self, data="XXX ERROR MESSAGE NEEDED"): - # XXX The idea is to make data mandatory. - self.errors.append(data) - if self.strict: - raise SerializeError - - -class SerializeError(Exception): - """Error in serialized tree""" - pass diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py deleted file mode 100644 index 7ef59590..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py +++ /dev/null @@ -1,30 +0,0 @@ -"""Tree adapters let you convert from one tree structure to another - -Example: - -.. code-block:: python - - from pip._vendor import html5lib - from pip._vendor.html5lib.treeadapters import genshi - - doc = '<html><body>Hi!</body></html>' - treebuilder = html5lib.getTreeBuilder('etree') - parser = html5lib.HTMLParser(tree=treebuilder) - tree = parser.parse(doc) - TreeWalker = html5lib.getTreeWalker('etree') - - genshi_tree = genshi.to_genshi(TreeWalker(tree)) - -""" -from __future__ import absolute_import, division, unicode_literals - -from . import sax - -__all__ = ["sax"] - -try: - from . import genshi # noqa -except ImportError: - pass -else: - __all__.append("genshi") diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 99d0654679c79fd13cc76e246369315b203af4f9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 965 zcmYe~<>g{vU|^UdaWHi`69dCz5C<7^FfcGUFfcF_$1pH3q%cG=q%fv1<uK+lMKR?v zM=|HJM6ob3q%fzj<gn(lMX@n5q_CzlMzL23q%fzj<*?>*L~$@Ogfrv`u`r}^R{Ah9 zfM6s;9*+S-D*FPi6!wLTj0`Cp!3>(5i5D0d7($9tQxy_Z5(`RFi;5L;QcDyn^Gg+y z^YhA5i%JyIit=+6^7B#^N<hkrONvU9OG=AU6-x3I67%v)GE$4UxLhj|a|?1(t+=@K z^c0fwQ&M%4a`Kb2t*jIZDoZl*^SHPa6d(o_WESYfm!;;V<QFMq<`(1^l_+GC<mQ;> zWF}!#qX(1J1KAFDBUER4YF=?hCfM+l{A2}N1$7&cdOMq>{FF*Nk4!}yeK5;LA1tg6 zvH@gHQfX#RN@|gUE!=Ls^wbhiFgQVEG}Kc;>eMwsItmhticuANg!uXdfJHSx%4|Ud z)J(7r5MRMo0isb4OlhR#CxhicwuC3<WTTo0wH_jYupMMQ#FOz*Ga)>^lKglGO9NpZ z*e#lxTwE_fiAj_B7Jp(=aehu|NoqVKyl!!%WR_(XXXfYK5-82f1jSQ)PG(7JQDRQ< zOGX9;22I9W%*BZnMQji@8^nqtb_NCpKTYmi?D6p_`N{F|x47ct(@H^!AU?i`iGhKk zh#5q%FfcIOVgPFfDNW4DiH`^Cy~XVbj%nATqWq#;Y>5R0sd*_Y8H)Hox<JIQK4+_# z(Bjmh;+WK&l+2<S|GZR}qRg^X1zm+uKhH4NpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ> zAO*9SfB>JEL=)Yd{PfJ?lFaOw)V#77pUk9~;>?m%-GapA?8Nlc;+TTW0)1$@11APh zg3||uDJ)It$H!;pWtPOp>lIYq;;_lhPbtkwwF8Apu>b=D1B;Ld6Au#`6BDBVBM&1R F699^^BeMVi diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-39.pyc deleted file mode 100644 index 9dfe76138922c1c7cbb7b935f57cfb39d948da1d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1573 zcmYe~<>g{vU|^UdaWHi=8w0~*5C<7EF)%PVFfcF_`!Fytq%fo~<}l<kMlt3xMKR?v zM=>*k#F%nea#^ETbJ?QUz<lN$mR$BI_FRrAj$F<t&Rni2u3YXYZbpU_mK4?&hA5sC zwqOQL_Lm@gG?{PlCngo==aiPD#%Jah<QJ9P;z-FX%Ph{!&$}g1nwOcJpOPA%lUb5l zl$cYj$#jb~&@VAJ^%kpRNl8($ChINM;1I{4kXy{IelE9ILR=$4Zm~Q2`}(^2h1_Cy z@plf13~)_m1X%^eYzzzxAe;>HRS+WsLpnn(V-14~!vw}yty-oUrW8g=hFazt<`kwf zh9bQh#sv&DOexHg3=0_<8S<oR7>hhg7*kjlFx4<FWK3aAV-90rgqXpc!dAvmw4sJ6 zg<X=NC@+Nr!m43P;gn=ZV-jPiWyu4HaY{1OvXn5VaHVj!K+RsjvXH@rp_#Fnv6i)j zwS=vPrJ1pYHH`^oehqU9Pc~E0h7?|~%XqVyiatP0FS<s+9(IUnFp~;7YM4{_vY93@ z7V(sTT*EBMfFj4A%~Zru!U=J84O5DMB*=||k_>6gDNx@QaujmZFiv1B^1}>?6ro@S zP2sAk&iQ#|sYN9Ui3%k}si_Jj`3i{&>8W|e8JS=KE-nQH1qG|bqI8Aw#GLHZA}fWG zj8w1`gb&hDS`5|*5`fEs#FL?BXO=*XDM~FVEy^pl0@;vSlvt8qq>!Hm;()Bn%TGxy zhA6znQc_uvs>yVV%Q+*lC^5MtwW#<Oe{ex!aw?JlOG;u%;w=VEX1|yJ|NsAAB*?(P zpviQLBe*27s3asY{T7F7Zb3;Uh{c(gn44M*(*KLCTD7=VwfGhbNC+jxF*7hQure?( z1cOqX2?Hp_)iA{B#4yz|)-sha)G($nNHU}_mNFJ8r7+bniZSG|)i8omTr*=0QySAm zrb3or22GYCP%8E-5@lducnM-^G8TbM)nvZKq-Su8C9$NW=oV{PVoqu5N`@k71_p*- zJ<e7!p~b01#WATlDVaqv{&}e`MVV!(3c3oRex6~jLBXCOj=>6^elGrguECy;F~P3B zuE8O$K?-Iu0RcWSi6*)^`RSR(C7IbVsd;5FKAA}|#hE3kx&?{J*@@|?#W4k$1^V%2 zsd*{+Mfw>fxjCjenMwMf2v1B&EC7YBJ|xcd3My}L+2mvvmn7%s7TC#xLV^X95gFP3 zSIL&-$3vCb<m4wO<`moMA=DNLGcYjRVsp()0R=d_bAE1aYF^1Lc9;BQP-NcXC@4+J z$xQZ4xy4ajSzMBu>zU%G$#sh@v7jI|FQteRq?;uxKQpfgl<RM?W|pMp78kKIFff3F zuZRQ00u_Qq+@N@7yTt}dZ>dGMSV~eWN^Y^1<Y%Ym74d*niGj>w1qF05IDjF93`mp{ z?gx;`#V(-2hJ%HXi;;togHeEyg;9u+g$cwK1Cw0;IhaHkIS^t@LQGtYLQEWte2i@W znHZV=bFeTmu`w2DF)%RrY4YCUijPk#Eh#NZjgKz^mB~e*L{$U|!YFQN*d^x|r9!*} w@+icIV9$Yqpa||mu#pg#gAxgZ1@;4nO>TZlX-=vgD0LNs3=v@xV3c7707%}BK>z>% diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-39.pyc deleted file mode 100644 index 1c945ee3bd3c419a2ffdbf318d8757bae274d674..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1492 zcmYe~<>g{vU|^UdaWM4*8w0~*5C<8vFfcGUFfcF_r!X)uq%fo~<}l<kMlt3xMKR?v zM=>*k#F%nea#^ET85vTTQ&@7?a@nKUb2*|o7#T7dqBv987jP|PaAAm*ieZl8j^c^p zP32BuEoCgSN##xDOy#y=D6~moOJQ$eh~i6O4Q9~fcnPv!llc~ZVp4H_PH9PMd}eMz zeo@ISj+D%@%;L=ayjudLd6~)iDXH-}nI)-3i8;lZjJE_FOG=6|lS)fci~WK<a|?1_ zGBGePXfoXrPfW=wEiQ4(FG|f!&qJuXC0Uw>L&`51q!;845N2m!U|?flU~mS7gA^kJ zLk;5shJ_4_3?+;Un81D$iD9Z`s%5TWT)<qzRKvWGiIJgDpa$gYW3?<bEGdkV47IE^ ztSL;{OhrzGT7_CQtSQW83`KKFK(Z{73?;11Otow^j0@OmSW;Le8ERNk*d!U!m>_fw z+d^hWh8ors_H3r24>gPn*s-Ys+X^z7Bb%w{5J6R(Wei2PY8V%A)Uc$mNHQ#BWMlxl ziz}O{=t-eg3U{%V7efk9Gh-8Dp%&byLU5mQ)-Zwf{HkFD#V{j73U4rjCSTQR=fs>G zg<!`B-JHzqRE6aHypq(s5`~P!yp){OB88;H;?xv{{5*w{qSVy##GLHZA_WM=#igL2 zpkS3)lnxcJQYgttMOIgmuTWZ?s!);-Rsfd;2_)y|m8BMyC}fr(83VP`3gjBN10aS# zRNZ1JsVqpn#qN@y3}R?9-Qox?Nh~S}Nld@R;hI}eQVC+Qq$HLk-r~$l%uOvWNK8(> z#R6g$@h~tj++uUhO9@F#*JQfI<(!dNl$czST2y?CKNzGANr2rsKQ}iuuf(lNC^RoS zFTXrbp(H;$HBSL#t)C|ME#6{~y)OC5r66Uu_zH?r(=sdKa}x^+GV{`Jv1XQ}<`&-) z0;>uD%lSg2idY#K7>YPRZs7yVy5^*UjPMJ-#gm$sg5Yr_BitvDnwNrN$}R5HycC%2 zn(VjOAW?FQ9U6qU*dPun;saU43U+%DCzzdBQc_gBlA%b6fq~&yr?XW|XmM&$aZGAX zN@h`ve_pCfQD#}Hg04cSpJ$kBP_So+W3Ym!pNqerYp|zdOt7o3YjB8bkb+rEK!8t7 zqKR%!etKqcNoICTYF=54Pi9g~ab`)XZb4#lc4B&JaZEvGfqr~hYF<iyk$y%=ZjNbA zW|BTAEhVNT7Jvd@zc{f%ub}c4TS<O=abg88DAU@3vM~n-qW~ix69*#*vVcjZ|13;G zjBJcd|5%tg7=;+w{<AS5XaPnJMkXdcCILns#v&C^VZwilD?UE0w4}5sH9o!wR7Mmr zgMuGaN=6A*<mTvsEU(DTDN0RDNi71$%`ML4{Ji3l#JrN?B2Y;Jj;kV3P}s4RCFYc- z78l7gFfc@M=Hw?Q=J+M%rh)?*Y#}&MkqBjwE)JXA{FKt1R69nH*FX^>!o<TQz{J8R K#K^(O#S8#|eyLpm diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py deleted file mode 100644 index 61d5fb6a..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py +++ /dev/null @@ -1,54 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from genshi.core import QName, Attrs -from genshi.core import START, END, TEXT, COMMENT, DOCTYPE - - -def to_genshi(walker): - """Convert a tree to a genshi tree - - :arg walker: the treewalker to use to walk the tree to convert it - - :returns: generator of genshi nodes - - """ - text = [] - for token in walker: - type = token["type"] - if type in ("Characters", "SpaceCharacters"): - text.append(token["data"]) - elif text: - yield TEXT, "".join(text), (None, -1, -1) - text = [] - - if type in ("StartTag", "EmptyTag"): - if token["namespace"]: - name = "{%s}%s" % (token["namespace"], token["name"]) - else: - name = token["name"] - attrs = Attrs([(QName("{%s}%s" % attr if attr[0] is not None else attr[1]), value) - for attr, value in token["data"].items()]) - yield (START, (QName(name), attrs), (None, -1, -1)) - if type == "EmptyTag": - type = "EndTag" - - if type == "EndTag": - if token["namespace"]: - name = "{%s}%s" % (token["namespace"], token["name"]) - else: - name = token["name"] - - yield END, QName(name), (None, -1, -1) - - elif type == "Comment": - yield COMMENT, token["data"], (None, -1, -1) - - elif type == "Doctype": - yield DOCTYPE, (token["name"], token["publicId"], - token["systemId"]), (None, -1, -1) - - else: - pass # FIXME: What to do? - - if text: - yield TEXT, "".join(text), (None, -1, -1) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/sax.py b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/sax.py deleted file mode 100644 index f4ccea5a..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/sax.py +++ /dev/null @@ -1,50 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from xml.sax.xmlreader import AttributesNSImpl - -from ..constants import adjustForeignAttributes, unadjustForeignAttributes - -prefix_mapping = {} -for prefix, localName, namespace in adjustForeignAttributes.values(): - if prefix is not None: - prefix_mapping[prefix] = namespace - - -def to_sax(walker, handler): - """Call SAX-like content handler based on treewalker walker - - :arg walker: the treewalker to use to walk the tree to convert it - - :arg handler: SAX handler to use - - """ - handler.startDocument() - for prefix, namespace in prefix_mapping.items(): - handler.startPrefixMapping(prefix, namespace) - - for token in walker: - type = token["type"] - if type == "Doctype": - continue - elif type in ("StartTag", "EmptyTag"): - attrs = AttributesNSImpl(token["data"], - unadjustForeignAttributes) - handler.startElementNS((token["namespace"], token["name"]), - token["name"], - attrs) - if type == "EmptyTag": - handler.endElementNS((token["namespace"], token["name"]), - token["name"]) - elif type == "EndTag": - handler.endElementNS((token["namespace"], token["name"]), - token["name"]) - elif type in ("Characters", "SpaceCharacters"): - handler.characters(token["data"]) - elif type == "Comment": - pass - else: - assert False, "Unknown token type" - - for prefix, namespace in prefix_mapping.items(): - handler.endPrefixMapping(prefix) - handler.endDocument() diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py deleted file mode 100644 index d44447ea..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py +++ /dev/null @@ -1,88 +0,0 @@ -"""A collection of modules for building different kinds of trees from HTML -documents. - -To create a treebuilder for a new type of tree, you need to do -implement several things: - -1. A set of classes for various types of elements: Document, Doctype, Comment, - Element. These must implement the interface of ``base.treebuilders.Node`` - (although comment nodes have a different signature for their constructor, - see ``treebuilders.etree.Comment``) Textual content may also be implemented - as another node type, or not, as your tree implementation requires. - -2. A treebuilder object (called ``TreeBuilder`` by convention) that inherits - from ``treebuilders.base.TreeBuilder``. This has 4 required attributes: - - * ``documentClass`` - the class to use for the bottommost node of a document - * ``elementClass`` - the class to use for HTML Elements - * ``commentClass`` - the class to use for comments - * ``doctypeClass`` - the class to use for doctypes - - It also has one required method: - - * ``getDocument`` - Returns the root node of the complete document tree - -3. If you wish to run the unit tests, you must also create a ``testSerializer`` - method on your treebuilder which accepts a node and returns a string - containing Node and its children serialized according to the format used in - the unittests - -""" - -from __future__ import absolute_import, division, unicode_literals - -from .._utils import default_etree - -treeBuilderCache = {} - - -def getTreeBuilder(treeType, implementation=None, **kwargs): - """Get a TreeBuilder class for various types of trees with built-in support - - :arg treeType: the name of the tree type required (case-insensitive). Supported - values are: - - * "dom" - A generic builder for DOM implementations, defaulting to a - xml.dom.minidom based implementation. - * "etree" - A generic builder for tree implementations exposing an - ElementTree-like interface, defaulting to xml.etree.cElementTree if - available and xml.etree.ElementTree if not. - * "lxml" - A etree-based builder for lxml.etree, handling limitations - of lxml's implementation. - - :arg implementation: (Currently applies to the "etree" and "dom" tree - types). A module implementing the tree type e.g. xml.etree.ElementTree - or xml.etree.cElementTree. - - :arg kwargs: Any additional options to pass to the TreeBuilder when - creating it. - - Example: - - >>> from html5lib.treebuilders import getTreeBuilder - >>> builder = getTreeBuilder('etree') - - """ - - treeType = treeType.lower() - if treeType not in treeBuilderCache: - if treeType == "dom": - from . import dom - # Come up with a sane default (pref. from the stdlib) - if implementation is None: - from xml.dom import minidom - implementation = minidom - # NEVER cache here, caching is done in the dom submodule - return dom.getDomModule(implementation, **kwargs).TreeBuilder - elif treeType == "lxml": - from . import etree_lxml - treeBuilderCache[treeType] = etree_lxml.TreeBuilder - elif treeType == "etree": - from . import etree - if implementation is None: - implementation = default_etree - # NEVER cache here, caching is done in the etree submodule - return etree.getETreeModule(implementation, **kwargs).TreeBuilder - else: - raise ValueError("""Unrecognised treebuilder "%s" """ % treeType) - return treeBuilderCache.get(treeType) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 3804fd8036fd70557bf6a8df2be70d28b2b44c3d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3360 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 diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-39.pyc deleted file mode 100644 index e4928bd3a95a7fa0c5153de3137e3d337a6b9728..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11344 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 CyTJ+o diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-39.pyc deleted file mode 100644 index 47664e6b588d9feebf437bcfe5c864839a3e6a21..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9481 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 diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-39.pyc deleted file mode 100644 index fcc114b380aee1df39d9a2b8e2be72ad0b24bc7b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11849 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 BiX#93 diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-39.pyc deleted file mode 100644 index 328dbb6ca730053534aeb3d2e7b477426d2afae8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13032 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 diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/base.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/base.py deleted file mode 100644 index 965fce29..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/base.py +++ /dev/null @@ -1,417 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals -from pip._vendor.six import text_type - -from ..constants import scopingElements, tableInsertModeElements, namespaces - -# The scope markers are inserted when entering object elements, -# marquees, table cells, and table captions, and are used to prevent formatting -# from "leaking" into tables, object elements, and marquees. -Marker = None - -listElementsMap = { - None: (frozenset(scopingElements), False), - "button": (frozenset(scopingElements | {(namespaces["html"], "button")}), False), - "list": (frozenset(scopingElements | {(namespaces["html"], "ol"), - (namespaces["html"], "ul")}), False), - "table": (frozenset([(namespaces["html"], "html"), - (namespaces["html"], "table")]), False), - "select": (frozenset([(namespaces["html"], "optgroup"), - (namespaces["html"], "option")]), True) -} - - -class Node(object): - """Represents an item in the tree""" - def __init__(self, name): - """Creates a Node - - :arg name: The tag name associated with the node - - """ - # The tag name associated with the node - self.name = name - # The parent of the current node (or None for the document node) - self.parent = None - # The value of the current node (applies to text nodes and comments) - self.value = None - # A dict holding name -> value pairs for attributes of the node - self.attributes = {} - # A list of child nodes of the current node. This must include all - # elements but not necessarily other node types. - self.childNodes = [] - # A list of miscellaneous flags that can be set on the node. - self._flags = [] - - def __str__(self): - attributesStr = " ".join(["%s=\"%s\"" % (name, value) - for name, value in - self.attributes.items()]) - if attributesStr: - return "<%s %s>" % (self.name, attributesStr) - else: - return "<%s>" % (self.name) - - def __repr__(self): - return "<%s>" % (self.name) - - def appendChild(self, node): - """Insert node as a child of the current node - - :arg node: the node to insert - - """ - raise NotImplementedError - - def insertText(self, data, insertBefore=None): - """Insert data as text in the current node, positioned before the - start of node insertBefore or to the end of the node's text. - - :arg data: the data to insert - - :arg insertBefore: True if you want to insert the text before the node - and False if you want to insert it after the node - - """ - raise NotImplementedError - - def insertBefore(self, node, refNode): - """Insert node as a child of the current node, before refNode in the - list of child nodes. Raises ValueError if refNode is not a child of - the current node - - :arg node: the node to insert - - :arg refNode: the child node to insert the node before - - """ - raise NotImplementedError - - def removeChild(self, node): - """Remove node from the children of the current node - - :arg node: the child node to remove - - """ - raise NotImplementedError - - def reparentChildren(self, newParent): - """Move all the children of the current node to newParent. - This is needed so that trees that don't store text as nodes move the - text in the correct way - - :arg newParent: the node to move all this node's children to - - """ - # XXX - should this method be made more general? - for child in self.childNodes: - newParent.appendChild(child) - self.childNodes = [] - - def cloneNode(self): - """Return a shallow copy of the current node i.e. a node with the same - name and attributes but with no parent or child nodes - """ - raise NotImplementedError - - def hasContent(self): - """Return true if the node has children or text, false otherwise - """ - raise NotImplementedError - - -class ActiveFormattingElements(list): - def append(self, node): - equalCount = 0 - if node != Marker: - for element in self[::-1]: - if element == Marker: - break - if self.nodesEqual(element, node): - equalCount += 1 - if equalCount == 3: - self.remove(element) - break - list.append(self, node) - - def nodesEqual(self, node1, node2): - if not node1.nameTuple == node2.nameTuple: - return False - - if not node1.attributes == node2.attributes: - return False - - return True - - -class TreeBuilder(object): - """Base treebuilder implementation - - * documentClass - the class to use for the bottommost node of a document - * elementClass - the class to use for HTML Elements - * commentClass - the class to use for comments - * doctypeClass - the class to use for doctypes - - """ - # pylint:disable=not-callable - - # Document class - documentClass = None - - # The class to use for creating a node - elementClass = None - - # The class to use for creating comments - commentClass = None - - # The class to use for creating doctypes - doctypeClass = None - - # Fragment class - fragmentClass = None - - def __init__(self, namespaceHTMLElements): - """Create a TreeBuilder - - :arg namespaceHTMLElements: whether or not to namespace HTML elements - - """ - if namespaceHTMLElements: - self.defaultNamespace = "http://www.w3.org/1999/xhtml" - else: - self.defaultNamespace = None - self.reset() - - def reset(self): - self.openElements = [] - self.activeFormattingElements = ActiveFormattingElements() - - # XXX - rename these to headElement, formElement - self.headPointer = None - self.formPointer = None - - self.insertFromTable = False - - self.document = self.documentClass() - - def elementInScope(self, target, variant=None): - - # If we pass a node in we match that. if we pass a string - # match any node with that name - exactNode = hasattr(target, "nameTuple") - if not exactNode: - if isinstance(target, text_type): - target = (namespaces["html"], target) - assert isinstance(target, tuple) - - listElements, invert = listElementsMap[variant] - - for node in reversed(self.openElements): - if exactNode and node == target: - return True - elif not exactNode and node.nameTuple == target: - return True - elif (invert ^ (node.nameTuple in listElements)): - return False - - assert False # We should never reach this point - - def reconstructActiveFormattingElements(self): - # Within this algorithm the order of steps described in the - # specification is not quite the same as the order of steps in the - # code. It should still do the same though. - - # Step 1: stop the algorithm when there's nothing to do. - if not self.activeFormattingElements: - return - - # Step 2 and step 3: we start with the last element. So i is -1. - i = len(self.activeFormattingElements) - 1 - entry = self.activeFormattingElements[i] - if entry == Marker or entry in self.openElements: - return - - # Step 6 - while entry != Marker and entry not in self.openElements: - if i == 0: - # This will be reset to 0 below - i = -1 - break - i -= 1 - # Step 5: let entry be one earlier in the list. - entry = self.activeFormattingElements[i] - - while True: - # Step 7 - i += 1 - - # Step 8 - entry = self.activeFormattingElements[i] - clone = entry.cloneNode() # Mainly to get a new copy of the attributes - - # Step 9 - element = self.insertElement({"type": "StartTag", - "name": clone.name, - "namespace": clone.namespace, - "data": clone.attributes}) - - # Step 10 - self.activeFormattingElements[i] = element - - # Step 11 - if element == self.activeFormattingElements[-1]: - break - - def clearActiveFormattingElements(self): - entry = self.activeFormattingElements.pop() - while self.activeFormattingElements and entry != Marker: - entry = self.activeFormattingElements.pop() - - def elementInActiveFormattingElements(self, name): - """Check if an element exists between the end of the active - formatting elements and the last marker. If it does, return it, else - return false""" - - for item in self.activeFormattingElements[::-1]: - # Check for Marker first because if it's a Marker it doesn't have a - # name attribute. - if item == Marker: - break - elif item.name == name: - return item - return False - - def insertRoot(self, token): - element = self.createElement(token) - self.openElements.append(element) - self.document.appendChild(element) - - def insertDoctype(self, token): - name = token["name"] - publicId = token["publicId"] - systemId = token["systemId"] - - doctype = self.doctypeClass(name, publicId, systemId) - self.document.appendChild(doctype) - - def insertComment(self, token, parent=None): - if parent is None: - parent = self.openElements[-1] - parent.appendChild(self.commentClass(token["data"])) - - def createElement(self, token): - """Create an element but don't insert it anywhere""" - name = token["name"] - namespace = token.get("namespace", self.defaultNamespace) - element = self.elementClass(name, namespace) - element.attributes = token["data"] - return element - - def _getInsertFromTable(self): - return self._insertFromTable - - def _setInsertFromTable(self, value): - """Switch the function used to insert an element from the - normal one to the misnested table one and back again""" - self._insertFromTable = value - if value: - self.insertElement = self.insertElementTable - else: - self.insertElement = self.insertElementNormal - - insertFromTable = property(_getInsertFromTable, _setInsertFromTable) - - def insertElementNormal(self, token): - name = token["name"] - assert isinstance(name, text_type), "Element %s not unicode" % name - namespace = token.get("namespace", self.defaultNamespace) - element = self.elementClass(name, namespace) - element.attributes = token["data"] - self.openElements[-1].appendChild(element) - self.openElements.append(element) - return element - - def insertElementTable(self, token): - """Create an element and insert it into the tree""" - element = self.createElement(token) - if self.openElements[-1].name not in tableInsertModeElements: - return self.insertElementNormal(token) - else: - # We should be in the InTable mode. This means we want to do - # special magic element rearranging - parent, insertBefore = self.getTableMisnestedNodePosition() - if insertBefore is None: - parent.appendChild(element) - else: - parent.insertBefore(element, insertBefore) - self.openElements.append(element) - return element - - def insertText(self, data, parent=None): - """Insert text data.""" - if parent is None: - parent = self.openElements[-1] - - if (not self.insertFromTable or (self.insertFromTable and - self.openElements[-1].name - not in tableInsertModeElements)): - parent.insertText(data) - else: - # We should be in the InTable mode. This means we want to do - # special magic element rearranging - parent, insertBefore = self.getTableMisnestedNodePosition() - parent.insertText(data, insertBefore) - - def getTableMisnestedNodePosition(self): - """Get the foster parent element, and sibling to insert before - (or None) when inserting a misnested table node""" - # The foster parent element is the one which comes before the most - # recently opened table element - # XXX - this is really inelegant - lastTable = None - fosterParent = None - insertBefore = None - for elm in self.openElements[::-1]: - if elm.name == "table": - lastTable = elm - break - if lastTable: - # XXX - we should really check that this parent is actually a - # node here - if lastTable.parent: - fosterParent = lastTable.parent - insertBefore = lastTable - else: - fosterParent = self.openElements[ - self.openElements.index(lastTable) - 1] - else: - fosterParent = self.openElements[0] - return fosterParent, insertBefore - - def generateImpliedEndTags(self, exclude=None): - name = self.openElements[-1].name - # XXX td, th and tr are not actually needed - if (name in frozenset(("dd", "dt", "li", "option", "optgroup", "p", "rp", "rt")) and - name != exclude): - self.openElements.pop() - # XXX This is not entirely what the specification says. We should - # investigate it more closely. - self.generateImpliedEndTags(exclude) - - def getDocument(self): - """Return the final tree""" - return self.document - - def getFragment(self): - """Return the final fragment""" - # assert self.innerHTML - fragment = self.fragmentClass() - self.openElements[0].reparentChildren(fragment) - return fragment - - def testSerializer(self, node): - """Serialize the subtree of node in the format required by unit tests - - :arg node: the node from which to start serializing - - """ - raise NotImplementedError diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/dom.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/dom.py deleted file mode 100644 index d8b53004..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/dom.py +++ /dev/null @@ -1,239 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - - -try: - from collections.abc import MutableMapping -except ImportError: # Python 2.7 - from collections import MutableMapping -from xml.dom import minidom, Node -import weakref - -from . import base -from .. import constants -from ..constants import namespaces -from .._utils import moduleFactoryFactory - - -def getDomBuilder(DomImplementation): - Dom = DomImplementation - - class AttrList(MutableMapping): - def __init__(self, element): - self.element = element - - def __iter__(self): - return iter(self.element.attributes.keys()) - - def __setitem__(self, name, value): - if isinstance(name, tuple): - raise NotImplementedError - else: - attr = self.element.ownerDocument.createAttribute(name) - attr.value = value - self.element.attributes[name] = attr - - def __len__(self): - return len(self.element.attributes) - - def items(self): - return list(self.element.attributes.items()) - - def values(self): - return list(self.element.attributes.values()) - - def __getitem__(self, name): - if isinstance(name, tuple): - raise NotImplementedError - else: - return self.element.attributes[name].value - - def __delitem__(self, name): - if isinstance(name, tuple): - raise NotImplementedError - else: - del self.element.attributes[name] - - class NodeBuilder(base.Node): - def __init__(self, element): - base.Node.__init__(self, element.nodeName) - self.element = element - - namespace = property(lambda self: hasattr(self.element, "namespaceURI") and - self.element.namespaceURI or None) - - def appendChild(self, node): - node.parent = self - self.element.appendChild(node.element) - - def insertText(self, data, insertBefore=None): - text = self.element.ownerDocument.createTextNode(data) - if insertBefore: - self.element.insertBefore(text, insertBefore.element) - else: - self.element.appendChild(text) - - def insertBefore(self, node, refNode): - self.element.insertBefore(node.element, refNode.element) - node.parent = self - - def removeChild(self, node): - if node.element.parentNode == self.element: - self.element.removeChild(node.element) - node.parent = None - - def reparentChildren(self, newParent): - while self.element.hasChildNodes(): - child = self.element.firstChild - self.element.removeChild(child) - newParent.element.appendChild(child) - self.childNodes = [] - - def getAttributes(self): - return AttrList(self.element) - - def setAttributes(self, attributes): - if attributes: - for name, value in list(attributes.items()): - if isinstance(name, tuple): - if name[0] is not None: - qualifiedName = (name[0] + ":" + name[1]) - else: - qualifiedName = name[1] - self.element.setAttributeNS(name[2], qualifiedName, - value) - else: - self.element.setAttribute( - name, value) - attributes = property(getAttributes, setAttributes) - - def cloneNode(self): - return NodeBuilder(self.element.cloneNode(False)) - - def hasContent(self): - return self.element.hasChildNodes() - - def getNameTuple(self): - if self.namespace is None: - return namespaces["html"], self.name - else: - return self.namespace, self.name - - nameTuple = property(getNameTuple) - - class TreeBuilder(base.TreeBuilder): # pylint:disable=unused-variable - def documentClass(self): - self.dom = Dom.getDOMImplementation().createDocument(None, None, None) - return weakref.proxy(self) - - def insertDoctype(self, token): - name = token["name"] - publicId = token["publicId"] - systemId = token["systemId"] - - domimpl = Dom.getDOMImplementation() - doctype = domimpl.createDocumentType(name, publicId, systemId) - self.document.appendChild(NodeBuilder(doctype)) - if Dom == minidom: - doctype.ownerDocument = self.dom - - def elementClass(self, name, namespace=None): - if namespace is None and self.defaultNamespace is None: - node = self.dom.createElement(name) - else: - node = self.dom.createElementNS(namespace, name) - - return NodeBuilder(node) - - def commentClass(self, data): - return NodeBuilder(self.dom.createComment(data)) - - def fragmentClass(self): - return NodeBuilder(self.dom.createDocumentFragment()) - - def appendChild(self, node): - self.dom.appendChild(node.element) - - def testSerializer(self, element): - return testSerializer(element) - - def getDocument(self): - return self.dom - - def getFragment(self): - return base.TreeBuilder.getFragment(self).element - - def insertText(self, data, parent=None): - data = data - if parent != self: - base.TreeBuilder.insertText(self, data, parent) - else: - # HACK: allow text nodes as children of the document node - if hasattr(self.dom, '_child_node_types'): - # pylint:disable=protected-access - if Node.TEXT_NODE not in self.dom._child_node_types: - self.dom._child_node_types = list(self.dom._child_node_types) - self.dom._child_node_types.append(Node.TEXT_NODE) - self.dom.appendChild(self.dom.createTextNode(data)) - - implementation = DomImplementation - name = None - - def testSerializer(element): - element.normalize() - rv = [] - - def serializeElement(element, indent=0): - if element.nodeType == Node.DOCUMENT_TYPE_NODE: - if element.name: - if element.publicId or element.systemId: - publicId = element.publicId or "" - systemId = element.systemId or "" - rv.append("""|%s<!DOCTYPE %s "%s" "%s">""" % - (' ' * indent, element.name, publicId, systemId)) - else: - rv.append("|%s<!DOCTYPE %s>" % (' ' * indent, element.name)) - else: - rv.append("|%s<!DOCTYPE >" % (' ' * indent,)) - elif element.nodeType == Node.DOCUMENT_NODE: - rv.append("#document") - elif element.nodeType == Node.DOCUMENT_FRAGMENT_NODE: - rv.append("#document-fragment") - elif element.nodeType == Node.COMMENT_NODE: - rv.append("|%s<!-- %s -->" % (' ' * indent, element.nodeValue)) - elif element.nodeType == Node.TEXT_NODE: - rv.append("|%s\"%s\"" % (' ' * indent, element.nodeValue)) - else: - if (hasattr(element, "namespaceURI") and - element.namespaceURI is not None): - name = "%s %s" % (constants.prefixes[element.namespaceURI], - element.nodeName) - else: - name = element.nodeName - rv.append("|%s<%s>" % (' ' * indent, name)) - if element.hasAttributes(): - attributes = [] - for i in range(len(element.attributes)): - attr = element.attributes.item(i) - name = attr.nodeName - value = attr.value - ns = attr.namespaceURI - if ns: - name = "%s %s" % (constants.prefixes[ns], attr.localName) - else: - name = attr.nodeName - attributes.append((name, value)) - - for name, value in sorted(attributes): - rv.append('|%s%s="%s"' % (' ' * (indent + 2), name, value)) - indent += 2 - for child in element.childNodes: - serializeElement(child, indent) - serializeElement(element, 0) - - return "\n".join(rv) - - return locals() - - -# The actual means to get a module! -getDomModule = moduleFactoryFactory(getDomBuilder) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree.py deleted file mode 100644 index ea92dc30..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree.py +++ /dev/null @@ -1,343 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals -# pylint:disable=protected-access - -from pip._vendor.six import text_type - -import re - -from copy import copy - -from . import base -from .. import _ihatexml -from .. import constants -from ..constants import namespaces -from .._utils import moduleFactoryFactory - -tag_regexp = re.compile("{([^}]*)}(.*)") - - -def getETreeBuilder(ElementTreeImplementation, fullTree=False): - ElementTree = ElementTreeImplementation - ElementTreeCommentType = ElementTree.Comment("asd").tag - - class Element(base.Node): - def __init__(self, name, namespace=None): - self._name = name - self._namespace = namespace - self._element = ElementTree.Element(self._getETreeTag(name, - namespace)) - if namespace is None: - self.nameTuple = namespaces["html"], self._name - else: - self.nameTuple = self._namespace, self._name - self.parent = None - self._childNodes = [] - self._flags = [] - - def _getETreeTag(self, name, namespace): - if namespace is None: - etree_tag = name - else: - etree_tag = "{%s}%s" % (namespace, name) - return etree_tag - - def _setName(self, name): - self._name = name - self._element.tag = self._getETreeTag(self._name, self._namespace) - - def _getName(self): - return self._name - - name = property(_getName, _setName) - - def _setNamespace(self, namespace): - self._namespace = namespace - self._element.tag = self._getETreeTag(self._name, self._namespace) - - def _getNamespace(self): - return self._namespace - - namespace = property(_getNamespace, _setNamespace) - - def _getAttributes(self): - return self._element.attrib - - def _setAttributes(self, attributes): - el_attrib = self._element.attrib - el_attrib.clear() - if attributes: - # calling .items _always_ allocates, and the above truthy check is cheaper than the - # allocation on average - for key, value in attributes.items(): - if isinstance(key, tuple): - name = "{%s}%s" % (key[2], key[1]) - else: - name = key - el_attrib[name] = value - - attributes = property(_getAttributes, _setAttributes) - - def _getChildNodes(self): - return self._childNodes - - def _setChildNodes(self, value): - del self._element[:] - self._childNodes = [] - for element in value: - self.insertChild(element) - - childNodes = property(_getChildNodes, _setChildNodes) - - def hasContent(self): - """Return true if the node has children or text""" - return bool(self._element.text or len(self._element)) - - def appendChild(self, node): - self._childNodes.append(node) - self._element.append(node._element) - node.parent = self - - def insertBefore(self, node, refNode): - index = list(self._element).index(refNode._element) - self._element.insert(index, node._element) - node.parent = self - - def removeChild(self, node): - self._childNodes.remove(node) - self._element.remove(node._element) - node.parent = None - - def insertText(self, data, insertBefore=None): - if not(len(self._element)): - if not self._element.text: - self._element.text = "" - self._element.text += data - elif insertBefore is None: - # Insert the text as the tail of the last child element - if not self._element[-1].tail: - self._element[-1].tail = "" - self._element[-1].tail += data - else: - # Insert the text before the specified node - children = list(self._element) - index = children.index(insertBefore._element) - if index > 0: - if not self._element[index - 1].tail: - self._element[index - 1].tail = "" - self._element[index - 1].tail += data - else: - if not self._element.text: - self._element.text = "" - self._element.text += data - - def cloneNode(self): - element = type(self)(self.name, self.namespace) - if self._element.attrib: - element._element.attrib = copy(self._element.attrib) - return element - - def reparentChildren(self, newParent): - if newParent.childNodes: - newParent.childNodes[-1]._element.tail += self._element.text - else: - if not newParent._element.text: - newParent._element.text = "" - if self._element.text is not None: - newParent._element.text += self._element.text - self._element.text = "" - base.Node.reparentChildren(self, newParent) - - class Comment(Element): - def __init__(self, data): - # Use the superclass constructor to set all properties on the - # wrapper element - self._element = ElementTree.Comment(data) - self.parent = None - self._childNodes = [] - self._flags = [] - - def _getData(self): - return self._element.text - - def _setData(self, value): - self._element.text = value - - data = property(_getData, _setData) - - class DocumentType(Element): - def __init__(self, name, publicId, systemId): - Element.__init__(self, "<!DOCTYPE>") - self._element.text = name - self.publicId = publicId - self.systemId = systemId - - def _getPublicId(self): - return self._element.get("publicId", "") - - def _setPublicId(self, value): - if value is not None: - self._element.set("publicId", value) - - publicId = property(_getPublicId, _setPublicId) - - def _getSystemId(self): - return self._element.get("systemId", "") - - def _setSystemId(self, value): - if value is not None: - self._element.set("systemId", value) - - systemId = property(_getSystemId, _setSystemId) - - class Document(Element): - def __init__(self): - Element.__init__(self, "DOCUMENT_ROOT") - - class DocumentFragment(Element): - def __init__(self): - Element.__init__(self, "DOCUMENT_FRAGMENT") - - def testSerializer(element): - rv = [] - - def serializeElement(element, indent=0): - if not(hasattr(element, "tag")): - element = element.getroot() - if element.tag == "<!DOCTYPE>": - if element.get("publicId") or element.get("systemId"): - publicId = element.get("publicId") or "" - systemId = element.get("systemId") or "" - rv.append("""<!DOCTYPE %s "%s" "%s">""" % - (element.text, publicId, systemId)) - else: - rv.append("<!DOCTYPE %s>" % (element.text,)) - elif element.tag == "DOCUMENT_ROOT": - rv.append("#document") - if element.text is not None: - rv.append("|%s\"%s\"" % (' ' * (indent + 2), element.text)) - if element.tail is not None: - raise TypeError("Document node cannot have tail") - if hasattr(element, "attrib") and len(element.attrib): - raise TypeError("Document node cannot have attributes") - elif element.tag == ElementTreeCommentType: - rv.append("|%s<!-- %s -->" % (' ' * indent, element.text)) - else: - assert isinstance(element.tag, text_type), \ - "Expected unicode, got %s, %s" % (type(element.tag), element.tag) - nsmatch = tag_regexp.match(element.tag) - - if nsmatch is None: - name = element.tag - else: - ns, name = nsmatch.groups() - prefix = constants.prefixes[ns] - name = "%s %s" % (prefix, name) - rv.append("|%s<%s>" % (' ' * indent, name)) - - if hasattr(element, "attrib"): - attributes = [] - for name, value in element.attrib.items(): - nsmatch = tag_regexp.match(name) - if nsmatch is not None: - ns, name = nsmatch.groups() - prefix = constants.prefixes[ns] - attr_string = "%s %s" % (prefix, name) - else: - attr_string = name - attributes.append((attr_string, value)) - - for name, value in sorted(attributes): - rv.append('|%s%s="%s"' % (' ' * (indent + 2), name, value)) - if element.text: - rv.append("|%s\"%s\"" % (' ' * (indent + 2), element.text)) - indent += 2 - for child in element: - serializeElement(child, indent) - if element.tail: - rv.append("|%s\"%s\"" % (' ' * (indent - 2), element.tail)) - serializeElement(element, 0) - - return "\n".join(rv) - - def tostring(element): # pylint:disable=unused-variable - """Serialize an element and its child nodes to a string""" - rv = [] - filter = _ihatexml.InfosetFilter() - - def serializeElement(element): - if isinstance(element, ElementTree.ElementTree): - element = element.getroot() - - if element.tag == "<!DOCTYPE>": - if element.get("publicId") or element.get("systemId"): - publicId = element.get("publicId") or "" - systemId = element.get("systemId") or "" - rv.append("""<!DOCTYPE %s PUBLIC "%s" "%s">""" % - (element.text, publicId, systemId)) - else: - rv.append("<!DOCTYPE %s>" % (element.text,)) - elif element.tag == "DOCUMENT_ROOT": - if element.text is not None: - rv.append(element.text) - if element.tail is not None: - raise TypeError("Document node cannot have tail") - if hasattr(element, "attrib") and len(element.attrib): - raise TypeError("Document node cannot have attributes") - - for child in element: - serializeElement(child) - - elif element.tag == ElementTreeCommentType: - rv.append("<!--%s-->" % (element.text,)) - else: - # This is assumed to be an ordinary element - if not element.attrib: - rv.append("<%s>" % (filter.fromXmlName(element.tag),)) - else: - attr = " ".join(["%s=\"%s\"" % ( - filter.fromXmlName(name), value) - for name, value in element.attrib.items()]) - rv.append("<%s %s>" % (element.tag, attr)) - if element.text: - rv.append(element.text) - - for child in element: - serializeElement(child) - - rv.append("</%s>" % (element.tag,)) - - if element.tail: - rv.append(element.tail) - - serializeElement(element) - - return "".join(rv) - - class TreeBuilder(base.TreeBuilder): # pylint:disable=unused-variable - documentClass = Document - doctypeClass = DocumentType - elementClass = Element - commentClass = Comment - fragmentClass = DocumentFragment - implementation = ElementTreeImplementation - - def testSerializer(self, element): - return testSerializer(element) - - def getDocument(self): - if fullTree: - return self.document._element - else: - if self.defaultNamespace is not None: - return self.document._element.find( - "{%s}html" % self.defaultNamespace) - else: - return self.document._element.find("html") - - def getFragment(self): - return base.TreeBuilder.getFragment(self)._element - - return locals() - - -getETreeModule = moduleFactoryFactory(getETreeBuilder) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py deleted file mode 100644 index f037759f..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py +++ /dev/null @@ -1,392 +0,0 @@ -"""Module for supporting the lxml.etree library. The idea here is to use as much -of the native library as possible, without using fragile hacks like custom element -names that break between releases. The downside of this is that we cannot represent -all possible trees; specifically the following are known to cause problems: - -Text or comments as siblings of the root element -Docypes with no name - -When any of these things occur, we emit a DataLossWarning -""" - -from __future__ import absolute_import, division, unicode_literals -# pylint:disable=protected-access - -import warnings -import re -import sys - -try: - from collections.abc import MutableMapping -except ImportError: - from collections import MutableMapping - -from . import base -from ..constants import DataLossWarning -from .. import constants -from . import etree as etree_builders -from .. import _ihatexml - -import lxml.etree as etree -from pip._vendor.six import PY3, binary_type - - -fullTree = True -tag_regexp = re.compile("{([^}]*)}(.*)") - -comment_type = etree.Comment("asd").tag - - -class DocumentType(object): - def __init__(self, name, publicId, systemId): - self.name = name - self.publicId = publicId - self.systemId = systemId - - -class Document(object): - def __init__(self): - self._elementTree = None - self._childNodes = [] - - def appendChild(self, element): - last = self._elementTree.getroot() - for last in self._elementTree.getroot().itersiblings(): - pass - - last.addnext(element._element) - - def _getChildNodes(self): - return self._childNodes - - childNodes = property(_getChildNodes) - - -def testSerializer(element): - rv = [] - infosetFilter = _ihatexml.InfosetFilter(preventDoubleDashComments=True) - - def serializeElement(element, indent=0): - if not hasattr(element, "tag"): - if hasattr(element, "getroot"): - # Full tree case - rv.append("#document") - if element.docinfo.internalDTD: - if not (element.docinfo.public_id or - element.docinfo.system_url): - dtd_str = "<!DOCTYPE %s>" % element.docinfo.root_name - else: - dtd_str = """<!DOCTYPE %s "%s" "%s">""" % ( - element.docinfo.root_name, - element.docinfo.public_id, - element.docinfo.system_url) - rv.append("|%s%s" % (' ' * (indent + 2), dtd_str)) - next_element = element.getroot() - while next_element.getprevious() is not None: - next_element = next_element.getprevious() - while next_element is not None: - serializeElement(next_element, indent + 2) - next_element = next_element.getnext() - elif isinstance(element, str) or isinstance(element, bytes): - # Text in a fragment - assert isinstance(element, str) or sys.version_info[0] == 2 - rv.append("|%s\"%s\"" % (' ' * indent, element)) - else: - # Fragment case - rv.append("#document-fragment") - for next_element in element: - serializeElement(next_element, indent + 2) - elif element.tag == comment_type: - rv.append("|%s<!-- %s -->" % (' ' * indent, element.text)) - if hasattr(element, "tail") and element.tail: - rv.append("|%s\"%s\"" % (' ' * indent, element.tail)) - else: - assert isinstance(element, etree._Element) - nsmatch = etree_builders.tag_regexp.match(element.tag) - if nsmatch is not None: - ns = nsmatch.group(1) - tag = nsmatch.group(2) - prefix = constants.prefixes[ns] - rv.append("|%s<%s %s>" % (' ' * indent, prefix, - infosetFilter.fromXmlName(tag))) - else: - rv.append("|%s<%s>" % (' ' * indent, - infosetFilter.fromXmlName(element.tag))) - - if hasattr(element, "attrib"): - attributes = [] - for name, value in element.attrib.items(): - nsmatch = tag_regexp.match(name) - if nsmatch is not None: - ns, name = nsmatch.groups() - name = infosetFilter.fromXmlName(name) - prefix = constants.prefixes[ns] - attr_string = "%s %s" % (prefix, name) - else: - attr_string = infosetFilter.fromXmlName(name) - attributes.append((attr_string, value)) - - for name, value in sorted(attributes): - rv.append('|%s%s="%s"' % (' ' * (indent + 2), name, value)) - - if element.text: - rv.append("|%s\"%s\"" % (' ' * (indent + 2), element.text)) - indent += 2 - for child in element: - serializeElement(child, indent) - if hasattr(element, "tail") and element.tail: - rv.append("|%s\"%s\"" % (' ' * (indent - 2), element.tail)) - serializeElement(element, 0) - - return "\n".join(rv) - - -def tostring(element): - """Serialize an element and its child nodes to a string""" - rv = [] - - def serializeElement(element): - if not hasattr(element, "tag"): - if element.docinfo.internalDTD: - if element.docinfo.doctype: - dtd_str = element.docinfo.doctype - else: - dtd_str = "<!DOCTYPE %s>" % element.docinfo.root_name - rv.append(dtd_str) - serializeElement(element.getroot()) - - elif element.tag == comment_type: - rv.append("<!--%s-->" % (element.text,)) - - else: - # This is assumed to be an ordinary element - if not element.attrib: - rv.append("<%s>" % (element.tag,)) - else: - attr = " ".join(["%s=\"%s\"" % (name, value) - for name, value in element.attrib.items()]) - rv.append("<%s %s>" % (element.tag, attr)) - if element.text: - rv.append(element.text) - - for child in element: - serializeElement(child) - - rv.append("</%s>" % (element.tag,)) - - if hasattr(element, "tail") and element.tail: - rv.append(element.tail) - - serializeElement(element) - - return "".join(rv) - - -class TreeBuilder(base.TreeBuilder): - documentClass = Document - doctypeClass = DocumentType - elementClass = None - commentClass = None - fragmentClass = Document - implementation = etree - - def __init__(self, namespaceHTMLElements, fullTree=False): - builder = etree_builders.getETreeModule(etree, fullTree=fullTree) - infosetFilter = self.infosetFilter = _ihatexml.InfosetFilter(preventDoubleDashComments=True) - self.namespaceHTMLElements = namespaceHTMLElements - - class Attributes(MutableMapping): - def __init__(self, element): - self._element = element - - def _coerceKey(self, key): - if isinstance(key, tuple): - name = "{%s}%s" % (key[2], infosetFilter.coerceAttribute(key[1])) - else: - name = infosetFilter.coerceAttribute(key) - return name - - def __getitem__(self, key): - value = self._element._element.attrib[self._coerceKey(key)] - if not PY3 and isinstance(value, binary_type): - value = value.decode("ascii") - return value - - def __setitem__(self, key, value): - self._element._element.attrib[self._coerceKey(key)] = value - - def __delitem__(self, key): - del self._element._element.attrib[self._coerceKey(key)] - - def __iter__(self): - return iter(self._element._element.attrib) - - def __len__(self): - return len(self._element._element.attrib) - - def clear(self): - return self._element._element.attrib.clear() - - class Element(builder.Element): - def __init__(self, name, namespace): - name = infosetFilter.coerceElement(name) - builder.Element.__init__(self, name, namespace=namespace) - self._attributes = Attributes(self) - - def _setName(self, name): - self._name = infosetFilter.coerceElement(name) - self._element.tag = self._getETreeTag( - self._name, self._namespace) - - def _getName(self): - return infosetFilter.fromXmlName(self._name) - - name = property(_getName, _setName) - - def _getAttributes(self): - return self._attributes - - def _setAttributes(self, value): - attributes = self.attributes - attributes.clear() - attributes.update(value) - - attributes = property(_getAttributes, _setAttributes) - - def insertText(self, data, insertBefore=None): - data = infosetFilter.coerceCharacters(data) - builder.Element.insertText(self, data, insertBefore) - - def cloneNode(self): - element = type(self)(self.name, self.namespace) - if self._element.attrib: - element._element.attrib.update(self._element.attrib) - return element - - class Comment(builder.Comment): - def __init__(self, data): - data = infosetFilter.coerceComment(data) - builder.Comment.__init__(self, data) - - def _setData(self, data): - data = infosetFilter.coerceComment(data) - self._element.text = data - - def _getData(self): - return self._element.text - - data = property(_getData, _setData) - - self.elementClass = Element - self.commentClass = Comment - # self.fragmentClass = builder.DocumentFragment - base.TreeBuilder.__init__(self, namespaceHTMLElements) - - def reset(self): - base.TreeBuilder.reset(self) - self.insertComment = self.insertCommentInitial - self.initial_comments = [] - self.doctype = None - - def testSerializer(self, element): - return testSerializer(element) - - def getDocument(self): - if fullTree: - return self.document._elementTree - else: - return self.document._elementTree.getroot() - - def getFragment(self): - fragment = [] - element = self.openElements[0]._element - if element.text: - fragment.append(element.text) - fragment.extend(list(element)) - if element.tail: - fragment.append(element.tail) - return fragment - - def insertDoctype(self, token): - name = token["name"] - publicId = token["publicId"] - systemId = token["systemId"] - - if not name: - warnings.warn("lxml cannot represent empty doctype", DataLossWarning) - self.doctype = None - else: - coercedName = self.infosetFilter.coerceElement(name) - if coercedName != name: - warnings.warn("lxml cannot represent non-xml doctype", DataLossWarning) - - doctype = self.doctypeClass(coercedName, publicId, systemId) - self.doctype = doctype - - def insertCommentInitial(self, data, parent=None): - assert parent is None or parent is self.document - assert self.document._elementTree is None - self.initial_comments.append(data) - - def insertCommentMain(self, data, parent=None): - if (parent == self.document and - self.document._elementTree.getroot()[-1].tag == comment_type): - warnings.warn("lxml cannot represent adjacent comments beyond the root elements", DataLossWarning) - super(TreeBuilder, self).insertComment(data, parent) - - def insertRoot(self, token): - # Because of the way libxml2 works, it doesn't seem to be possible to - # alter information like the doctype after the tree has been parsed. - # Therefore we need to use the built-in parser to create our initial - # tree, after which we can add elements like normal - docStr = "" - if self.doctype: - assert self.doctype.name - docStr += "<!DOCTYPE %s" % self.doctype.name - if (self.doctype.publicId is not None or - self.doctype.systemId is not None): - docStr += (' PUBLIC "%s" ' % - (self.infosetFilter.coercePubid(self.doctype.publicId or ""))) - if self.doctype.systemId: - sysid = self.doctype.systemId - if sysid.find("'") >= 0 and sysid.find('"') >= 0: - warnings.warn("DOCTYPE system cannot contain single and double quotes", DataLossWarning) - sysid = sysid.replace("'", 'U00027') - if sysid.find("'") >= 0: - docStr += '"%s"' % sysid - else: - docStr += "'%s'" % sysid - else: - docStr += "''" - docStr += ">" - if self.doctype.name != token["name"]: - warnings.warn("lxml cannot represent doctype with a different name to the root element", DataLossWarning) - docStr += "<THIS_SHOULD_NEVER_APPEAR_PUBLICLY/>" - root = etree.fromstring(docStr) - - # Append the initial comments: - for comment_token in self.initial_comments: - comment = self.commentClass(comment_token["data"]) - root.addprevious(comment._element) - - # Create the root document and add the ElementTree to it - self.document = self.documentClass() - self.document._elementTree = root.getroottree() - - # Give the root element the right name - name = token["name"] - namespace = token.get("namespace", self.defaultNamespace) - if namespace is None: - etree_tag = name - else: - etree_tag = "{%s}%s" % (namespace, name) - root.tag = etree_tag - - # Add the root element to the internal child/open data structures - root_element = self.elementClass(name, namespace) - root_element._element = root - self.document._childNodes.append(root_element) - self.openElements.append(root_element) - - # Reset to the default insert comment function - self.insertComment = self.insertCommentMain diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py deleted file mode 100644 index b2d3aac3..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py +++ /dev/null @@ -1,154 +0,0 @@ -"""A collection of modules for iterating through different kinds of -tree, generating tokens identical to those produced by the tokenizer -module. - -To create a tree walker for a new type of tree, you need to -implement a tree walker object (called TreeWalker by convention) that -implements a 'serialize' method which takes a tree as sole argument and -returns an iterator which generates tokens. -""" - -from __future__ import absolute_import, division, unicode_literals - -from .. import constants -from .._utils import default_etree - -__all__ = ["getTreeWalker", "pprint"] - -treeWalkerCache = {} - - -def getTreeWalker(treeType, implementation=None, **kwargs): - """Get a TreeWalker class for various types of tree with built-in support - - :arg str treeType: the name of the tree type required (case-insensitive). - Supported values are: - - * "dom": The xml.dom.minidom DOM implementation - * "etree": A generic walker for tree implementations exposing an - elementtree-like interface (known to work with ElementTree, - cElementTree and lxml.etree). - * "lxml": Optimized walker for lxml.etree - * "genshi": a Genshi stream - - :arg implementation: A module implementing the tree type e.g. - xml.etree.ElementTree or cElementTree (Currently applies to the "etree" - tree type only). - - :arg kwargs: keyword arguments passed to the etree walker--for other - walkers, this has no effect - - :returns: a TreeWalker class - - """ - - treeType = treeType.lower() - if treeType not in treeWalkerCache: - if treeType == "dom": - from . import dom - treeWalkerCache[treeType] = dom.TreeWalker - elif treeType == "genshi": - from . import genshi - treeWalkerCache[treeType] = genshi.TreeWalker - elif treeType == "lxml": - from . import etree_lxml - treeWalkerCache[treeType] = etree_lxml.TreeWalker - elif treeType == "etree": - from . import etree - if implementation is None: - implementation = default_etree - # XXX: NEVER cache here, caching is done in the etree submodule - return etree.getETreeModule(implementation, **kwargs).TreeWalker - return treeWalkerCache.get(treeType) - - -def concatenateCharacterTokens(tokens): - pendingCharacters = [] - for token in tokens: - type = token["type"] - if type in ("Characters", "SpaceCharacters"): - pendingCharacters.append(token["data"]) - else: - if pendingCharacters: - yield {"type": "Characters", "data": "".join(pendingCharacters)} - pendingCharacters = [] - yield token - if pendingCharacters: - yield {"type": "Characters", "data": "".join(pendingCharacters)} - - -def pprint(walker): - """Pretty printer for tree walkers - - Takes a TreeWalker instance and pretty prints the output of walking the tree. - - :arg walker: a TreeWalker instance - - """ - output = [] - indent = 0 - for token in concatenateCharacterTokens(walker): - type = token["type"] - if type in ("StartTag", "EmptyTag"): - # tag name - if token["namespace"] and token["namespace"] != constants.namespaces["html"]: - if token["namespace"] in constants.prefixes: - ns = constants.prefixes[token["namespace"]] - else: - ns = token["namespace"] - name = "%s %s" % (ns, token["name"]) - else: - name = token["name"] - output.append("%s<%s>" % (" " * indent, name)) - indent += 2 - # attributes (sorted for consistent ordering) - attrs = token["data"] - for (namespace, localname), value in sorted(attrs.items()): - if namespace: - if namespace in constants.prefixes: - ns = constants.prefixes[namespace] - else: - ns = namespace - name = "%s %s" % (ns, localname) - else: - name = localname - output.append("%s%s=\"%s\"" % (" " * indent, name, value)) - # self-closing - if type == "EmptyTag": - indent -= 2 - - elif type == "EndTag": - indent -= 2 - - elif type == "Comment": - output.append("%s<!-- %s -->" % (" " * indent, token["data"])) - - elif type == "Doctype": - if token["name"]: - if token["publicId"]: - output.append("""%s<!DOCTYPE %s "%s" "%s">""" % - (" " * indent, - token["name"], - token["publicId"], - token["systemId"] if token["systemId"] else "")) - elif token["systemId"]: - output.append("""%s<!DOCTYPE %s "" "%s">""" % - (" " * indent, - token["name"], - token["systemId"])) - else: - output.append("%s<!DOCTYPE %s>" % (" " * indent, - token["name"])) - else: - output.append("%s<!DOCTYPE >" % (" " * indent,)) - - elif type == "Characters": - output.append("%s\"%s\"" % (" " * indent, token["data"])) - - elif type == "SpaceCharacters": - assert False, "concatenateCharacterTokens should have got rid of all Space tokens" - - else: - raise ValueError("Unknown token type, %s" % type) - - return "\n".join(output) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 34fc06cf9a14d6271ded03f3177b5eb10e08e77d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4026 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 TE)gakMjj>(CKhHc9S(i~Irdbl diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-39.pyc deleted file mode 100644 index bbfc8763f08952bd75c0f9e1920594a433f827ab..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7025 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 A6#xJL diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-39.pyc deleted file mode 100644 index 1147e58ae30c8a58fdd3f93181e7639a5f5a7f41..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1760 zcmYe~<>g{vU|^UdaWJ)&m4V?gh=Yt-7#J8F7#J9eofsGxQW#Pga~N_NqZo6UqL^}- zqnH^%VoW(KxvWvFj0`EvDJ(f`x$IHwj12A!DXb}MEet7asq9%C&CF4pDeS=vnj9}d zrfV|a;!jK}&d(_=NsZ6UEyyn_xy6x^S(aIxnV)w{pfoQtIX@*eJ}0vzwJ0&CSd;M< zi(h_9>Ptoj1_lr(DX};;8DtPLW`a3Yhk=11l_82Tg&~S5g)xPxg&~R=<g^xsC>DsL zqF7VdQ#e`}qS#V6gBdirZgGVarKW}_=47W9C4<a?nG5nh8v_G_Gbji?FfcIGFlI57 zFlI4jGZiV6FlVvUFlMpVFlMpUFlMo*u>`~9IZ7C_IMbNQ7>evln6tQQ7_+$3nBcNJ z*-S<2G8t-_N_cA+v-lS9FJx$DbYY0KsAaBUTp&=xypXY$xrRAQu&AYmIZLR93B;~p z&Js>zvSBEUfrzCr)G%kULPScKvqWkbvjl4xvqWo{Y8V%YEo4Yzh1(~d%~W)(ggHwB z%^i{@j9F4(S3W3V&XP`J3}z@{&XNK75#-twhG2%3jDDK3Q5<>sDXAfq1*t`>3=9lW zLN5N!p}wwuA@L!R0j}|W{w}UX>>vqt7k_7v&@Gm{#N5<d90jFGIho0xDYrO^D~n4~ zb3Id{I73_`Lcm(0gq&R*LmcCSU7bTb{rw<fEFkG9PLO?Ji8-aIQ9Q0bu3)P`w%lUL z$t*6p#g$l6Qk0ogT9R6PizPd?vN%d0J+;IUCJ0I@Q9K|Q6c;2Wr-lZ3-eN5S8^)QF zpPZQEmzbLx#SS(17T9lKA>NF{V&{y^oD`4&#Zf%Y{=NvC*`d5BUbyE$E{YO^bKQa* z-Qnt^IAG$p*hBri{rtoIG+A!36sP8--C_ax?iMS^6UDb!K-5ZxA_)cthF=}dRxzQ) zsYS&xsW~Z`MKS()sV+sCWvL3f3ZZ_UVXi^Jo*|CG3Z8y0{(i2(o{llWuD-6pA+A9R zW-$Q)J~4?Vx;gpjnZ+fU*)gekWidXPNioHlC8@dviOJcC>8Zsr1(^l<@nxxbDfvbE z86~+nra75O`XxoFspa6rU#y>!pQ~3;d5bSSwFDFlE~zDnnK{Lrp!BZ>$`y<}j3P`z zj66&{j4X^oj9iRt5I!Tve->sQMjj?1Mh@mGNko3qLp2E{dx5eVC{Kg47bu^Bl3p-F z5y(1C#wf0|%%b8FaFncMDiUE}U?>s=5umUF2Uw9L0|Ub?-t^QGH@Hd_kW)bhGcZ<3 zpgIGgh!j_F=cQJZ1ZO7YWagz8Nn^1e999T5>PQYi4+n%QQe41QkXV$O2aXS{4gdu} z09=U{lKp4_fKcS8$$pC?J|2`w;^S{|#mDF7r<CTT#>d~{iH|QVP0WGF6iI>nD+3~A zL4+KLKm<RS1&V_r4h9AW5H1E09E=>&9LyZdU{OC!E|B?Yr6r|Bsqyhepr|Qg2AKmY zTyL>g<mTw5<mZA*mRk&vazxB8KQAaXxwNP_vn&-6hhXy{5f8Q*On|Jv#bE<+za1zw O6@yZe2onzz4>JG-;<+yX diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-39.pyc deleted file mode 100644 index 46f1c0120b90088dcb6ea5059fe4074faf1dbb9c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3522 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 Khlz`sqZ9xPcaoR@ diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-39.pyc deleted file mode 100644 index 01c44c8ed1b1fe27e01317fab78ef36d3185b050..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6659 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 E0Wz^#XaE2J diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-39.pyc deleted file mode 100644 index bb93a33e4dc2f97d74c8b7c0d44ced264c332673..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1916 zcmYe~<>g{vU|^UdaWIvYlY!weh=Yt-7#J8F7#J9e`xqD)QW#Pga~N_NqZo6UqL^}- zqnH^%VoW(KxvWvFU^a6OOD<a!TP}MPdoD*5M=oa+XD(M17g&xZhb5OgiaVDliYJ#h ziZ_=piZ7Qxia%E%N`R3eg*AmOM=)0?N{Epmg*}BMM>tm`N+ee_N|ceoogsxYg{y@j zg)3DkORSkWN-Tvtm_d{0CCH_k%(wUxlZx|mN=s7XGjj{_i%M>Bq-2(57H8(?-4ZCx z%S_HsNsZ6REJ-a&%qiAnyu}*mmzbNX$$E=5IK(k1<QB85pUW-Y2w$IgKSy8J-~dNw z*IVo^{>~wh0j{@LLR=$4G}&%(fYrwP1>a(G^>YEy+z=6G7sn9CTbv+42$Lzm^A@|a zzpt;WU&u>F1_lOA##<~&iN&cenLr$-TRdg?nJKP0sky0nCB?V6@)C1XiwhEyQ;U;9 z{z1kd4dBq1VPIfLWr$)-VTfW%VN79aVTfW*VNPLbVTfW$VGU-`WV^)`Qk0q+o|u!J zT9gd36=n`723Z*x7(j*>M}T9oma&E*i@}8<R-=}whB1Yql(9&!hG79?4Py<{LM9i6 zSgu;;8s;ztMutMA8m3ytLN2JP5QwT21~gS3DGb33nv8y$Ot)A{ic(W=v6bX!r{)!F zvfN@RPR&WX#Zgd{T9%n#T6~K&wJbHS<Q6Mf!AgcASq27%U)|1DF`>n&Ma40xIVqV% zG5&d}E=8GTsS3IZp?;oWu0g?`A&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+ zIr-_C#U+{9F{ycFF+Q0|F~ylBsk#M;$=QkNsl_n`nFadsWvO{7`9=B}CAm4KIhjfN zAg7jtL#$XoJvFa5BU7)S@)k#YJSeTi$Mb^Hy$~oInOGRP7&#aP7&#c(m_c-vFe0?| zVCs{ZL299xkAZ=K0~YKhj0_Alj4{l$%(X1FtToIf4B1RY`)XKXm}=Q-*=yLc7;8Cd z*s_>vIWrk*xoX&57-9`#m}<Fec}kdTxJy`?nTmpHcxt$6xU-mQxU(43m~0pd^*|yi z3^m+P9%l(_3Zo>*<TW)MC2VC3MQdsp7O>ZF)^OBt)iCie6wIn&N@0>@DB;Lv2D6zZ z8EV+FnHREvqnx*f7aZmD@&sxa7H~rJEd(cnyiGOCB^=pIMc-;zz;0y$xwQsnBXjXH zu#JpGUuqZ@aDj9#WCEF$S5?DY!kx`Dfw73MhG79u4a-7Cuy|4pa|th4+^B|O0Ut=* zg&~%w7V3rxjD<>hb~Vf;{9rX+H4Iq-H7tD$V7+QJ%q4;){3Svq!X+Xlq9tN!>}3oS z7>iQ!cxo6Hh}SSf>;NZ87Qb68py)0F<%l9dQ2vuBVq;)nxW$>1pPZNj%6qpsK_oZ_ z-r~wE&de(=Nz6-5EdphlB2fkgh9VIL28Jk()ZBuS%8<nLB6cvhxFoTtBqTBY7F%jw z3P@N0WGs7fel93q7lDe^TP!816(vQSV2PCc<dVvQ)FM!#DB=bg%L5`niL3~eSc>?; z%1ZOH^YY8{H2I1oLDJG7L6*GKijrF_*_nAMw^&jVOA>D}#@}KtNlcGoPb?`Z%1kQ0 z#RBp}krK#dg30-LWvN9asVVU=S;p*JjAccjLIj-OAcP#qd<g~y29O=aE}(P^PUReo zY>aG-EQ~yiT#Q0Yd`u!Bnvv@t2QwFw5EDdJgi(Nri;)k68F@e?6Bi@fe-0)l<|;v? zoB__{#eSNspiBjFVSM~8uK4)e{FKt1)cE*YJn`{`rI1*Nk1vvkISArDP{{ycfn6%b zz`y_sv0_kx#=*$JR|FFA(-a4pm{wX+T9g_eUj!;Ki$M9X2&62E8=9??^NXMn3W|Ji z3_>CT6gS|w!Wkt+;CN*y0u=<eIFs|i$)ltgoG2j41LO{fLs6Z4i^B%uQ#(-VD+W1U Qgo%eyhEaiuhe?1L0EdsyrvLx| diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/base.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/base.py deleted file mode 100644 index 80c474c4..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/base.py +++ /dev/null @@ -1,252 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from xml.dom import Node -from ..constants import namespaces, voidElements, spaceCharacters - -__all__ = ["DOCUMENT", "DOCTYPE", "TEXT", "ELEMENT", "COMMENT", "ENTITY", "UNKNOWN", - "TreeWalker", "NonRecursiveTreeWalker"] - -DOCUMENT = Node.DOCUMENT_NODE -DOCTYPE = Node.DOCUMENT_TYPE_NODE -TEXT = Node.TEXT_NODE -ELEMENT = Node.ELEMENT_NODE -COMMENT = Node.COMMENT_NODE -ENTITY = Node.ENTITY_NODE -UNKNOWN = "<#UNKNOWN#>" - -spaceCharacters = "".join(spaceCharacters) - - -class TreeWalker(object): - """Walks a tree yielding tokens - - Tokens are dicts that all have a ``type`` field specifying the type of the - token. - - """ - def __init__(self, tree): - """Creates a TreeWalker - - :arg tree: the tree to walk - - """ - self.tree = tree - - def __iter__(self): - raise NotImplementedError - - def error(self, msg): - """Generates an error token with the given message - - :arg msg: the error message - - :returns: SerializeError token - - """ - return {"type": "SerializeError", "data": msg} - - def emptyTag(self, namespace, name, attrs, hasChildren=False): - """Generates an EmptyTag token - - :arg namespace: the namespace of the token--can be ``None`` - - :arg name: the name of the element - - :arg attrs: the attributes of the element as a dict - - :arg hasChildren: whether or not to yield a SerializationError because - this tag shouldn't have children - - :returns: EmptyTag token - - """ - yield {"type": "EmptyTag", "name": name, - "namespace": namespace, - "data": attrs} - if hasChildren: - yield self.error("Void element has children") - - def startTag(self, namespace, name, attrs): - """Generates a StartTag token - - :arg namespace: the namespace of the token--can be ``None`` - - :arg name: the name of the element - - :arg attrs: the attributes of the element as a dict - - :returns: StartTag token - - """ - return {"type": "StartTag", - "name": name, - "namespace": namespace, - "data": attrs} - - def endTag(self, namespace, name): - """Generates an EndTag token - - :arg namespace: the namespace of the token--can be ``None`` - - :arg name: the name of the element - - :returns: EndTag token - - """ - return {"type": "EndTag", - "name": name, - "namespace": namespace} - - def text(self, data): - """Generates SpaceCharacters and Characters tokens - - Depending on what's in the data, this generates one or more - ``SpaceCharacters`` and ``Characters`` tokens. - - For example: - - >>> from html5lib.treewalkers.base import TreeWalker - >>> # Give it an empty tree just so it instantiates - >>> walker = TreeWalker([]) - >>> list(walker.text('')) - [] - >>> list(walker.text(' ')) - [{u'data': ' ', u'type': u'SpaceCharacters'}] - >>> list(walker.text(' abc ')) # doctest: +NORMALIZE_WHITESPACE - [{u'data': ' ', u'type': u'SpaceCharacters'}, - {u'data': u'abc', u'type': u'Characters'}, - {u'data': u' ', u'type': u'SpaceCharacters'}] - - :arg data: the text data - - :returns: one or more ``SpaceCharacters`` and ``Characters`` tokens - - """ - data = data - middle = data.lstrip(spaceCharacters) - left = data[:len(data) - len(middle)] - if left: - yield {"type": "SpaceCharacters", "data": left} - data = middle - middle = data.rstrip(spaceCharacters) - right = data[len(middle):] - if middle: - yield {"type": "Characters", "data": middle} - if right: - yield {"type": "SpaceCharacters", "data": right} - - def comment(self, data): - """Generates a Comment token - - :arg data: the comment - - :returns: Comment token - - """ - return {"type": "Comment", "data": data} - - def doctype(self, name, publicId=None, systemId=None): - """Generates a Doctype token - - :arg name: - - :arg publicId: - - :arg systemId: - - :returns: the Doctype token - - """ - return {"type": "Doctype", - "name": name, - "publicId": publicId, - "systemId": systemId} - - def entity(self, name): - """Generates an Entity token - - :arg name: the entity name - - :returns: an Entity token - - """ - return {"type": "Entity", "name": name} - - def unknown(self, nodeType): - """Handles unknown node types""" - return self.error("Unknown node type: " + nodeType) - - -class NonRecursiveTreeWalker(TreeWalker): - def getNodeDetails(self, node): - raise NotImplementedError - - def getFirstChild(self, node): - raise NotImplementedError - - def getNextSibling(self, node): - raise NotImplementedError - - def getParentNode(self, node): - raise NotImplementedError - - def __iter__(self): - currentNode = self.tree - while currentNode is not None: - details = self.getNodeDetails(currentNode) - type, details = details[0], details[1:] - hasChildren = False - - if type == DOCTYPE: - yield self.doctype(*details) - - elif type == TEXT: - for token in self.text(*details): - yield token - - elif type == ELEMENT: - namespace, name, attributes, hasChildren = details - if (not namespace or namespace == namespaces["html"]) and name in voidElements: - for token in self.emptyTag(namespace, name, attributes, - hasChildren): - yield token - hasChildren = False - else: - yield self.startTag(namespace, name, attributes) - - elif type == COMMENT: - yield self.comment(details[0]) - - elif type == ENTITY: - yield self.entity(details[0]) - - elif type == DOCUMENT: - hasChildren = True - - else: - yield self.unknown(details[0]) - - if hasChildren: - firstChild = self.getFirstChild(currentNode) - else: - firstChild = None - - if firstChild is not None: - currentNode = firstChild - else: - while currentNode is not None: - details = self.getNodeDetails(currentNode) - type, details = details[0], details[1:] - if type == ELEMENT: - namespace, name, attributes, hasChildren = details - if (namespace and namespace != namespaces["html"]) or name not in voidElements: - yield self.endTag(namespace, name) - if self.tree is currentNode: - currentNode = None - break - nextSibling = self.getNextSibling(currentNode) - if nextSibling is not None: - currentNode = nextSibling - break - else: - currentNode = self.getParentNode(currentNode) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/dom.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/dom.py deleted file mode 100644 index b0c89b00..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/dom.py +++ /dev/null @@ -1,43 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from xml.dom import Node - -from . import base - - -class TreeWalker(base.NonRecursiveTreeWalker): - def getNodeDetails(self, node): - if node.nodeType == Node.DOCUMENT_TYPE_NODE: - return base.DOCTYPE, node.name, node.publicId, node.systemId - - elif node.nodeType in (Node.TEXT_NODE, Node.CDATA_SECTION_NODE): - return base.TEXT, node.nodeValue - - elif node.nodeType == Node.ELEMENT_NODE: - attrs = {} - for attr in list(node.attributes.keys()): - attr = node.getAttributeNode(attr) - if attr.namespaceURI: - attrs[(attr.namespaceURI, attr.localName)] = attr.value - else: - attrs[(None, attr.name)] = attr.value - return (base.ELEMENT, node.namespaceURI, node.nodeName, - attrs, node.hasChildNodes()) - - elif node.nodeType == Node.COMMENT_NODE: - return base.COMMENT, node.nodeValue - - elif node.nodeType in (Node.DOCUMENT_NODE, Node.DOCUMENT_FRAGMENT_NODE): - return (base.DOCUMENT,) - - else: - return base.UNKNOWN, node.nodeType - - def getFirstChild(self, node): - return node.firstChild - - def getNextSibling(self, node): - return node.nextSibling - - def getParentNode(self, node): - return node.parentNode diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree.py deleted file mode 100644 index 837b27ec..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree.py +++ /dev/null @@ -1,131 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from collections import OrderedDict -import re - -from pip._vendor.six import string_types - -from . import base -from .._utils import moduleFactoryFactory - -tag_regexp = re.compile("{([^}]*)}(.*)") - - -def getETreeBuilder(ElementTreeImplementation): - ElementTree = ElementTreeImplementation - ElementTreeCommentType = ElementTree.Comment("asd").tag - - class TreeWalker(base.NonRecursiveTreeWalker): # pylint:disable=unused-variable - """Given the particular ElementTree representation, this implementation, - to avoid using recursion, returns "nodes" as tuples with the following - content: - - 1. The current element - - 2. The index of the element relative to its parent - - 3. A stack of ancestor elements - - 4. A flag "text", "tail" or None to indicate if the current node is a - text node; either the text or tail of the current element (1) - """ - def getNodeDetails(self, node): - if isinstance(node, tuple): # It might be the root Element - elt, _, _, flag = node - if flag in ("text", "tail"): - return base.TEXT, getattr(elt, flag) - else: - node = elt - - if not(hasattr(node, "tag")): - node = node.getroot() - - if node.tag in ("DOCUMENT_ROOT", "DOCUMENT_FRAGMENT"): - return (base.DOCUMENT,) - - elif node.tag == "<!DOCTYPE>": - return (base.DOCTYPE, node.text, - node.get("publicId"), node.get("systemId")) - - elif node.tag == ElementTreeCommentType: - return base.COMMENT, node.text - - else: - assert isinstance(node.tag, string_types), type(node.tag) - # This is assumed to be an ordinary element - match = tag_regexp.match(node.tag) - if match: - namespace, tag = match.groups() - else: - namespace = None - tag = node.tag - attrs = OrderedDict() - for name, value in list(node.attrib.items()): - match = tag_regexp.match(name) - if match: - attrs[(match.group(1), match.group(2))] = value - else: - attrs[(None, name)] = value - return (base.ELEMENT, namespace, tag, - attrs, len(node) or node.text) - - def getFirstChild(self, node): - if isinstance(node, tuple): - element, key, parents, flag = node - else: - element, key, parents, flag = node, None, [], None - - if flag in ("text", "tail"): - return None - else: - if element.text: - return element, key, parents, "text" - elif len(element): - parents.append(element) - return element[0], 0, parents, None - else: - return None - - def getNextSibling(self, node): - if isinstance(node, tuple): - element, key, parents, flag = node - else: - return None - - if flag == "text": - if len(element): - parents.append(element) - return element[0], 0, parents, None - else: - return None - else: - if element.tail and flag != "tail": - return element, key, parents, "tail" - elif key < len(parents[-1]) - 1: - return parents[-1][key + 1], key + 1, parents, None - else: - return None - - def getParentNode(self, node): - if isinstance(node, tuple): - element, key, parents, flag = node - else: - return None - - if flag == "text": - if not parents: - return element - else: - return element, key, parents, None - else: - parent = parents.pop() - if not parents: - return parent - else: - assert list(parents[-1]).count(parent) == 1 - return parent, list(parents[-1]).index(parent), parents, None - - return locals() - - -getETreeModule = moduleFactoryFactory(getETreeBuilder) diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py deleted file mode 100644 index c56af390..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py +++ /dev/null @@ -1,215 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals -from pip._vendor.six import text_type - -from collections import OrderedDict - -from lxml import etree -from ..treebuilders.etree import tag_regexp - -from . import base - -from .. import _ihatexml - - -def ensure_str(s): - if s is None: - return None - elif isinstance(s, text_type): - return s - else: - return s.decode("ascii", "strict") - - -class Root(object): - def __init__(self, et): - self.elementtree = et - self.children = [] - - try: - if et.docinfo.internalDTD: - self.children.append(Doctype(self, - ensure_str(et.docinfo.root_name), - ensure_str(et.docinfo.public_id), - ensure_str(et.docinfo.system_url))) - except AttributeError: - pass - - try: - node = et.getroot() - except AttributeError: - node = et - - while node.getprevious() is not None: - node = node.getprevious() - while node is not None: - self.children.append(node) - node = node.getnext() - - self.text = None - self.tail = None - - def __getitem__(self, key): - return self.children[key] - - def getnext(self): - return None - - def __len__(self): - return 1 - - -class Doctype(object): - def __init__(self, root_node, name, public_id, system_id): - self.root_node = root_node - self.name = name - self.public_id = public_id - self.system_id = system_id - - self.text = None - self.tail = None - - def getnext(self): - return self.root_node.children[1] - - -class FragmentRoot(Root): - def __init__(self, children): - self.children = [FragmentWrapper(self, child) for child in children] - self.text = self.tail = None - - def getnext(self): - return None - - -class FragmentWrapper(object): - def __init__(self, fragment_root, obj): - self.root_node = fragment_root - self.obj = obj - if hasattr(self.obj, 'text'): - self.text = ensure_str(self.obj.text) - else: - self.text = None - if hasattr(self.obj, 'tail'): - self.tail = ensure_str(self.obj.tail) - else: - self.tail = None - - def __getattr__(self, name): - return getattr(self.obj, name) - - def getnext(self): - siblings = self.root_node.children - idx = siblings.index(self) - if idx < len(siblings) - 1: - return siblings[idx + 1] - else: - return None - - def __getitem__(self, key): - return self.obj[key] - - def __bool__(self): - return bool(self.obj) - - def getparent(self): - return None - - def __str__(self): - return str(self.obj) - - def __unicode__(self): - return str(self.obj) - - def __len__(self): - return len(self.obj) - - -class TreeWalker(base.NonRecursiveTreeWalker): - def __init__(self, tree): - # pylint:disable=redefined-variable-type - if isinstance(tree, list): - self.fragmentChildren = set(tree) - tree = FragmentRoot(tree) - else: - self.fragmentChildren = set() - tree = Root(tree) - base.NonRecursiveTreeWalker.__init__(self, tree) - self.filter = _ihatexml.InfosetFilter() - - def getNodeDetails(self, node): - if isinstance(node, tuple): # Text node - node, key = node - assert key in ("text", "tail"), "Text nodes are text or tail, found %s" % key - return base.TEXT, ensure_str(getattr(node, key)) - - elif isinstance(node, Root): - return (base.DOCUMENT,) - - elif isinstance(node, Doctype): - return base.DOCTYPE, node.name, node.public_id, node.system_id - - elif isinstance(node, FragmentWrapper) and not hasattr(node, "tag"): - return base.TEXT, ensure_str(node.obj) - - elif node.tag == etree.Comment: - return base.COMMENT, ensure_str(node.text) - - elif node.tag == etree.Entity: - return base.ENTITY, ensure_str(node.text)[1:-1] # strip &; - - else: - # This is assumed to be an ordinary element - match = tag_regexp.match(ensure_str(node.tag)) - if match: - namespace, tag = match.groups() - else: - namespace = None - tag = ensure_str(node.tag) - attrs = OrderedDict() - for name, value in list(node.attrib.items()): - name = ensure_str(name) - value = ensure_str(value) - match = tag_regexp.match(name) - if match: - attrs[(match.group(1), match.group(2))] = value - else: - attrs[(None, name)] = value - return (base.ELEMENT, namespace, self.filter.fromXmlName(tag), - attrs, len(node) > 0 or node.text) - - def getFirstChild(self, node): - assert not isinstance(node, tuple), "Text nodes have no children" - - assert len(node) or node.text, "Node has no children" - if node.text: - return (node, "text") - else: - return node[0] - - def getNextSibling(self, node): - if isinstance(node, tuple): # Text node - node, key = node - assert key in ("text", "tail"), "Text nodes are text or tail, found %s" % key - if key == "text": - # XXX: we cannot use a "bool(node) and node[0] or None" construct here - # because node[0] might evaluate to False if it has no child element - if len(node): - return node[0] - else: - return None - else: # tail - return node.getnext() - - return (node, "tail") if node.tail else node.getnext() - - def getParentNode(self, node): - if isinstance(node, tuple): # Text node - node, key = node - assert key in ("text", "tail"), "Text nodes are text or tail, found %s" % key - if key == "text": - return node - # else: fallback to "normal" processing - elif node in self.fragmentChildren: - return None - - return node.getparent() diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py deleted file mode 100644 index 7483be27..00000000 --- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py +++ /dev/null @@ -1,69 +0,0 @@ -from __future__ import absolute_import, division, unicode_literals - -from genshi.core import QName -from genshi.core import START, END, XML_NAMESPACE, DOCTYPE, TEXT -from genshi.core import START_NS, END_NS, START_CDATA, END_CDATA, PI, COMMENT - -from . import base - -from ..constants import voidElements, namespaces - - -class TreeWalker(base.TreeWalker): - def __iter__(self): - # Buffer the events so we can pass in the following one - previous = None - for event in self.tree: - if previous is not None: - for token in self.tokens(previous, event): - yield token - previous = event - - # Don't forget the final event! - if previous is not None: - for token in self.tokens(previous, None): - yield token - - def tokens(self, event, next): - kind, data, _ = event - if kind == START: - tag, attribs = data - name = tag.localname - namespace = tag.namespace - converted_attribs = {} - for k, v in attribs: - if isinstance(k, QName): - converted_attribs[(k.namespace, k.localname)] = v - else: - converted_attribs[(None, k)] = v - - if namespace == namespaces["html"] and name in voidElements: - for token in self.emptyTag(namespace, name, converted_attribs, - not next or next[0] != END or - next[1] != tag): - yield token - else: - yield self.startTag(namespace, name, converted_attribs) - - elif kind == END: - name = data.localname - namespace = data.namespace - if namespace != namespaces["html"] or name not in voidElements: - yield self.endTag(namespace, name) - - elif kind == COMMENT: - yield self.comment(data) - - elif kind == TEXT: - for token in self.text(data): - yield token - - elif kind == DOCTYPE: - yield self.doctype(*data) - - elif kind in (XML_NAMESPACE, DOCTYPE, START_NS, END_NS, - START_CDATA, END_CDATA, PI): - pass - - else: - yield self.unknown(kind) diff --git a/env/Lib/site-packages/pip/_vendor/idna/__init__.py b/env/Lib/site-packages/pip/_vendor/idna/__init__.py index 847bf935..a40eeafc 100644 --- a/env/Lib/site-packages/pip/_vendor/idna/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/idna/__init__.py @@ -1,2 +1,44 @@ from .package_data import __version__ -from .core import * +from .core import ( + IDNABidiError, + IDNAError, + InvalidCodepoint, + InvalidCodepointContext, + alabel, + check_bidi, + check_hyphen_ok, + check_initial_combiner, + check_label, + check_nfc, + decode, + encode, + ulabel, + uts46_remap, + valid_contextj, + valid_contexto, + valid_label_length, + valid_string_length, +) +from .intranges import intranges_contain + +__all__ = [ + "IDNABidiError", + "IDNAError", + "InvalidCodepoint", + "InvalidCodepointContext", + "alabel", + "check_bidi", + "check_hyphen_ok", + "check_initial_combiner", + "check_label", + "check_nfc", + "decode", + "encode", + "intranges_contain", + "ulabel", + "uts46_remap", + "valid_contextj", + "valid_contexto", + "valid_label_length", + "valid_string_length", +] diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 9153748e3386dc6e8428f5c6eeee01482af68441..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 285 zcmYe~<>g{vU|^UdaWK`2fq~&Mh=Yuo7#J8F7#J9eB^VeOQW#Pga~N_NqZk=MY^EHh z5QY@yU<OT=my8Sy44RC$xZ~r?Qj3Z+^Yh~4H5qR)YWZn0-{L7qOwLYBPmNDWEJ-W^ znRtsOIlm}%B|{M#0|SKkRqJdO6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq z;ux&p>F46_=Njzk7!&O3>lz&58l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0n zstdKeIHn-8KtH}LH7_N<NIx?rFHt`}J~J<~BtBlRpz;=nO>TZlX-=vg$RoudH}Wt7 E0MNor%K!iX diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-39.pyc deleted file mode 100644 index 8842b410416ab5da9865a9fe1ff35997e2fb9a68..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2819 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 E082_zmjD0& diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-39.pyc deleted file mode 100644 index aa878326e9d1859aea85e744013129b15ff77d1d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 657 zcmYe~<>g{vU|^UdaWM4-0|Ucj5C<7EF)%PVFfcF_>o71dq%fo~<}idnXvPqR6s8pB z7KSLM6qXd$7KSM16t)!h7KSL66pmm9P0p8$3=9mKjJFuIl0ht(sUSAURA-Q>91IK$ zB@8tT&5XeeD;fPX8E>(r<|XH+q^@MV#hR0tl$x`Wp@^M<f#FxRvsFxJacWU<OlnR_ zW>JiPUaCt`W?8C&u0p7vXP9eHuxE&4u!5(bi@%?1u%}~8u&b|YaENP=f>}&JfKN=K ziEd7QdS-D+W_C<!URjJ!W>QRXW=X1UL1J=tVtQ(EOhIOWetcPKUP^wEer8HuqJDCI zZb4#+UP0w8_K<wXU}sNH7Lc1kj%Q#j;$&c8AkJe&%#eU!OGyQJt%#L@0pcmJ&x$}{ zaEmh}KQu2BBn|RyG1Lxjyms(_122WKnX!p6g&~+hlgY12$J52nQNhT-z(OG<KebpP zFTX^gv?Mbpvp7{DFEKZ@peVIKp`a+gBtJPnN0afEuwQ<OXKq1GYHn&?NotB~QBi&o zD9(x@ZUZ?6;y@0VZcuuGxsQ*5fx%Cc^%hHVeo^WzR*>_P!2weQa(NL*8p#|a!)$W% XQ%ZAE?Ldj47!&{;j2uiH%pA-B)S8X# diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-39.pyc deleted file mode 100644 index 92702b5b1057f0b3f71546eef5f22b964953fee6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9113 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 bbJ=jPb8vF7ap-Vqawu>}a!7K?aLEGzq_{*P diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-39.pyc deleted file mode 100644 index 50dcaa5a94151ca7e0d72d83f83aff1d52423aa6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 22166 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 F764rPD<J>? diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-39.pyc deleted file mode 100644 index 3378c2c3ec717fcdb9763c7d652400034fdcafed..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1837 zcmYe~<>g{vU|^UdaWM5N8w0~*5C<7EF)%PVFfcF_8!#|1q%cG=q%fv1<uFDurZA_l zv@k?5rLd;3wJ=06r?97Rv@k@mq;RHiwJ=1nrZ5FFXmTfVGBPl5xo4K8<|!m9<YX3? zDCDOpWagEmrl%Ga>nP+VrlcyA7JvjbGV%*j(@Jx4Dm4`n6^e5cb8-~&N^_G^i$JnD z`FZIIMWuPgT={7V$@zK3smY}!nPsU+W+mt67L=BxDkLftr4|&W7N_QwB$j06=Yh1B zWTYyj<rn30X=oIeBo>tz>L{e<r5I}JC_wl|V7`&2f}Wn9rk+Ab2FSg6#pS6*3Lve8 zrK!bWqm;@MixnyqpvH4$=7FX2i!#$Q^AdBw9<*0d010R2rYiVr<m9JoD1+Utsj0{H z5)`t2$&4ThirE+#7}yyY7@R?2+`+)WP{L5d(9BrNn9fkkl)_lcT*6qwRKwWJ*v#m{ z5SvuXQp1wMB+dX4%VsF@s$r~Qkz@doAaO~C6ebCVY^EZwLYW%I8fK6fL`N%=BttE0 z4buYV5|$d)6lO_=8rBp>ka}^3W~POVj0`m_wakSwC9E|}&5Xeenk<RZj0_Axu%N^e zeF}-ipqNT6EKSWzP6Y*XQDR<tYOxiUf`WnqG^FDVz(E^t01xYUNZ`kVLLU^|Its<5 z$r%bI8Hpt*p$RqxmQ)lHi&7O*D-x4Saw-){GV+U46)KSQfg?3OQ^Ceop+dn16u0r2 zpa@qe&d*I%$kgKk8x{n19>l1;<ouM>6p$B+GxO4O5D5vIA{1<F6pW1&YCvXb>L}#p zmw?oklosTq7VCjcd-?zW|Nk#Rky!*HG}&&k73UX~q^8_r1&6~e=A6{LTWpC11*v%{ zw|L`I!B)mY<XFKbX|mm71!ao(Tig(>@gUwUHn5uFTU<Gb#U=6OMVTe3w-_^T@g|oR z6{Y5tK#W+)P$a;>!0@Zi*(xTqIJKxaCN(D|vna+tFV&?8lrwY{Lj63$T!Vr=LmYz@ zJpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgsUw zld}`kQ;TB?G7I$M%Tn`F@{9B{Q}Pn^GxJIyF4QZiyd@0h#iteJ=Yo9zDpQKZKuMf~ zgOP=ig;9V}fKh^xiBW`6hLMe_NQi-fAsJM(fRunRhz-KvY{0|7z)-`G!f3}(!|22i z%%I8S_fmm@0pedxrdzDw*uKS_nwJ6&0tg`pQo+H%z#tFGN+81+7>huBl>7#YDP~xH z1BD;RB72Z^Ob!fbpfZcuuSl4IfguN^>VN(JdS<A-jJFtzAU1)t6@jd~#T%cJ3Q9+i z7*Rs9SRCDlpiIsJv$zVH(Nh?knQECz7#A?rFxD_FWU6JZVNPMpW-0P3VTNR12?j}q zX2uw%T9#VY8kQOc76xX9Y{nwD8rE!vBELKqMut3=6y{)t8c?=oY-Y@6C@O>Kh3jJj z>C0v+Dg&uYVF_l?WUaDwNi9h&%FWD6Rme<JNXX19iBC{SOU%hB1{J9J3i)~9{0u7l zATbRp(-I)e1U+ziF9HQnh?^!WIFN6#C1n<;CYRjehS2djsc9uepin3R6>*yEw^%@y z6oKOQ78^M6$KPTu$S=Od0#bR4wJ0+^qvRH2JbDldB9d2feqKppW}X@-n8AsQiHnhk znS)V;QG$_$iHA{u5tP`9KuJZD?G}4{d`f<De0-4vC}Dt79N3`{H-Xe3*@TEu4x8Nk Zl+v73J5WL?2Bl*bb`B;EQ4VGf7693E+>8JK diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-39.pyc deleted file mode 100644 index 4136077de8dc3d40cfbeca722e5029a3bfb8080a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 239 zcmYe~<>g{vU|^UdaWGYsfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}WHjr9!u zG#PJk$H$kY78Pga=f%gbWGG@{V1N+68lA0TLW@(2iepl9QZkET{PR*>iZaVm6?7Fs z{XD~5gMvLn9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u5>0e-^3yYmOER-#QuE4U zd@_?_iZe@6bqf-cvlG)(i(?8h3-sg5Qu9*si}W*7@)Gr-GVv*iC5d_kmA5!-a`RJ4 Nb5iX<p7;#%6#xLCLFxbi diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-39.pyc deleted file mode 100644 index 59e3992c8093fb82c859a5e4cae20fd07c8563ea..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 146174 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 S$(Lm_lOM|_CV!TVO#cBG3F3+X diff --git a/env/Lib/site-packages/pip/_vendor/idna/codec.py b/env/Lib/site-packages/pip/_vendor/idna/codec.py index 30fe72fb..1ca9ba62 100644 --- a/env/Lib/site-packages/pip/_vendor/idna/codec.py +++ b/env/Lib/site-packages/pip/_vendor/idna/codec.py @@ -1,23 +1,22 @@ from .core import encode, decode, alabel, ulabel, IDNAError import codecs import re +from typing import Tuple, Optional _unicode_dots_re = re.compile('[\u002e\u3002\uff0e\uff61]') class Codec(codecs.Codec): - def encode(self, data, errors='strict'): - + def encode(self, data: str, errors: str = 'strict') -> Tuple[bytes, int]: if errors != 'strict': raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) if not data: - return "", 0 + return b"", 0 return encode(data), len(data) - def decode(self, data, errors='strict'): - + def decode(self, data: bytes, errors: str = 'strict') -> Tuple[str, int]: if errors != 'strict': raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) @@ -27,12 +26,12 @@ class Codec(codecs.Codec): return decode(data), len(data) class IncrementalEncoder(codecs.BufferedIncrementalEncoder): - def _buffer_encode(self, data, errors, final): + def _buffer_encode(self, data: str, errors: str, final: bool) -> Tuple[str, int]: # type: ignore if errors != 'strict': raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) if not data: - return ('', 0) + return "", 0 labels = _unicode_dots_re.split(data) trailing_dot = '' @@ -55,12 +54,12 @@ class IncrementalEncoder(codecs.BufferedIncrementalEncoder): size += len(label) # Join with U+002E - result = '.'.join(result) + trailing_dot + result_str = '.'.join(result) + trailing_dot # type: ignore size += len(trailing_dot) - return (result, size) + return result_str, size class IncrementalDecoder(codecs.BufferedIncrementalDecoder): - def _buffer_decode(self, data, errors, final): + def _buffer_decode(self, data: str, errors: str, final: bool) -> Tuple[str, int]: # type: ignore if errors != 'strict': raise IDNAError('Unsupported error handling \"{}\"'.format(errors)) @@ -87,22 +86,25 @@ class IncrementalDecoder(codecs.BufferedIncrementalDecoder): size += 1 size += len(label) - result = '.'.join(result) + trailing_dot + result_str = '.'.join(result) + trailing_dot size += len(trailing_dot) - return (result, size) + return (result_str, size) class StreamWriter(Codec, codecs.StreamWriter): pass + class StreamReader(Codec, codecs.StreamReader): pass -def getregentry(): + +def getregentry() -> codecs.CodecInfo: + # Compatibility as a search_function for codecs.register() return codecs.CodecInfo( name='idna', - encode=Codec().encode, - decode=Codec().decode, + encode=Codec().encode, # type: ignore + decode=Codec().decode, # type: ignore incrementalencoder=IncrementalEncoder, incrementaldecoder=IncrementalDecoder, streamwriter=StreamWriter, diff --git a/env/Lib/site-packages/pip/_vendor/idna/compat.py b/env/Lib/site-packages/pip/_vendor/idna/compat.py index 2e622d6f..786e6bda 100644 --- a/env/Lib/site-packages/pip/_vendor/idna/compat.py +++ b/env/Lib/site-packages/pip/_vendor/idna/compat.py @@ -1,12 +1,13 @@ from .core import * from .codec import * +from typing import Any, Union -def ToASCII(label): +def ToASCII(label: str) -> bytes: return encode(label) -def ToUnicode(label): +def ToUnicode(label: Union[bytes, bytearray]) -> str: return decode(label) -def nameprep(s): +def nameprep(s: Any) -> None: raise NotImplementedError('IDNA 2008 does not utilise nameprep protocol') diff --git a/env/Lib/site-packages/pip/_vendor/idna/core.py b/env/Lib/site-packages/pip/_vendor/idna/core.py index 2c193d63..4f300371 100644 --- a/env/Lib/site-packages/pip/_vendor/idna/core.py +++ b/env/Lib/site-packages/pip/_vendor/idna/core.py @@ -2,7 +2,7 @@ from . import idnadata import bisect import unicodedata import re -import sys +from typing import Union, Optional from .intranges import intranges_contain _virama_combining_class = 9 @@ -29,39 +29,36 @@ class InvalidCodepointContext(IDNAError): pass -def _combining_class(cp): +def _combining_class(cp: int) -> int: v = unicodedata.combining(chr(cp)) if v == 0: if not unicodedata.name(chr(cp)): raise ValueError('Unknown character in unicodedata') return v -def _is_script(cp, script): +def _is_script(cp: str, script: str) -> bool: return intranges_contain(ord(cp), idnadata.scripts[script]) -def _punycode(s): +def _punycode(s: str) -> bytes: return s.encode('punycode') -def _unot(s): +def _unot(s: int) -> str: return 'U+{:04X}'.format(s) -def valid_label_length(label): - +def valid_label_length(label: Union[bytes, str]) -> bool: if len(label) > 63: return False return True -def valid_string_length(label, trailing_dot): - +def valid_string_length(label: Union[bytes, str], trailing_dot: bool) -> bool: if len(label) > (254 if trailing_dot else 253): return False return True -def check_bidi(label, check_ltr=False): - +def check_bidi(label: str, check_ltr: bool = False) -> bool: # Bidi rules should only be applied if string contains RTL characters bidi_label = False for (idx, cp) in enumerate(label, 1): @@ -84,7 +81,7 @@ def check_bidi(label, check_ltr=False): raise IDNABidiError('First codepoint in label {} must be directionality L, R or AL'.format(repr(label))) valid_ending = False - number_type = False + number_type = None # type: Optional[str] for (idx, cp) in enumerate(label, 1): direction = unicodedata.bidirectional(cp) @@ -120,15 +117,13 @@ def check_bidi(label, check_ltr=False): return True -def check_initial_combiner(label): - +def check_initial_combiner(label: str) -> bool: if unicodedata.category(label[0])[0] == 'M': raise IDNAError('Label begins with an illegal combining character') return True -def check_hyphen_ok(label): - +def check_hyphen_ok(label: str) -> bool: if label[2:4] == '--': raise IDNAError('Label has disallowed hyphens in 3rd and 4th position') if label[0] == '-' or label[-1] == '-': @@ -136,14 +131,12 @@ def check_hyphen_ok(label): return True -def check_nfc(label): - +def check_nfc(label: str) -> None: if unicodedata.normalize('NFC', label) != label: raise IDNAError('Label must be in Normalization Form C') -def valid_contextj(label, pos): - +def valid_contextj(label: str, pos: int) -> bool: cp_value = ord(label[pos]) if cp_value == 0x200c: @@ -186,8 +179,7 @@ def valid_contextj(label, pos): return False -def valid_contexto(label, pos, exception=False): - +def valid_contexto(label: str, pos: int, exception: bool = False) -> bool: cp_value = ord(label[pos]) if cp_value == 0x00b7: @@ -226,9 +218,10 @@ def valid_contexto(label, pos, exception=False): return False return True + return False -def check_label(label): +def check_label(label: Union[str, bytes, bytearray]) -> None: if isinstance(label, (bytes, bytearray)): label = label.decode('utf-8') if len(label) == 0: @@ -259,14 +252,13 @@ def check_label(label): check_bidi(label) -def alabel(label): - +def alabel(label: str) -> bytes: try: - label = label.encode('ascii') - ulabel(label) - if not valid_label_length(label): + label_bytes = label.encode('ascii') + ulabel(label_bytes) + if not valid_label_length(label_bytes): raise IDNAError('Label too long') - return label + return label_bytes except UnicodeEncodeError: pass @@ -275,51 +267,58 @@ def alabel(label): label = str(label) check_label(label) - label = _punycode(label) - label = _alabel_prefix + label + label_bytes = _punycode(label) + label_bytes = _alabel_prefix + label_bytes - if not valid_label_length(label): + if not valid_label_length(label_bytes): raise IDNAError('Label too long') - return label - + return label_bytes -def ulabel(label): +def ulabel(label: Union[str, bytes, bytearray]) -> str: if not isinstance(label, (bytes, bytearray)): try: - label = label.encode('ascii') + label_bytes = label.encode('ascii') except UnicodeEncodeError: check_label(label) return label + else: + label_bytes = label - label = label.lower() - if label.startswith(_alabel_prefix): - label = label[len(_alabel_prefix):] - if not label: + label_bytes = label_bytes.lower() + if label_bytes.startswith(_alabel_prefix): + label_bytes = label_bytes[len(_alabel_prefix):] + if not label_bytes: raise IDNAError('Malformed A-label, no Punycode eligible content found') - if label.decode('ascii')[-1] == '-': + if label_bytes.decode('ascii')[-1] == '-': raise IDNAError('A-label must not end with a hyphen') else: - check_label(label) - return label.decode('ascii') + check_label(label_bytes) + return label_bytes.decode('ascii') - label = label.decode('punycode') + try: + label = label_bytes.decode('punycode') + except UnicodeError: + raise IDNAError('Invalid A-label') check_label(label) return label -def uts46_remap(domain, std3_rules=True, transitional=False): +def uts46_remap(domain: str, std3_rules: bool = True, transitional: bool = False) -> str: """Re-map the characters in the string according to UTS46 processing.""" from .uts46data import uts46data output = '' - try: - for pos, char in enumerate(domain): - code_point = ord(char) + + for pos, char in enumerate(domain): + code_point = ord(char) + try: uts46row = uts46data[code_point if code_point < 256 else bisect.bisect_left(uts46data, (code_point, 'Z')) - 1] status = uts46row[1] - replacement = uts46row[2] if len(uts46row) == 3 else None + replacement = None # type: Optional[str] + if len(uts46row) == 3: + replacement = uts46row[2] # type: ignore if (status == 'V' or (status == 'D' and not transitional) or (status == '3' and not std3_rules and replacement is None)): @@ -330,17 +329,20 @@ def uts46_remap(domain, std3_rules=True, transitional=False): output += replacement elif status != 'I': raise IndexError() - return unicodedata.normalize('NFC', output) - except IndexError: - raise InvalidCodepoint( - 'Codepoint {} not allowed at position {} in {}'.format( - _unot(code_point), pos + 1, repr(domain))) + except IndexError: + raise InvalidCodepoint( + 'Codepoint {} not allowed at position {} in {}'.format( + _unot(code_point), pos + 1, repr(domain))) + return unicodedata.normalize('NFC', output) -def encode(s, strict=False, uts46=False, std3_rules=False, transitional=False): +def encode(s: Union[str, bytes, bytearray], strict: bool = False, uts46: bool = False, std3_rules: bool = False, transitional: bool = False) -> bytes: if isinstance(s, (bytes, bytearray)): - s = s.decode('ascii') + try: + s = s.decode('ascii') + except UnicodeDecodeError: + raise IDNAError('should pass a unicode string to the function rather than a byte string.') if uts46: s = uts46_remap(s, std3_rules, transitional) trailing_dot = False @@ -368,10 +370,12 @@ def encode(s, strict=False, uts46=False, std3_rules=False, transitional=False): return s -def decode(s, strict=False, uts46=False, std3_rules=False): - - if isinstance(s, (bytes, bytearray)): - s = s.decode('ascii') +def decode(s: Union[str, bytes, bytearray], strict: bool = False, uts46: bool = False, std3_rules: bool = False) -> str: + try: + if isinstance(s, (bytes, bytearray)): + s = s.decode('ascii') + except UnicodeDecodeError: + raise IDNAError('Invalid ASCII in A-label') if uts46: s = uts46_remap(s, std3_rules, False) trailing_dot = False diff --git a/env/Lib/site-packages/pip/_vendor/idna/idnadata.py b/env/Lib/site-packages/pip/_vendor/idna/idnadata.py index b86a3e06..67db4625 100644 --- a/env/Lib/site-packages/pip/_vendor/idna/idnadata.py +++ b/env/Lib/site-packages/pip/_vendor/idna/idnadata.py @@ -1,6 +1,6 @@ # This file is automatically generated by tools/idna-data -__version__ = '13.0.0' +__version__ = '15.0.0' scripts = { 'Greek': ( 0x37000000374, @@ -49,17 +49,19 @@ scripts = { 0x30210000302a, 0x30380000303c, 0x340000004dc0, - 0x4e0000009ffd, + 0x4e000000a000, 0xf9000000fa6e, 0xfa700000fada, + 0x16fe200016fe4, 0x16ff000016ff2, - 0x200000002a6de, - 0x2a7000002b735, + 0x200000002a6e0, + 0x2a7000002b73a, 0x2b7400002b81e, 0x2b8200002cea2, 0x2ceb00002ebe1, 0x2f8000002fa1e, 0x300000003134b, + 0x31350000323b0, ), 'Hebrew': ( 0x591000005c8, @@ -75,7 +77,8 @@ scripts = { 'Hiragana': ( 0x304100003097, 0x309d000030a0, - 0x1b0010001b11f, + 0x1b0010001b120, + 0x1b1320001b133, 0x1b1500001b153, 0x1f2000001f201, ), @@ -87,7 +90,12 @@ scripts = { 0x330000003358, 0xff660000ff70, 0xff710000ff9e, + 0x1aff00001aff4, + 0x1aff50001affc, + 0x1affd0001afff, 0x1b0000001b001, + 0x1b1200001b123, + 0x1b1550001b156, 0x1b1640001b168, ), } @@ -405,6 +413,39 @@ joining_types = { 0x868: 68, 0x869: 82, 0x86a: 82, + 0x870: 82, + 0x871: 82, + 0x872: 82, + 0x873: 82, + 0x874: 82, + 0x875: 82, + 0x876: 82, + 0x877: 82, + 0x878: 82, + 0x879: 82, + 0x87a: 82, + 0x87b: 82, + 0x87c: 82, + 0x87d: 82, + 0x87e: 82, + 0x87f: 82, + 0x880: 82, + 0x881: 82, + 0x882: 82, + 0x883: 67, + 0x884: 67, + 0x885: 67, + 0x886: 68, + 0x887: 85, + 0x888: 85, + 0x889: 68, + 0x88a: 68, + 0x88b: 68, + 0x88c: 68, + 0x88d: 68, + 0x88e: 82, + 0x890: 85, + 0x891: 85, 0x8a0: 68, 0x8a1: 68, 0x8a2: 68, @@ -426,6 +467,7 @@ joining_types = { 0x8b2: 82, 0x8b3: 68, 0x8b4: 68, + 0x8b5: 68, 0x8b6: 68, 0x8b7: 68, 0x8b8: 68, @@ -444,6 +486,7 @@ joining_types = { 0x8c5: 68, 0x8c6: 68, 0x8c7: 68, + 0x8c8: 68, 0x8e2: 85, 0x1806: 85, 0x1807: 68, @@ -768,6 +811,24 @@ joining_types = { 0x10f52: 68, 0x10f53: 68, 0x10f54: 82, + 0x10f70: 68, + 0x10f71: 68, + 0x10f72: 68, + 0x10f73: 68, + 0x10f74: 82, + 0x10f75: 82, + 0x10f76: 68, + 0x10f77: 68, + 0x10f78: 68, + 0x10f79: 68, + 0x10f7a: 68, + 0x10f7b: 68, + 0x10f7c: 68, + 0x10f7d: 68, + 0x10f7e: 68, + 0x10f7f: 68, + 0x10f80: 68, + 0x10f81: 68, 0x10fb0: 68, 0x10fb1: 85, 0x10fb2: 68, @@ -1168,9 +1229,9 @@ codepoint_classes = { 0x8000000082e, 0x8400000085c, 0x8600000086b, - 0x8a0000008b5, - 0x8b6000008c8, - 0x8d3000008e2, + 0x87000000888, + 0x8890000088f, + 0x898000008e2, 0x8e300000958, 0x96000000964, 0x96600000970, @@ -1252,11 +1313,12 @@ codepoint_classes = { 0xc0e00000c11, 0xc1200000c29, 0xc2a00000c3a, - 0xc3d00000c45, + 0xc3c00000c45, 0xc4600000c49, 0xc4a00000c4e, 0xc5500000c57, 0xc5800000c5b, + 0xc5d00000c5e, 0xc6000000c64, 0xc6600000c70, 0xc8000000c84, @@ -1269,10 +1331,10 @@ codepoint_classes = { 0xcc600000cc9, 0xcca00000cce, 0xcd500000cd7, - 0xcde00000cdf, + 0xcdd00000cdf, 0xce000000ce4, 0xce600000cf0, - 0xcf100000cf3, + 0xcf100000cf4, 0xd0000000d0d, 0xd0e00000d11, 0xd1200000d45, @@ -1307,7 +1369,7 @@ codepoint_classes = { 0xeb400000ebe, 0xec000000ec5, 0xec600000ec7, - 0xec800000ece, + 0xec800000ecf, 0xed000000eda, 0xede00000ee0, 0xf0000000f01, @@ -1366,9 +1428,8 @@ codepoint_classes = { 0x16810000169b, 0x16a0000016eb, 0x16f1000016f9, - 0x17000000170d, - 0x170e00001715, - 0x172000001735, + 0x170000001716, + 0x171f00001735, 0x174000001754, 0x17600000176d, 0x176e00001771, @@ -1397,8 +1458,8 @@ codepoint_classes = { 0x1a9000001a9a, 0x1aa700001aa8, 0x1ab000001abe, - 0x1abf00001ac1, - 0x1b0000001b4c, + 0x1abf00001acf, + 0x1b0000001b4d, 0x1b5000001b5a, 0x1b6b00001b74, 0x1b8000001bf4, @@ -1413,8 +1474,7 @@ codepoint_classes = { 0x1d4e00001d4f, 0x1d6b00001d78, 0x1d7900001d9b, - 0x1dc000001dfa, - 0x1dfb00001e00, + 0x1dc000001e00, 0x1e0100001e02, 0x1e0300001e04, 0x1e0500001e06, @@ -1563,7 +1623,7 @@ codepoint_classes = { 0x1ff600001ff7, 0x214e0000214f, 0x218400002185, - 0x2c3000002c5f, + 0x2c3000002c60, 0x2c6100002c62, 0x2c6500002c67, 0x2c6800002c69, @@ -1652,8 +1712,7 @@ codepoint_classes = { 0x31a0000031c0, 0x31f000003200, 0x340000004dc0, - 0x4e0000009ffd, - 0xa0000000a48d, + 0x4e000000a48d, 0xa4d00000a4fe, 0xa5000000a60d, 0xa6100000a62c, @@ -1766,9 +1825,16 @@ codepoint_classes = { 0xa7bb0000a7bc, 0xa7bd0000a7be, 0xa7bf0000a7c0, + 0xa7c10000a7c2, 0xa7c30000a7c4, 0xa7c80000a7c9, 0xa7ca0000a7cb, + 0xa7d10000a7d2, + 0xa7d30000a7d4, + 0xa7d50000a7d6, + 0xa7d70000a7d8, + 0xa7d90000a7da, + 0xa7f20000a7f5, 0xa7f60000a7f8, 0xa7fa0000a828, 0xa82c0000a82d, @@ -1796,7 +1862,7 @@ codepoint_classes = { 0xab200000ab27, 0xab280000ab2f, 0xab300000ab5b, - 0xab600000ab6a, + 0xab600000ab69, 0xabc00000abeb, 0xabec0000abee, 0xabf00000abfa, @@ -1834,9 +1900,16 @@ codepoint_classes = { 0x104d8000104fc, 0x1050000010528, 0x1053000010564, + 0x10597000105a2, + 0x105a3000105b2, + 0x105b3000105ba, + 0x105bb000105bd, 0x1060000010737, 0x1074000010756, 0x1076000010768, + 0x1078000010786, + 0x10787000107b1, + 0x107b2000107bb, 0x1080000010806, 0x1080800010809, 0x1080a00010836, @@ -1873,14 +1946,16 @@ codepoint_classes = { 0x10e8000010eaa, 0x10eab00010ead, 0x10eb000010eb2, - 0x10f0000010f1d, + 0x10efd00010f1d, 0x10f2700010f28, 0x10f3000010f51, + 0x10f7000010f86, 0x10fb000010fc5, 0x10fe000010ff7, 0x1100000011047, - 0x1106600011070, + 0x1106600011076, 0x1107f000110bb, + 0x110c2000110c3, 0x110d0000110e9, 0x110f0000110fa, 0x1110000011135, @@ -1894,7 +1969,7 @@ codepoint_classes = { 0x111dc000111dd, 0x1120000011212, 0x1121300011238, - 0x1123e0001123f, + 0x1123e00011242, 0x1128000011287, 0x1128800011289, 0x1128a0001128e, @@ -1934,6 +2009,7 @@ codepoint_classes = { 0x117000001171b, 0x1171d0001172c, 0x117300001173a, + 0x1174000011747, 0x118000001183b, 0x118c0000118ea, 0x118ff00011907, @@ -1952,7 +2028,7 @@ codepoint_classes = { 0x11a4700011a48, 0x11a5000011a9a, 0x11a9d00011a9e, - 0x11ac000011af9, + 0x11ab000011af9, 0x11c0000011c09, 0x11c0a00011c37, 0x11c3800011c41, @@ -1974,14 +2050,22 @@ codepoint_classes = { 0x11d9300011d99, 0x11da000011daa, 0x11ee000011ef7, + 0x11f0000011f11, + 0x11f1200011f3b, + 0x11f3e00011f43, + 0x11f5000011f5a, 0x11fb000011fb1, 0x120000001239a, 0x1248000012544, - 0x130000001342f, + 0x12f9000012ff1, + 0x1300000013430, + 0x1344000013456, 0x1440000014647, 0x1680000016a39, 0x16a4000016a5f, 0x16a6000016a6a, + 0x16a7000016abf, + 0x16ac000016aca, 0x16ad000016aee, 0x16af000016af5, 0x16b0000016b37, @@ -1999,8 +2083,13 @@ codepoint_classes = { 0x17000000187f8, 0x1880000018cd6, 0x18d0000018d09, - 0x1b0000001b11f, + 0x1aff00001aff4, + 0x1aff50001affc, + 0x1affd0001afff, + 0x1b0000001b123, + 0x1b1320001b133, 0x1b1500001b153, + 0x1b1550001b156, 0x1b1640001b168, 0x1b1700001b2fc, 0x1bc000001bc6b, @@ -2008,33 +2097,45 @@ codepoint_classes = { 0x1bc800001bc89, 0x1bc900001bc9a, 0x1bc9d0001bc9f, + 0x1cf000001cf2e, + 0x1cf300001cf47, 0x1da000001da37, 0x1da3b0001da6d, 0x1da750001da76, 0x1da840001da85, 0x1da9b0001daa0, 0x1daa10001dab0, + 0x1df000001df1f, + 0x1df250001df2b, 0x1e0000001e007, 0x1e0080001e019, 0x1e01b0001e022, 0x1e0230001e025, 0x1e0260001e02b, + 0x1e0300001e06e, + 0x1e08f0001e090, 0x1e1000001e12d, 0x1e1300001e13e, 0x1e1400001e14a, 0x1e14e0001e14f, + 0x1e2900001e2af, 0x1e2c00001e2fa, + 0x1e4d00001e4fa, + 0x1e7e00001e7e7, + 0x1e7e80001e7ec, + 0x1e7ed0001e7ef, + 0x1e7f00001e7ff, 0x1e8000001e8c5, 0x1e8d00001e8d7, 0x1e9220001e94c, 0x1e9500001e95a, - 0x1fbf00001fbfa, - 0x200000002a6de, - 0x2a7000002b735, + 0x200000002a6e0, + 0x2a7000002b73a, 0x2b7400002b81e, 0x2b8200002cea2, 0x2ceb00002ebe1, 0x300000003134b, + 0x31350000323b0, ), 'CONTEXTJ': ( 0x200c0000200e, diff --git a/env/Lib/site-packages/pip/_vendor/idna/intranges.py b/env/Lib/site-packages/pip/_vendor/idna/intranges.py index fa8a7356..6a43b047 100644 --- a/env/Lib/site-packages/pip/_vendor/idna/intranges.py +++ b/env/Lib/site-packages/pip/_vendor/idna/intranges.py @@ -6,8 +6,9 @@ in the original list?" in time O(log(# runs)). """ import bisect +from typing import List, Tuple -def intranges_from_list(list_): +def intranges_from_list(list_: List[int]) -> Tuple[int, ...]: """Represent a list of integers as a sequence of ranges: ((start_0, end_0), (start_1, end_1), ...), such that the original integers are exactly those x such that start_i <= x < end_i for some i. @@ -28,14 +29,14 @@ def intranges_from_list(list_): return tuple(ranges) -def _encode_range(start, end): +def _encode_range(start: int, end: int) -> int: return (start << 32) | end -def _decode_range(r): +def _decode_range(r: int) -> Tuple[int, int]: return (r >> 32), (r & ((1 << 32) - 1)) -def intranges_contain(int_, ranges): +def intranges_contain(int_: int, ranges: Tuple[int, ...]) -> bool: """Determine if `int_` falls into one of the ranges in `ranges`.""" tuple_ = _encode_range(int_, 0) pos = bisect.bisect_left(ranges, tuple_) diff --git a/env/Lib/site-packages/pip/_vendor/idna/package_data.py b/env/Lib/site-packages/pip/_vendor/idna/package_data.py index 1420ea2f..8501893b 100644 --- a/env/Lib/site-packages/pip/_vendor/idna/package_data.py +++ b/env/Lib/site-packages/pip/_vendor/idna/package_data.py @@ -1,2 +1,2 @@ -__version__ = '3.1' +__version__ = '3.4' diff --git a/env/Lib/site-packages/pip/_vendor/idna/uts46data.py b/env/Lib/site-packages/pip/_vendor/idna/uts46data.py index 8ae36cbe..186796c1 100644 --- a/env/Lib/site-packages/pip/_vendor/idna/uts46data.py +++ b/env/Lib/site-packages/pip/_vendor/idna/uts46data.py @@ -1,10 +1,14 @@ # This file is automatically generated by tools/idna-data +# vim: set fileencoding=utf-8 : + +from typing import List, Tuple, Union + """IDNA Mapping Table from UTS46.""" -__version__ = '13.0.0' -def _seg_0(): +__version__ = '15.0.0' +def _seg_0() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x0, '3'), (0x1, '3'), @@ -108,7 +112,7 @@ def _seg_0(): (0x63, 'V'), ] -def _seg_1(): +def _seg_1() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x64, 'V'), (0x65, 'V'), @@ -212,7 +216,7 @@ def _seg_1(): (0xC7, 'M', 'ç'), ] -def _seg_2(): +def _seg_2() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0xC8, 'M', 'è'), (0xC9, 'M', 'é'), @@ -316,7 +320,7 @@ def _seg_2(): (0x12B, 'V'), ] -def _seg_3(): +def _seg_3() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x12C, 'M', 'ĭ'), (0x12D, 'V'), @@ -420,7 +424,7 @@ def _seg_3(): (0x193, 'M', 'ɠ'), ] -def _seg_4(): +def _seg_4() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x194, 'M', 'ɣ'), (0x195, 'V'), @@ -524,7 +528,7 @@ def _seg_4(): (0x20C, 'M', 'ȍ'), ] -def _seg_5(): +def _seg_5() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x20D, 'V'), (0x20E, 'M', 'ȏ'), @@ -628,7 +632,7 @@ def _seg_5(): (0x377, 'V'), ] -def _seg_6(): +def _seg_6() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x378, 'X'), (0x37A, '3', ' ι'), @@ -732,7 +736,7 @@ def _seg_6(): (0x402, 'M', 'ђ'), ] -def _seg_7(): +def _seg_7() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x403, 'M', 'ѓ'), (0x404, 'M', 'є'), @@ -836,7 +840,7 @@ def _seg_7(): (0x49D, 'V'), ] -def _seg_8(): +def _seg_8() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x49E, 'M', 'ҟ'), (0x49F, 'V'), @@ -940,7 +944,7 @@ def _seg_8(): (0x502, 'M', 'ԃ'), ] -def _seg_9(): +def _seg_9() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x503, 'V'), (0x504, 'M', 'ԅ'), @@ -1041,10 +1045,10 @@ def _seg_9(): (0x5F5, 'X'), (0x606, 'V'), (0x61C, 'X'), - (0x61E, 'V'), + (0x61D, 'V'), ] -def _seg_10(): +def _seg_10() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x675, 'M', 'اٴ'), (0x676, 'M', 'وٴ'), @@ -1070,11 +1074,9 @@ def _seg_10(): (0x85F, 'X'), (0x860, 'V'), (0x86B, 'X'), - (0x8A0, 'V'), - (0x8B5, 'X'), - (0x8B6, 'V'), - (0x8C8, 'X'), - (0x8D3, 'V'), + (0x870, 'V'), + (0x88F, 'X'), + (0x898, 'V'), (0x8E2, 'X'), (0x8E3, 'V'), (0x958, 'M', 'क़'), @@ -1146,12 +1148,12 @@ def _seg_10(): (0xA59, 'M', 'ਖ਼'), (0xA5A, 'M', 'ਗ਼'), (0xA5B, 'M', 'ਜ਼'), + (0xA5C, 'V'), + (0xA5D, 'X'), ] -def _seg_11(): +def _seg_11() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ - (0xA5C, 'V'), - (0xA5D, 'X'), (0xA5E, 'M', 'ਫ਼'), (0xA5F, 'X'), (0xA66, 'V'), @@ -1250,14 +1252,14 @@ def _seg_11(): (0xC0E, 'V'), (0xC11, 'X'), (0xC12, 'V'), + (0xC29, 'X'), + (0xC2A, 'V'), ] -def _seg_12(): +def _seg_12() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ - (0xC29, 'X'), - (0xC2A, 'V'), (0xC3A, 'X'), - (0xC3D, 'V'), + (0xC3C, 'V'), (0xC45, 'X'), (0xC46, 'V'), (0xC49, 'X'), @@ -1267,6 +1269,8 @@ def _seg_12(): (0xC57, 'X'), (0xC58, 'V'), (0xC5B, 'X'), + (0xC5D, 'V'), + (0xC5E, 'X'), (0xC60, 'V'), (0xC64, 'X'), (0xC66, 'V'), @@ -1289,14 +1293,14 @@ def _seg_12(): (0xCCE, 'X'), (0xCD5, 'V'), (0xCD7, 'X'), - (0xCDE, 'V'), + (0xCDD, 'V'), (0xCDF, 'X'), (0xCE0, 'V'), (0xCE4, 'X'), (0xCE6, 'V'), (0xCF0, 'X'), (0xCF1, 'V'), - (0xCF3, 'X'), + (0xCF4, 'X'), (0xD00, 'V'), (0xD0D, 'X'), (0xD0E, 'V'), @@ -1356,7 +1360,7 @@ def _seg_12(): (0xEB4, 'V'), ] -def _seg_13(): +def _seg_13() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0xEBE, 'X'), (0xEC0, 'V'), @@ -1364,7 +1368,7 @@ def _seg_13(): (0xEC6, 'V'), (0xEC7, 'X'), (0xEC8, 'V'), - (0xECE, 'X'), + (0xECF, 'X'), (0xED0, 'V'), (0xEDA, 'X'), (0xEDC, 'M', 'ຫນ'), @@ -1460,7 +1464,7 @@ def _seg_13(): (0x1312, 'V'), ] -def _seg_14(): +def _seg_14() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ (0x1316, 'X'), (0x1318, 'V'), @@ -1485,10 +1489,8 @@ def _seg_14(): (0x16A0, 'V'), (0x16F9, 'X'), (0x1700, 'V'), - (0x170D, 'X'), - (0x170E, 'V'), - (0x1715, 'X'), - (0x1720, 'V'), + (0x1716, 'X'), + (0x171F, 'V'), (0x1737, 'X'), (0x1740, 'V'), (0x1754, 'X'), @@ -1511,6 +1513,7 @@ def _seg_14(): (0x1807, 'V'), (0x180B, 'I'), (0x180E, 'X'), + (0x180F, 'I'), (0x1810, 'V'), (0x181A, 'X'), (0x1820, 'V'), @@ -1550,11 +1553,11 @@ def _seg_14(): (0x1AA0, 'V'), (0x1AAE, 'X'), (0x1AB0, 'V'), - (0x1AC1, 'X'), + (0x1ACF, 'X'), (0x1B00, 'V'), - (0x1B4C, 'X'), + (0x1B4D, 'X'), (0x1B50, 'V'), - (0x1B7D, 'X'), + (0x1B7F, 'X'), (0x1B80, 'V'), (0x1BF4, 'X'), (0x1BFC, 'V'), @@ -1562,11 +1565,11 @@ def _seg_14(): (0x1C3B, 'V'), (0x1C4A, 'X'), (0x1C4D, 'V'), + (0x1C80, 'M', 'в'), ] -def _seg_15(): +def _seg_15() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ - (0x1C80, 'M', 'в'), (0x1C81, 'M', 'д'), (0x1C82, 'M', 'о'), (0x1C83, 'M', 'с'), @@ -1666,11 +1669,11 @@ def _seg_15(): (0x1D50, 'M', 'm'), (0x1D51, 'M', 'ŋ'), (0x1D52, 'M', 'o'), + (0x1D53, 'M', 'ɔ'), ] -def _seg_16(): +def _seg_16() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: return [ - (0x1D53, 'M', 'ɔ'), (0x1D54, 'M', 'ᴖ'), (0x1D55, 'M', 'ᴗ'), (0x1D56, 'M', 'p'), @@ -1735,8 +1738,6 @@ def _seg_16(): (0x1DBE, 'M', 'ʒ'), (0x1DBF, 'M', 'θ'), (0x1DC0, 'V'), - (0x1DFA, 'X'), - (0x1DFB, 'V'), (0x1E00, 'M', 'ḁ'), (0x1E01, 'V'), (0x1E02, 'M', 'ḃ'), @@ -1770,13 +1771,13 @@ def _seg_16(): (0x1E1E, 'M', 'ḟ'), (0x1E1F, 'V'), (0x1E20, 'M', 'ḡ'), - ] - -def _seg_17(): - return [ (0x1E21, 'V'), (0x1E22, 'M', 'ḣ'), (0x1E23, 'V'), + ] + +def _seg_17() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1E24, 'M', 'ḥ'), (0x1E25, 'V'), (0x1E26, 'M', 'ḧ'), @@ -1874,13 +1875,13 @@ def _seg_17(): (0x1E82, 'M', 'ẃ'), (0x1E83, 'V'), (0x1E84, 'M', 'ẅ'), - ] - -def _seg_18(): - return [ (0x1E85, 'V'), (0x1E86, 'M', 'ẇ'), (0x1E87, 'V'), + ] + +def _seg_18() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1E88, 'M', 'ẉ'), (0x1E89, 'V'), (0x1E8A, 'M', 'ẋ'), @@ -1978,13 +1979,13 @@ def _seg_18(): (0x1EEB, 'V'), (0x1EEC, 'M', 'ử'), (0x1EED, 'V'), - ] - -def _seg_19(): - return [ (0x1EEE, 'M', 'ữ'), (0x1EEF, 'V'), (0x1EF0, 'M', 'ự'), + ] + +def _seg_19() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1EF1, 'V'), (0x1EF2, 'M', 'ỳ'), (0x1EF3, 'V'), @@ -2082,13 +2083,13 @@ def _seg_19(): (0x1F82, 'M', 'ἂι'), (0x1F83, 'M', 'ἃι'), (0x1F84, 'M', 'ἄι'), - ] - -def _seg_20(): - return [ (0x1F85, 'M', 'ἅι'), (0x1F86, 'M', 'ἆι'), (0x1F87, 'M', 'ἇι'), + ] + +def _seg_20() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1F88, 'M', 'ἀι'), (0x1F89, 'M', 'ἁι'), (0x1F8A, 'M', 'ἂι'), @@ -2186,13 +2187,13 @@ def _seg_20(): (0x1FF0, 'X'), (0x1FF2, 'M', 'ὼι'), (0x1FF3, 'M', 'ωι'), - ] - -def _seg_21(): - return [ (0x1FF4, 'M', 'ώι'), (0x1FF5, 'X'), (0x1FF6, 'V'), + ] + +def _seg_21() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1FF7, 'M', 'ῶι'), (0x1FF8, 'M', 'ὸ'), (0x1FF9, 'M', 'ό'), @@ -2285,18 +2286,18 @@ def _seg_21(): (0x20A0, 'V'), (0x20A8, 'M', 'rs'), (0x20A9, 'V'), - (0x20C0, 'X'), + (0x20C1, 'X'), (0x20D0, 'V'), (0x20F1, 'X'), (0x2100, '3', 'a/c'), (0x2101, '3', 'a/s'), - ] - -def _seg_22(): - return [ (0x2102, 'M', 'c'), (0x2103, 'M', '°c'), (0x2104, 'V'), + ] + +def _seg_22() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2105, '3', 'c/o'), (0x2106, '3', 'c/u'), (0x2107, 'M', 'ɛ'), @@ -2394,13 +2395,13 @@ def _seg_22(): (0x2177, 'M', 'viii'), (0x2178, 'M', 'ix'), (0x2179, 'M', 'x'), - ] - -def _seg_23(): - return [ (0x217A, 'M', 'xi'), (0x217B, 'M', 'xii'), (0x217C, 'M', 'l'), + ] + +def _seg_23() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x217D, 'M', 'c'), (0x217E, 'M', 'd'), (0x217F, 'M', 'm'), @@ -2498,13 +2499,13 @@ def _seg_23(): (0x24B7, 'M', 'b'), (0x24B8, 'M', 'c'), (0x24B9, 'M', 'd'), - ] - -def _seg_24(): - return [ (0x24BA, 'M', 'e'), (0x24BB, 'M', 'f'), (0x24BC, 'M', 'g'), + ] + +def _seg_24() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x24BD, 'M', 'h'), (0x24BE, 'M', 'i'), (0x24BF, 'M', 'j'), @@ -2602,22 +2603,21 @@ def _seg_24(): (0x2C23, 'M', 'ⱓ'), (0x2C24, 'M', 'ⱔ'), (0x2C25, 'M', 'ⱕ'), - ] - -def _seg_25(): - return [ (0x2C26, 'M', 'ⱖ'), (0x2C27, 'M', 'ⱗ'), (0x2C28, 'M', 'ⱘ'), + ] + +def _seg_25() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2C29, 'M', 'ⱙ'), (0x2C2A, 'M', 'ⱚ'), (0x2C2B, 'M', 'ⱛ'), (0x2C2C, 'M', 'ⱜ'), (0x2C2D, 'M', 'ⱝ'), (0x2C2E, 'M', 'ⱞ'), - (0x2C2F, 'X'), + (0x2C2F, 'M', 'ⱟ'), (0x2C30, 'V'), - (0x2C5F, 'X'), (0x2C60, 'M', 'ⱡ'), (0x2C61, 'V'), (0x2C62, 'M', 'ɫ'), @@ -2706,14 +2706,14 @@ def _seg_25(): (0x2CBC, 'M', 'ⲽ'), (0x2CBD, 'V'), (0x2CBE, 'M', 'ⲿ'), - ] - -def _seg_26(): - return [ (0x2CBF, 'V'), (0x2CC0, 'M', 'ⳁ'), (0x2CC1, 'V'), (0x2CC2, 'M', 'ⳃ'), + ] + +def _seg_26() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2CC3, 'V'), (0x2CC4, 'M', 'ⳅ'), (0x2CC5, 'V'), @@ -2784,7 +2784,7 @@ def _seg_26(): (0x2DD8, 'V'), (0x2DDF, 'X'), (0x2DE0, 'V'), - (0x2E53, 'X'), + (0x2E5E, 'X'), (0x2E80, 'V'), (0x2E9A, 'X'), (0x2E9B, 'V'), @@ -2810,14 +2810,14 @@ def _seg_26(): (0x2F0F, 'M', '几'), (0x2F10, 'M', '凵'), (0x2F11, 'M', '刀'), - ] - -def _seg_27(): - return [ (0x2F12, 'M', '力'), (0x2F13, 'M', '勹'), (0x2F14, 'M', '匕'), (0x2F15, 'M', '匚'), + ] + +def _seg_27() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2F16, 'M', '匸'), (0x2F17, 'M', '十'), (0x2F18, 'M', '卜'), @@ -2914,14 +2914,14 @@ def _seg_27(): (0x2F73, 'M', '穴'), (0x2F74, 'M', '立'), (0x2F75, 'M', '竹'), - ] - -def _seg_28(): - return [ (0x2F76, 'M', '米'), (0x2F77, 'M', '糸'), (0x2F78, 'M', '缶'), (0x2F79, 'M', '网'), + ] + +def _seg_28() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2F7A, 'M', '羊'), (0x2F7B, 'M', '羽'), (0x2F7C, 'M', '老'), @@ -3018,14 +3018,14 @@ def _seg_28(): (0x3000, '3', ' '), (0x3001, 'V'), (0x3002, 'M', '.'), - ] - -def _seg_29(): - return [ (0x3003, 'V'), (0x3036, 'M', '〒'), (0x3037, 'V'), (0x3038, 'M', '十'), + ] + +def _seg_29() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x3039, 'M', '卄'), (0x303A, 'M', '卅'), (0x303B, 'V'), @@ -3122,14 +3122,14 @@ def _seg_29(): (0x317E, 'M', 'ᄶ'), (0x317F, 'M', 'ᅀ'), (0x3180, 'M', 'ᅇ'), - ] - -def _seg_30(): - return [ (0x3181, 'M', 'ᅌ'), (0x3182, 'M', 'ᇱ'), (0x3183, 'M', 'ᇲ'), (0x3184, 'M', 'ᅗ'), + ] + +def _seg_30() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x3185, 'M', 'ᅘ'), (0x3186, 'M', 'ᅙ'), (0x3187, 'M', 'ᆄ'), @@ -3226,14 +3226,14 @@ def _seg_30(): (0x3240, '3', '(祭)'), (0x3241, '3', '(休)'), (0x3242, '3', '(自)'), - ] - -def _seg_31(): - return [ (0x3243, '3', '(至)'), (0x3244, 'M', '問'), (0x3245, 'M', '幼'), (0x3246, 'M', '文'), + ] + +def _seg_31() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x3247, 'M', '箏'), (0x3248, 'V'), (0x3250, 'M', 'pte'), @@ -3330,14 +3330,14 @@ def _seg_31(): (0x32AB, 'M', '学'), (0x32AC, 'M', '監'), (0x32AD, 'M', '企'), - ] - -def _seg_32(): - return [ (0x32AE, 'M', '資'), (0x32AF, 'M', '協'), (0x32B0, 'M', '夜'), (0x32B1, 'M', '36'), + ] + +def _seg_32() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x32B2, 'M', '37'), (0x32B3, 'M', '38'), (0x32B4, 'M', '39'), @@ -3434,14 +3434,14 @@ def _seg_32(): (0x330F, 'M', 'ガンマ'), (0x3310, 'M', 'ギガ'), (0x3311, 'M', 'ギニー'), - ] - -def _seg_33(): - return [ (0x3312, 'M', 'キュリー'), (0x3313, 'M', 'ギルダー'), (0x3314, 'M', 'キロ'), (0x3315, 'M', 'キログラム'), + ] + +def _seg_33() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x3316, 'M', 'キロメートル'), (0x3317, 'M', 'キロワット'), (0x3318, 'M', 'グラム'), @@ -3538,14 +3538,14 @@ def _seg_33(): (0x3373, 'M', 'au'), (0x3374, 'M', 'bar'), (0x3375, 'M', 'ov'), - ] - -def _seg_34(): - return [ (0x3376, 'M', 'pc'), (0x3377, 'M', 'dm'), (0x3378, 'M', 'dm2'), (0x3379, 'M', 'dm3'), + ] + +def _seg_34() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x337A, 'M', 'iu'), (0x337B, 'M', '平成'), (0x337C, 'M', '昭和'), @@ -3642,14 +3642,14 @@ def _seg_34(): (0x33D7, 'M', 'ph'), (0x33D8, 'X'), (0x33D9, 'M', 'ppm'), - ] - -def _seg_35(): - return [ (0x33DA, 'M', 'pr'), (0x33DB, 'M', 'sr'), (0x33DC, 'M', 'sv'), (0x33DD, 'M', 'wb'), + ] + +def _seg_35() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x33DE, 'M', 'v∕m'), (0x33DF, 'M', 'a∕m'), (0x33E0, 'M', '1日'), @@ -3685,8 +3685,6 @@ def _seg_35(): (0x33FE, 'M', '31日'), (0x33FF, 'M', 'gal'), (0x3400, 'V'), - (0x9FFD, 'X'), - (0xA000, 'V'), (0xA48D, 'X'), (0xA490, 'V'), (0xA4C7, 'X'), @@ -3746,16 +3744,16 @@ def _seg_35(): (0xA685, 'V'), (0xA686, 'M', 'ꚇ'), (0xA687, 'V'), - ] - -def _seg_36(): - return [ (0xA688, 'M', 'ꚉ'), (0xA689, 'V'), (0xA68A, 'M', 'ꚋ'), (0xA68B, 'V'), (0xA68C, 'M', 'ꚍ'), (0xA68D, 'V'), + ] + +def _seg_36() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xA68E, 'M', 'ꚏ'), (0xA68F, 'V'), (0xA690, 'M', 'ꚑ'), @@ -3850,16 +3848,16 @@ def _seg_36(): (0xA76C, 'M', 'ꝭ'), (0xA76D, 'V'), (0xA76E, 'M', 'ꝯ'), - ] - -def _seg_37(): - return [ (0xA76F, 'V'), (0xA770, 'M', 'ꝯ'), (0xA771, 'V'), (0xA779, 'M', 'ꝺ'), (0xA77A, 'V'), (0xA77B, 'M', 'ꝼ'), + ] + +def _seg_37() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xA77C, 'V'), (0xA77D, 'M', 'ᵹ'), (0xA77E, 'M', 'ꝿ'), @@ -3922,7 +3920,8 @@ def _seg_37(): (0xA7BD, 'V'), (0xA7BE, 'M', 'ꞿ'), (0xA7BF, 'V'), - (0xA7C0, 'X'), + (0xA7C0, 'M', 'ꟁ'), + (0xA7C1, 'V'), (0xA7C2, 'M', 'ꟃ'), (0xA7C3, 'V'), (0xA7C4, 'M', 'ꞔ'), @@ -3933,6 +3932,20 @@ def _seg_37(): (0xA7C9, 'M', 'ꟊ'), (0xA7CA, 'V'), (0xA7CB, 'X'), + (0xA7D0, 'M', 'ꟑ'), + (0xA7D1, 'V'), + (0xA7D2, 'X'), + (0xA7D3, 'V'), + (0xA7D4, 'X'), + (0xA7D5, 'V'), + (0xA7D6, 'M', 'ꟗ'), + (0xA7D7, 'V'), + (0xA7D8, 'M', 'ꟙ'), + (0xA7D9, 'V'), + (0xA7DA, 'X'), + (0xA7F2, 'M', 'c'), + (0xA7F3, 'M', 'f'), + (0xA7F4, 'M', 'q'), (0xA7F5, 'M', 'ꟶ'), (0xA7F6, 'V'), (0xA7F8, 'M', 'ħ'), @@ -3945,6 +3958,10 @@ def _seg_37(): (0xA878, 'X'), (0xA880, 'V'), (0xA8C6, 'X'), + ] + +def _seg_38() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xA8CE, 'V'), (0xA8DA, 'X'), (0xA8E0, 'V'), @@ -3954,10 +3971,6 @@ def _seg_37(): (0xA980, 'V'), (0xA9CE, 'X'), (0xA9CF, 'V'), - ] - -def _seg_38(): - return [ (0xA9DA, 'X'), (0xA9DE, 'V'), (0xA9FF, 'X'), @@ -4049,6 +4062,10 @@ def _seg_38(): (0xABA8, 'M', 'Ꮨ'), (0xABA9, 'M', 'Ꮩ'), (0xABAA, 'M', 'Ꮪ'), + ] + +def _seg_39() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xABAB, 'M', 'Ꮫ'), (0xABAC, 'M', 'Ꮬ'), (0xABAD, 'M', 'Ꮭ'), @@ -4058,10 +4075,6 @@ def _seg_38(): (0xABB1, 'M', 'Ꮱ'), (0xABB2, 'M', 'Ꮲ'), (0xABB3, 'M', 'Ꮳ'), - ] - -def _seg_39(): - return [ (0xABB4, 'M', 'Ꮴ'), (0xABB5, 'M', 'Ꮵ'), (0xABB6, 'M', 'Ꮶ'), @@ -4153,6 +4166,10 @@ def _seg_39(): (0xF943, 'M', '弄'), (0xF944, 'M', '籠'), (0xF945, 'M', '聾'), + ] + +def _seg_40() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xF946, 'M', '牢'), (0xF947, 'M', '磊'), (0xF948, 'M', '賂'), @@ -4162,10 +4179,6 @@ def _seg_39(): (0xF94C, 'M', '樓'), (0xF94D, 'M', '淚'), (0xF94E, 'M', '漏'), - ] - -def _seg_40(): - return [ (0xF94F, 'M', '累'), (0xF950, 'M', '縷'), (0xF951, 'M', '陋'), @@ -4257,6 +4270,10 @@ def _seg_40(): (0xF9A7, 'M', '獵'), (0xF9A8, 'M', '令'), (0xF9A9, 'M', '囹'), + ] + +def _seg_41() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xF9AA, 'M', '寧'), (0xF9AB, 'M', '嶺'), (0xF9AC, 'M', '怜'), @@ -4266,10 +4283,6 @@ def _seg_40(): (0xF9B0, 'M', '聆'), (0xF9B1, 'M', '鈴'), (0xF9B2, 'M', '零'), - ] - -def _seg_41(): - return [ (0xF9B3, 'M', '靈'), (0xF9B4, 'M', '領'), (0xF9B5, 'M', '例'), @@ -4361,6 +4374,10 @@ def _seg_41(): (0xFA0B, 'M', '廓'), (0xFA0C, 'M', '兀'), (0xFA0D, 'M', '嗀'), + ] + +def _seg_42() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFA0E, 'V'), (0xFA10, 'M', '塚'), (0xFA11, 'V'), @@ -4370,10 +4387,6 @@ def _seg_41(): (0xFA16, 'M', '猪'), (0xFA17, 'M', '益'), (0xFA18, 'M', '礼'), - ] - -def _seg_42(): - return [ (0xFA19, 'M', '神'), (0xFA1A, 'M', '祥'), (0xFA1B, 'M', '福'), @@ -4465,6 +4478,10 @@ def _seg_42(): (0xFA76, 'M', '勇'), (0xFA77, 'M', '勺'), (0xFA78, 'M', '喝'), + ] + +def _seg_43() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFA79, 'M', '啕'), (0xFA7A, 'M', '喙'), (0xFA7B, 'M', '嗢'), @@ -4474,10 +4491,6 @@ def _seg_42(): (0xFA7F, 'M', '奔'), (0xFA80, 'M', '婢'), (0xFA81, 'M', '嬨'), - ] - -def _seg_43(): - return [ (0xFA82, 'M', '廒'), (0xFA83, 'M', '廙'), (0xFA84, 'M', '彩'), @@ -4569,6 +4582,10 @@ def _seg_43(): (0xFADA, 'X'), (0xFB00, 'M', 'ff'), (0xFB01, 'M', 'fi'), + ] + +def _seg_44() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFB02, 'M', 'fl'), (0xFB03, 'M', 'ffi'), (0xFB04, 'M', 'ffl'), @@ -4578,10 +4595,6 @@ def _seg_43(): (0xFB14, 'M', 'մե'), (0xFB15, 'M', 'մի'), (0xFB16, 'M', 'վն'), - ] - -def _seg_44(): - return [ (0xFB17, 'M', 'մխ'), (0xFB18, 'X'), (0xFB1D, 'M', 'יִ'), @@ -4666,13 +4679,17 @@ def _seg_44(): (0xFBAE, 'M', 'ے'), (0xFBB0, 'M', 'ۓ'), (0xFBB2, 'V'), - (0xFBC2, 'X'), + (0xFBC3, 'X'), (0xFBD3, 'M', 'ڭ'), (0xFBD7, 'M', 'ۇ'), (0xFBD9, 'M', 'ۆ'), (0xFBDB, 'M', 'ۈ'), (0xFBDD, 'M', 'ۇٴ'), (0xFBDE, 'M', 'ۋ'), + ] + +def _seg_45() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFBE0, 'M', 'ۅ'), (0xFBE2, 'M', 'ۉ'), (0xFBE4, 'M', 'ې'), @@ -4682,10 +4699,6 @@ def _seg_44(): (0xFBEE, 'M', 'ئو'), (0xFBF0, 'M', 'ئۇ'), (0xFBF2, 'M', 'ئۆ'), - ] - -def _seg_45(): - return [ (0xFBF4, 'M', 'ئۈ'), (0xFBF6, 'M', 'ئې'), (0xFBF9, 'M', 'ئى'), @@ -4777,6 +4790,10 @@ def _seg_45(): (0xFC54, 'M', 'هي'), (0xFC55, 'M', 'يج'), (0xFC56, 'M', 'يح'), + ] + +def _seg_46() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFC57, 'M', 'يخ'), (0xFC58, 'M', 'يم'), (0xFC59, 'M', 'يى'), @@ -4786,10 +4803,6 @@ def _seg_45(): (0xFC5D, 'M', 'ىٰ'), (0xFC5E, '3', ' ٌّ'), (0xFC5F, '3', ' ٍّ'), - ] - -def _seg_46(): - return [ (0xFC60, '3', ' َّ'), (0xFC61, '3', ' ُّ'), (0xFC62, '3', ' ِّ'), @@ -4881,6 +4894,10 @@ def _seg_46(): (0xFCB8, 'M', 'طح'), (0xFCB9, 'M', 'ظم'), (0xFCBA, 'M', 'عج'), + ] + +def _seg_47() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFCBB, 'M', 'عم'), (0xFCBC, 'M', 'غج'), (0xFCBD, 'M', 'غم'), @@ -4890,10 +4907,6 @@ def _seg_46(): (0xFCC1, 'M', 'فم'), (0xFCC2, 'M', 'قح'), (0xFCC3, 'M', 'قم'), - ] - -def _seg_47(): - return [ (0xFCC4, 'M', 'كج'), (0xFCC5, 'M', 'كح'), (0xFCC6, 'M', 'كخ'), @@ -4985,6 +4998,10 @@ def _seg_47(): (0xFD1C, 'M', 'حي'), (0xFD1D, 'M', 'جى'), (0xFD1E, 'M', 'جي'), + ] + +def _seg_48() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFD1F, 'M', 'خى'), (0xFD20, 'M', 'خي'), (0xFD21, 'M', 'صى'), @@ -4994,10 +5011,6 @@ def _seg_47(): (0xFD25, 'M', 'شج'), (0xFD26, 'M', 'شح'), (0xFD27, 'M', 'شخ'), - ] - -def _seg_48(): - return [ (0xFD28, 'M', 'شم'), (0xFD29, 'M', 'شر'), (0xFD2A, 'M', 'سر'), @@ -5020,7 +5033,6 @@ def _seg_48(): (0xFD3B, 'M', 'ظم'), (0xFD3C, 'M', 'اً'), (0xFD3E, 'V'), - (0xFD40, 'X'), (0xFD50, 'M', 'تجم'), (0xFD51, 'M', 'تحج'), (0xFD53, 'M', 'تحم'), @@ -5090,6 +5102,10 @@ def _seg_48(): (0xFDA4, 'M', 'تمى'), (0xFDA5, 'M', 'جمي'), (0xFDA6, 'M', 'جحى'), + ] + +def _seg_49() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFDA7, 'M', 'جمى'), (0xFDA8, 'M', 'سخى'), (0xFDA9, 'M', 'صحي'), @@ -5098,10 +5114,6 @@ def _seg_48(): (0xFDAC, 'M', 'لجي'), (0xFDAD, 'M', 'لمي'), (0xFDAE, 'M', 'يحي'), - ] - -def _seg_49(): - return [ (0xFDAF, 'M', 'يجي'), (0xFDB0, 'M', 'يمي'), (0xFDB1, 'M', 'ممي'), @@ -5128,6 +5140,8 @@ def _seg_49(): (0xFDC6, 'M', 'سخي'), (0xFDC7, 'M', 'نجي'), (0xFDC8, 'X'), + (0xFDCF, 'V'), + (0xFDD0, 'X'), (0xFDF0, 'M', 'صلے'), (0xFDF1, 'M', 'قلے'), (0xFDF2, 'M', 'الله'), @@ -5142,7 +5156,6 @@ def _seg_49(): (0xFDFB, '3', 'جل جلاله'), (0xFDFC, 'M', 'ریال'), (0xFDFD, 'V'), - (0xFDFE, 'X'), (0xFE00, 'I'), (0xFE10, '3', ','), (0xFE11, 'M', '、'), @@ -5193,6 +5206,10 @@ def _seg_49(): (0xFE5B, '3', '{'), (0xFE5C, '3', '}'), (0xFE5D, 'M', '〔'), + ] + +def _seg_50() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFE5E, 'M', '〕'), (0xFE5F, '3', '#'), (0xFE60, '3', '&'), @@ -5202,10 +5219,6 @@ def _seg_49(): (0xFE64, '3', '<'), (0xFE65, '3', '>'), (0xFE66, '3', '='), - ] - -def _seg_50(): - return [ (0xFE67, 'X'), (0xFE68, '3', '\\'), (0xFE69, '3', '$'), @@ -5297,6 +5310,10 @@ def _seg_50(): (0xFF18, 'M', '8'), (0xFF19, 'M', '9'), (0xFF1A, '3', ':'), + ] + +def _seg_51() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFF1B, '3', ';'), (0xFF1C, '3', '<'), (0xFF1D, '3', '='), @@ -5306,10 +5323,6 @@ def _seg_50(): (0xFF21, 'M', 'a'), (0xFF22, 'M', 'b'), (0xFF23, 'M', 'c'), - ] - -def _seg_51(): - return [ (0xFF24, 'M', 'd'), (0xFF25, 'M', 'e'), (0xFF26, 'M', 'f'), @@ -5401,6 +5414,10 @@ def _seg_51(): (0xFF7C, 'M', 'シ'), (0xFF7D, 'M', 'ス'), (0xFF7E, 'M', 'セ'), + ] + +def _seg_52() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFF7F, 'M', 'ソ'), (0xFF80, 'M', 'タ'), (0xFF81, 'M', 'チ'), @@ -5410,10 +5427,6 @@ def _seg_51(): (0xFF85, 'M', 'ナ'), (0xFF86, 'M', 'ニ'), (0xFF87, 'M', 'ヌ'), - ] - -def _seg_52(): - return [ (0xFF88, 'M', 'ネ'), (0xFF89, 'M', 'ノ'), (0xFF8A, 'M', 'ハ'), @@ -5505,6 +5518,10 @@ def _seg_52(): (0xFFE7, 'X'), (0xFFE8, 'M', '│'), (0xFFE9, 'M', '←'), + ] + +def _seg_53() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0xFFEA, 'M', '↑'), (0xFFEB, 'M', '→'), (0xFFEC, 'M', '↓'), @@ -5514,10 +5531,6 @@ def _seg_52(): (0x10000, 'V'), (0x1000C, 'X'), (0x1000D, 'V'), - ] - -def _seg_53(): - return [ (0x10027, 'X'), (0x10028, 'V'), (0x1003B, 'X'), @@ -5609,6 +5622,10 @@ def _seg_53(): (0x104B3, 'M', '𐓛'), (0x104B4, 'M', '𐓜'), (0x104B5, 'M', '𐓝'), + ] + +def _seg_54() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x104B6, 'M', '𐓞'), (0x104B7, 'M', '𐓟'), (0x104B8, 'M', '𐓠'), @@ -5618,10 +5635,6 @@ def _seg_53(): (0x104BC, 'M', '𐓤'), (0x104BD, 'M', '𐓥'), (0x104BE, 'M', '𐓦'), - ] - -def _seg_54(): - return [ (0x104BF, 'M', '𐓧'), (0x104C0, 'M', '𐓨'), (0x104C1, 'M', '𐓩'), @@ -5651,13 +5664,123 @@ def _seg_54(): (0x10530, 'V'), (0x10564, 'X'), (0x1056F, 'V'), - (0x10570, 'X'), + (0x10570, 'M', '𐖗'), + (0x10571, 'M', '𐖘'), + (0x10572, 'M', '𐖙'), + (0x10573, 'M', '𐖚'), + (0x10574, 'M', '𐖛'), + (0x10575, 'M', '𐖜'), + (0x10576, 'M', '𐖝'), + (0x10577, 'M', '𐖞'), + (0x10578, 'M', '𐖟'), + (0x10579, 'M', '𐖠'), + (0x1057A, 'M', '𐖡'), + (0x1057B, 'X'), + (0x1057C, 'M', '𐖣'), + (0x1057D, 'M', '𐖤'), + (0x1057E, 'M', '𐖥'), + (0x1057F, 'M', '𐖦'), + (0x10580, 'M', '𐖧'), + (0x10581, 'M', '𐖨'), + (0x10582, 'M', '𐖩'), + (0x10583, 'M', '𐖪'), + (0x10584, 'M', '𐖫'), + (0x10585, 'M', '𐖬'), + (0x10586, 'M', '𐖭'), + (0x10587, 'M', '𐖮'), + (0x10588, 'M', '𐖯'), + (0x10589, 'M', '𐖰'), + (0x1058A, 'M', '𐖱'), + (0x1058B, 'X'), + (0x1058C, 'M', '𐖳'), + (0x1058D, 'M', '𐖴'), + (0x1058E, 'M', '𐖵'), + (0x1058F, 'M', '𐖶'), + (0x10590, 'M', '𐖷'), + (0x10591, 'M', '𐖸'), + (0x10592, 'M', '𐖹'), + (0x10593, 'X'), + (0x10594, 'M', '𐖻'), + (0x10595, 'M', '𐖼'), + (0x10596, 'X'), + (0x10597, 'V'), + (0x105A2, 'X'), + (0x105A3, 'V'), + (0x105B2, 'X'), + (0x105B3, 'V'), + (0x105BA, 'X'), + (0x105BB, 'V'), + (0x105BD, 'X'), (0x10600, 'V'), (0x10737, 'X'), (0x10740, 'V'), (0x10756, 'X'), (0x10760, 'V'), (0x10768, 'X'), + (0x10780, 'V'), + (0x10781, 'M', 'ː'), + (0x10782, 'M', 'ˑ'), + (0x10783, 'M', 'æ'), + (0x10784, 'M', 'ʙ'), + (0x10785, 'M', 'ɓ'), + (0x10786, 'X'), + (0x10787, 'M', 'ʣ'), + (0x10788, 'M', 'ꭦ'), + ] + +def _seg_55() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ + (0x10789, 'M', 'ʥ'), + (0x1078A, 'M', 'ʤ'), + (0x1078B, 'M', 'ɖ'), + (0x1078C, 'M', 'ɗ'), + (0x1078D, 'M', 'ᶑ'), + (0x1078E, 'M', 'ɘ'), + (0x1078F, 'M', 'ɞ'), + (0x10790, 'M', 'ʩ'), + (0x10791, 'M', 'ɤ'), + (0x10792, 'M', 'ɢ'), + (0x10793, 'M', 'ɠ'), + (0x10794, 'M', 'ʛ'), + (0x10795, 'M', 'ħ'), + (0x10796, 'M', 'ʜ'), + (0x10797, 'M', 'ɧ'), + (0x10798, 'M', 'ʄ'), + (0x10799, 'M', 'ʪ'), + (0x1079A, 'M', 'ʫ'), + (0x1079B, 'M', 'ɬ'), + (0x1079C, 'M', '𝼄'), + (0x1079D, 'M', 'ꞎ'), + (0x1079E, 'M', 'ɮ'), + (0x1079F, 'M', '𝼅'), + (0x107A0, 'M', 'ʎ'), + (0x107A1, 'M', '𝼆'), + (0x107A2, 'M', 'ø'), + (0x107A3, 'M', 'ɶ'), + (0x107A4, 'M', 'ɷ'), + (0x107A5, 'M', 'q'), + (0x107A6, 'M', 'ɺ'), + (0x107A7, 'M', '𝼈'), + (0x107A8, 'M', 'ɽ'), + (0x107A9, 'M', 'ɾ'), + (0x107AA, 'M', 'ʀ'), + (0x107AB, 'M', 'ʨ'), + (0x107AC, 'M', 'ʦ'), + (0x107AD, 'M', 'ꭧ'), + (0x107AE, 'M', 'ʧ'), + (0x107AF, 'M', 'ʈ'), + (0x107B0, 'M', 'ⱱ'), + (0x107B1, 'X'), + (0x107B2, 'M', 'ʏ'), + (0x107B3, 'M', 'ʡ'), + (0x107B4, 'M', 'ʢ'), + (0x107B5, 'M', 'ʘ'), + (0x107B6, 'M', 'ǀ'), + (0x107B7, 'M', 'ǁ'), + (0x107B8, 'M', 'ǂ'), + (0x107B9, 'M', '𝼊'), + (0x107BA, 'M', '𝼞'), + (0x107BB, 'X'), (0x10800, 'V'), (0x10806, 'X'), (0x10808, 'V'), @@ -5707,6 +5830,10 @@ def _seg_54(): (0x10A60, 'V'), (0x10AA0, 'X'), (0x10AC0, 'V'), + ] + +def _seg_56() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x10AE7, 'X'), (0x10AEB, 'V'), (0x10AF7, 'X'), @@ -5722,10 +5849,6 @@ def _seg_54(): (0x10B9D, 'X'), (0x10BA9, 'V'), (0x10BB0, 'X'), - ] - -def _seg_55(): - return [ (0x10C00, 'V'), (0x10C49, 'X'), (0x10C80, 'M', '𐳀'), @@ -5794,10 +5917,12 @@ def _seg_55(): (0x10EAE, 'X'), (0x10EB0, 'V'), (0x10EB2, 'X'), - (0x10F00, 'V'), + (0x10EFD, 'V'), (0x10F28, 'X'), (0x10F30, 'V'), (0x10F5A, 'X'), + (0x10F70, 'V'), + (0x10F8A, 'X'), (0x10FB0, 'V'), (0x10FCC, 'X'), (0x10FE0, 'V'), @@ -5805,11 +5930,15 @@ def _seg_55(): (0x11000, 'V'), (0x1104E, 'X'), (0x11052, 'V'), - (0x11070, 'X'), + (0x11076, 'X'), (0x1107F, 'V'), (0x110BD, 'X'), (0x110BE, 'V'), - (0x110C2, 'X'), + ] + +def _seg_57() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ + (0x110C3, 'X'), (0x110D0, 'V'), (0x110E9, 'X'), (0x110F0, 'V'), @@ -5826,12 +5955,8 @@ def _seg_55(): (0x111F5, 'X'), (0x11200, 'V'), (0x11212, 'X'), - ] - -def _seg_56(): - return [ (0x11213, 'V'), - (0x1123F, 'X'), + (0x11242, 'X'), (0x11280, 'V'), (0x11287, 'X'), (0x11288, 'V'), @@ -5895,7 +6020,7 @@ def _seg_56(): (0x11660, 'V'), (0x1166D, 'X'), (0x11680, 'V'), - (0x116B9, 'X'), + (0x116BA, 'X'), (0x116C0, 'V'), (0x116CA, 'X'), (0x11700, 'V'), @@ -5903,7 +6028,7 @@ def _seg_56(): (0x1171D, 'V'), (0x1172C, 'X'), (0x11730, 'V'), - (0x11740, 'X'), + (0x11747, 'X'), (0x11800, 'V'), (0x1183C, 'X'), (0x118A0, 'M', '𑣀'), @@ -5913,6 +6038,10 @@ def _seg_56(): (0x118A4, 'M', '𑣄'), (0x118A5, 'M', '𑣅'), (0x118A6, 'M', '𑣆'), + ] + +def _seg_58() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x118A7, 'M', '𑣇'), (0x118A8, 'M', '𑣈'), (0x118A9, 'M', '𑣉'), @@ -5930,10 +6059,6 @@ def _seg_56(): (0x118B5, 'M', '𑣕'), (0x118B6, 'M', '𑣖'), (0x118B7, 'M', '𑣗'), - ] - -def _seg_57(): - return [ (0x118B8, 'M', '𑣘'), (0x118B9, 'M', '𑣙'), (0x118BA, 'M', '𑣚'), @@ -5970,8 +6095,10 @@ def _seg_57(): (0x11A48, 'X'), (0x11A50, 'V'), (0x11AA3, 'X'), - (0x11AC0, 'V'), + (0x11AB0, 'V'), (0x11AF9, 'X'), + (0x11B00, 'V'), + (0x11B0A, 'X'), (0x11C00, 'V'), (0x11C09, 'X'), (0x11C0A, 'V'), @@ -6014,6 +6141,16 @@ def _seg_57(): (0x11DAA, 'X'), (0x11EE0, 'V'), (0x11EF9, 'X'), + (0x11F00, 'V'), + ] + +def _seg_59() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ + (0x11F11, 'X'), + (0x11F12, 'V'), + (0x11F3B, 'X'), + (0x11F3E, 'V'), + (0x11F5A, 'X'), (0x11FB0, 'V'), (0x11FB1, 'X'), (0x11FC0, 'V'), @@ -6026,22 +6163,24 @@ def _seg_57(): (0x12475, 'X'), (0x12480, 'V'), (0x12544, 'X'), + (0x12F90, 'V'), + (0x12FF3, 'X'), (0x13000, 'V'), - (0x1342F, 'X'), + (0x13430, 'X'), + (0x13440, 'V'), + (0x13456, 'X'), (0x14400, 'V'), (0x14647, 'X'), (0x16800, 'V'), (0x16A39, 'X'), (0x16A40, 'V'), (0x16A5F, 'X'), - ] - -def _seg_58(): - return [ (0x16A60, 'V'), (0x16A6A, 'X'), (0x16A6E, 'V'), - (0x16A70, 'X'), + (0x16ABF, 'X'), + (0x16AC0, 'V'), + (0x16ACA, 'X'), (0x16AD0, 'V'), (0x16AEE, 'X'), (0x16AF0, 'V'), @@ -6106,10 +6245,24 @@ def _seg_58(): (0x18CD6, 'X'), (0x18D00, 'V'), (0x18D09, 'X'), + (0x1AFF0, 'V'), + ] + +def _seg_60() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ + (0x1AFF4, 'X'), + (0x1AFF5, 'V'), + (0x1AFFC, 'X'), + (0x1AFFD, 'V'), + (0x1AFFF, 'X'), (0x1B000, 'V'), - (0x1B11F, 'X'), + (0x1B123, 'X'), + (0x1B132, 'V'), + (0x1B133, 'X'), (0x1B150, 'V'), (0x1B153, 'X'), + (0x1B155, 'V'), + (0x1B156, 'X'), (0x1B164, 'V'), (0x1B168, 'X'), (0x1B170, 'V'), @@ -6125,6 +6278,12 @@ def _seg_58(): (0x1BC9C, 'V'), (0x1BCA0, 'I'), (0x1BCA4, 'X'), + (0x1CF00, 'V'), + (0x1CF2E, 'X'), + (0x1CF30, 'V'), + (0x1CF47, 'X'), + (0x1CF50, 'V'), + (0x1CFC4, 'X'), (0x1D000, 'V'), (0x1D0F6, 'X'), (0x1D100, 'V'), @@ -6138,10 +6297,6 @@ def _seg_58(): (0x1D163, 'M', '𝅘𝅥𝅱'), (0x1D164, 'M', '𝅘𝅥𝅲'), (0x1D165, 'V'), - ] - -def _seg_59(): - return [ (0x1D173, 'X'), (0x1D17B, 'V'), (0x1D1BB, 'M', '𝆹𝅥'), @@ -6151,9 +6306,11 @@ def _seg_59(): (0x1D1BF, 'M', '𝆹𝅥𝅯'), (0x1D1C0, 'M', '𝆺𝅥𝅯'), (0x1D1C1, 'V'), - (0x1D1E9, 'X'), + (0x1D1EB, 'X'), (0x1D200, 'V'), (0x1D246, 'X'), + (0x1D2C0, 'V'), + (0x1D2D4, 'X'), (0x1D2E0, 'V'), (0x1D2F4, 'X'), (0x1D300, 'V'), @@ -6193,6 +6350,10 @@ def _seg_59(): (0x1D41E, 'M', 'e'), (0x1D41F, 'M', 'f'), (0x1D420, 'M', 'g'), + ] + +def _seg_61() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D421, 'M', 'h'), (0x1D422, 'M', 'i'), (0x1D423, 'M', 'j'), @@ -6242,10 +6403,6 @@ def _seg_59(): (0x1D44F, 'M', 'b'), (0x1D450, 'M', 'c'), (0x1D451, 'M', 'd'), - ] - -def _seg_60(): - return [ (0x1D452, 'M', 'e'), (0x1D453, 'M', 'f'), (0x1D454, 'M', 'g'), @@ -6297,6 +6454,10 @@ def _seg_60(): (0x1D482, 'M', 'a'), (0x1D483, 'M', 'b'), (0x1D484, 'M', 'c'), + ] + +def _seg_62() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D485, 'M', 'd'), (0x1D486, 'M', 'e'), (0x1D487, 'M', 'f'), @@ -6346,10 +6507,6 @@ def _seg_60(): (0x1D4B6, 'M', 'a'), (0x1D4B7, 'M', 'b'), (0x1D4B8, 'M', 'c'), - ] - -def _seg_61(): - return [ (0x1D4B9, 'M', 'd'), (0x1D4BA, 'X'), (0x1D4BB, 'M', 'f'), @@ -6401,6 +6558,10 @@ def _seg_61(): (0x1D4E9, 'M', 'z'), (0x1D4EA, 'M', 'a'), (0x1D4EB, 'M', 'b'), + ] + +def _seg_63() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D4EC, 'M', 'c'), (0x1D4ED, 'M', 'd'), (0x1D4EE, 'M', 'e'), @@ -6450,10 +6611,6 @@ def _seg_61(): (0x1D51B, 'M', 'x'), (0x1D51C, 'M', 'y'), (0x1D51D, 'X'), - ] - -def _seg_62(): - return [ (0x1D51E, 'M', 'a'), (0x1D51F, 'M', 'b'), (0x1D520, 'M', 'c'), @@ -6505,6 +6662,10 @@ def _seg_62(): (0x1D550, 'M', 'y'), (0x1D551, 'X'), (0x1D552, 'M', 'a'), + ] + +def _seg_64() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D553, 'M', 'b'), (0x1D554, 'M', 'c'), (0x1D555, 'M', 'd'), @@ -6554,10 +6715,6 @@ def _seg_62(): (0x1D581, 'M', 'v'), (0x1D582, 'M', 'w'), (0x1D583, 'M', 'x'), - ] - -def _seg_63(): - return [ (0x1D584, 'M', 'y'), (0x1D585, 'M', 'z'), (0x1D586, 'M', 'a'), @@ -6609,6 +6766,10 @@ def _seg_63(): (0x1D5B4, 'M', 'u'), (0x1D5B5, 'M', 'v'), (0x1D5B6, 'M', 'w'), + ] + +def _seg_65() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D5B7, 'M', 'x'), (0x1D5B8, 'M', 'y'), (0x1D5B9, 'M', 'z'), @@ -6658,10 +6819,6 @@ def _seg_63(): (0x1D5E5, 'M', 'r'), (0x1D5E6, 'M', 's'), (0x1D5E7, 'M', 't'), - ] - -def _seg_64(): - return [ (0x1D5E8, 'M', 'u'), (0x1D5E9, 'M', 'v'), (0x1D5EA, 'M', 'w'), @@ -6713,6 +6870,10 @@ def _seg_64(): (0x1D618, 'M', 'q'), (0x1D619, 'M', 'r'), (0x1D61A, 'M', 's'), + ] + +def _seg_66() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D61B, 'M', 't'), (0x1D61C, 'M', 'u'), (0x1D61D, 'M', 'v'), @@ -6762,10 +6923,6 @@ def _seg_64(): (0x1D649, 'M', 'n'), (0x1D64A, 'M', 'o'), (0x1D64B, 'M', 'p'), - ] - -def _seg_65(): - return [ (0x1D64C, 'M', 'q'), (0x1D64D, 'M', 'r'), (0x1D64E, 'M', 's'), @@ -6817,6 +6974,10 @@ def _seg_65(): (0x1D67C, 'M', 'm'), (0x1D67D, 'M', 'n'), (0x1D67E, 'M', 'o'), + ] + +def _seg_67() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D67F, 'M', 'p'), (0x1D680, 'M', 'q'), (0x1D681, 'M', 'r'), @@ -6866,10 +7027,6 @@ def _seg_65(): (0x1D6AE, 'M', 'η'), (0x1D6AF, 'M', 'θ'), (0x1D6B0, 'M', 'ι'), - ] - -def _seg_66(): - return [ (0x1D6B1, 'M', 'κ'), (0x1D6B2, 'M', 'λ'), (0x1D6B3, 'M', 'μ'), @@ -6921,6 +7078,10 @@ def _seg_66(): (0x1D6E2, 'M', 'α'), (0x1D6E3, 'M', 'β'), (0x1D6E4, 'M', 'γ'), + ] + +def _seg_68() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D6E5, 'M', 'δ'), (0x1D6E6, 'M', 'ε'), (0x1D6E7, 'M', 'ζ'), @@ -6970,10 +7131,6 @@ def _seg_66(): (0x1D714, 'M', 'ω'), (0x1D715, 'M', '∂'), (0x1D716, 'M', 'ε'), - ] - -def _seg_67(): - return [ (0x1D717, 'M', 'θ'), (0x1D718, 'M', 'κ'), (0x1D719, 'M', 'φ'), @@ -7025,6 +7182,10 @@ def _seg_67(): (0x1D747, 'M', 'σ'), (0x1D749, 'M', 'τ'), (0x1D74A, 'M', 'υ'), + ] + +def _seg_69() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D74B, 'M', 'φ'), (0x1D74C, 'M', 'χ'), (0x1D74D, 'M', 'ψ'), @@ -7074,10 +7235,6 @@ def _seg_67(): (0x1D779, 'M', 'κ'), (0x1D77A, 'M', 'λ'), (0x1D77B, 'M', 'μ'), - ] - -def _seg_68(): - return [ (0x1D77C, 'M', 'ν'), (0x1D77D, 'M', 'ξ'), (0x1D77E, 'M', 'ο'), @@ -7129,6 +7286,10 @@ def _seg_68(): (0x1D7AD, 'M', 'δ'), (0x1D7AE, 'M', 'ε'), (0x1D7AF, 'M', 'ζ'), + ] + +def _seg_70() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1D7B0, 'M', 'η'), (0x1D7B1, 'M', 'θ'), (0x1D7B2, 'M', 'ι'), @@ -7178,10 +7339,6 @@ def _seg_68(): (0x1D7E1, 'M', '9'), (0x1D7E2, 'M', '0'), (0x1D7E3, 'M', '1'), - ] - -def _seg_69(): - return [ (0x1D7E4, 'M', '2'), (0x1D7E5, 'M', '3'), (0x1D7E6, 'M', '4'), @@ -7216,6 +7373,10 @@ def _seg_69(): (0x1DAA0, 'X'), (0x1DAA1, 'V'), (0x1DAB0, 'X'), + (0x1DF00, 'V'), + (0x1DF1F, 'X'), + (0x1DF25, 'V'), + (0x1DF2B, 'X'), (0x1E000, 'V'), (0x1E007, 'X'), (0x1E008, 'V'), @@ -7226,6 +7387,75 @@ def _seg_69(): (0x1E025, 'X'), (0x1E026, 'V'), (0x1E02B, 'X'), + (0x1E030, 'M', 'а'), + (0x1E031, 'M', 'б'), + (0x1E032, 'M', 'в'), + ] + +def _seg_71() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ + (0x1E033, 'M', 'г'), + (0x1E034, 'M', 'д'), + (0x1E035, 'M', 'е'), + (0x1E036, 'M', 'ж'), + (0x1E037, 'M', 'з'), + (0x1E038, 'M', 'и'), + (0x1E039, 'M', 'к'), + (0x1E03A, 'M', 'л'), + (0x1E03B, 'M', 'м'), + (0x1E03C, 'M', 'о'), + (0x1E03D, 'M', 'п'), + (0x1E03E, 'M', 'р'), + (0x1E03F, 'M', 'с'), + (0x1E040, 'M', 'т'), + (0x1E041, 'M', 'у'), + (0x1E042, 'M', 'ф'), + (0x1E043, 'M', 'х'), + (0x1E044, 'M', 'ц'), + (0x1E045, 'M', 'ч'), + (0x1E046, 'M', 'ш'), + (0x1E047, 'M', 'ы'), + (0x1E048, 'M', 'э'), + (0x1E049, 'M', 'ю'), + (0x1E04A, 'M', 'ꚉ'), + (0x1E04B, 'M', 'ә'), + (0x1E04C, 'M', 'і'), + (0x1E04D, 'M', 'ј'), + (0x1E04E, 'M', 'ө'), + (0x1E04F, 'M', 'ү'), + (0x1E050, 'M', 'ӏ'), + (0x1E051, 'M', 'а'), + (0x1E052, 'M', 'б'), + (0x1E053, 'M', 'в'), + (0x1E054, 'M', 'г'), + (0x1E055, 'M', 'д'), + (0x1E056, 'M', 'е'), + (0x1E057, 'M', 'ж'), + (0x1E058, 'M', 'з'), + (0x1E059, 'M', 'и'), + (0x1E05A, 'M', 'к'), + (0x1E05B, 'M', 'л'), + (0x1E05C, 'M', 'о'), + (0x1E05D, 'M', 'п'), + (0x1E05E, 'M', 'с'), + (0x1E05F, 'M', 'у'), + (0x1E060, 'M', 'ф'), + (0x1E061, 'M', 'х'), + (0x1E062, 'M', 'ц'), + (0x1E063, 'M', 'ч'), + (0x1E064, 'M', 'ш'), + (0x1E065, 'M', 'ъ'), + (0x1E066, 'M', 'ы'), + (0x1E067, 'M', 'ґ'), + (0x1E068, 'M', 'і'), + (0x1E069, 'M', 'ѕ'), + (0x1E06A, 'M', 'џ'), + (0x1E06B, 'M', 'ҫ'), + (0x1E06C, 'M', 'ꙑ'), + (0x1E06D, 'M', 'ұ'), + (0x1E06E, 'X'), + (0x1E08F, 'V'), + (0x1E090, 'X'), (0x1E100, 'V'), (0x1E12D, 'X'), (0x1E130, 'V'), @@ -7234,10 +7464,22 @@ def _seg_69(): (0x1E14A, 'X'), (0x1E14E, 'V'), (0x1E150, 'X'), + (0x1E290, 'V'), + (0x1E2AF, 'X'), (0x1E2C0, 'V'), (0x1E2FA, 'X'), (0x1E2FF, 'V'), (0x1E300, 'X'), + (0x1E4D0, 'V'), + (0x1E4FA, 'X'), + (0x1E7E0, 'V'), + (0x1E7E7, 'X'), + (0x1E7E8, 'V'), + (0x1E7EC, 'X'), + (0x1E7ED, 'V'), + (0x1E7EF, 'X'), + (0x1E7F0, 'V'), + (0x1E7FF, 'X'), (0x1E800, 'V'), (0x1E8C5, 'X'), (0x1E8C7, 'V'), @@ -7252,6 +7494,10 @@ def _seg_69(): (0x1E907, 'M', '𞤩'), (0x1E908, 'M', '𞤪'), (0x1E909, 'M', '𞤫'), + ] + +def _seg_72() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1E90A, 'M', '𞤬'), (0x1E90B, 'M', '𞤭'), (0x1E90C, 'M', '𞤮'), @@ -7282,10 +7528,6 @@ def _seg_69(): (0x1E95A, 'X'), (0x1E95E, 'V'), (0x1E960, 'X'), - ] - -def _seg_70(): - return [ (0x1EC71, 'V'), (0x1ECB5, 'X'), (0x1ED01, 'V'), @@ -7356,6 +7598,10 @@ def _seg_70(): (0x1EE48, 'X'), (0x1EE49, 'M', 'ي'), (0x1EE4A, 'X'), + ] + +def _seg_73() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1EE4B, 'M', 'ل'), (0x1EE4C, 'X'), (0x1EE4D, 'M', 'ن'), @@ -7386,10 +7632,6 @@ def _seg_70(): (0x1EE68, 'M', 'ط'), (0x1EE69, 'M', 'ي'), (0x1EE6A, 'M', 'ك'), - ] - -def _seg_71(): - return [ (0x1EE6B, 'X'), (0x1EE6C, 'M', 'م'), (0x1EE6D, 'M', 'ن'), @@ -7460,6 +7702,10 @@ def _seg_71(): (0x1EEB2, 'M', 'ق'), (0x1EEB3, 'M', 'ر'), (0x1EEB4, 'M', 'ش'), + ] + +def _seg_74() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1EEB5, 'M', 'ت'), (0x1EEB6, 'M', 'ث'), (0x1EEB7, 'M', 'خ'), @@ -7490,10 +7736,6 @@ def _seg_71(): (0x1F106, '3', '5,'), (0x1F107, '3', '6,'), (0x1F108, '3', '7,'), - ] - -def _seg_72(): - return [ (0x1F109, '3', '8,'), (0x1F10A, '3', '9,'), (0x1F10B, 'V'), @@ -7564,6 +7806,10 @@ def _seg_72(): (0x1F150, 'V'), (0x1F16A, 'M', 'mc'), (0x1F16B, 'M', 'md'), + ] + +def _seg_75() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1F16C, 'M', 'mr'), (0x1F16D, 'V'), (0x1F190, 'M', 'dj'), @@ -7594,10 +7840,6 @@ def _seg_72(): (0x1F221, 'M', '終'), (0x1F222, 'M', '生'), (0x1F223, 'M', '販'), - ] - -def _seg_73(): - return [ (0x1F224, 'M', '声'), (0x1F225, 'M', '吹'), (0x1F226, 'M', '演'), @@ -7640,16 +7882,18 @@ def _seg_73(): (0x1F266, 'X'), (0x1F300, 'V'), (0x1F6D8, 'X'), - (0x1F6E0, 'V'), + (0x1F6DC, 'V'), (0x1F6ED, 'X'), (0x1F6F0, 'V'), (0x1F6FD, 'X'), (0x1F700, 'V'), - (0x1F774, 'X'), - (0x1F780, 'V'), - (0x1F7D9, 'X'), + (0x1F777, 'X'), + (0x1F77B, 'V'), + (0x1F7DA, 'X'), (0x1F7E0, 'V'), (0x1F7EC, 'X'), + (0x1F7F0, 'V'), + (0x1F7F1, 'X'), (0x1F800, 'V'), (0x1F80C, 'X'), (0x1F810, 'V'), @@ -7663,27 +7907,27 @@ def _seg_73(): (0x1F8B0, 'V'), (0x1F8B2, 'X'), (0x1F900, 'V'), - (0x1F979, 'X'), - (0x1F97A, 'V'), - (0x1F9CC, 'X'), - (0x1F9CD, 'V'), (0x1FA54, 'X'), (0x1FA60, 'V'), (0x1FA6E, 'X'), + ] + +def _seg_76() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x1FA70, 'V'), - (0x1FA75, 'X'), - (0x1FA78, 'V'), - (0x1FA7B, 'X'), + (0x1FA7D, 'X'), (0x1FA80, 'V'), - (0x1FA87, 'X'), + (0x1FA89, 'X'), (0x1FA90, 'V'), - (0x1FAA9, 'X'), - (0x1FAB0, 'V'), - (0x1FAB7, 'X'), - (0x1FAC0, 'V'), - (0x1FAC3, 'X'), - (0x1FAD0, 'V'), - (0x1FAD7, 'X'), + (0x1FABE, 'X'), + (0x1FABF, 'V'), + (0x1FAC6, 'X'), + (0x1FACE, 'V'), + (0x1FADC, 'X'), + (0x1FAE0, 'V'), + (0x1FAE9, 'X'), + (0x1FAF0, 'V'), + (0x1FAF9, 'X'), (0x1FB00, 'V'), (0x1FB93, 'X'), (0x1FB94, 'V'), @@ -7698,15 +7942,11 @@ def _seg_73(): (0x1FBF7, 'M', '7'), (0x1FBF8, 'M', '8'), (0x1FBF9, 'M', '9'), - ] - -def _seg_74(): - return [ (0x1FBFA, 'X'), (0x20000, 'V'), - (0x2A6DE, 'X'), + (0x2A6E0, 'X'), (0x2A700, 'V'), - (0x2B735, 'X'), + (0x2B73A, 'X'), (0x2B740, 'V'), (0x2B81E, 'X'), (0x2B820, 'V'), @@ -7774,6 +8014,10 @@ def _seg_74(): (0x2F83C, 'M', '咞'), (0x2F83D, 'M', '吸'), (0x2F83E, 'M', '呈'), + ] + +def _seg_77() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2F83F, 'M', '周'), (0x2F840, 'M', '咢'), (0x2F841, 'M', '哶'), @@ -7802,10 +8046,6 @@ def _seg_74(): (0x2F859, 'M', '𡓤'), (0x2F85A, 'M', '売'), (0x2F85B, 'M', '壷'), - ] - -def _seg_75(): - return [ (0x2F85C, 'M', '夆'), (0x2F85D, 'M', '多'), (0x2F85E, 'M', '夢'), @@ -7878,6 +8118,10 @@ def _seg_75(): (0x2F8A4, 'M', '𢛔'), (0x2F8A5, 'M', '惇'), (0x2F8A6, 'M', '慈'), + ] + +def _seg_78() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2F8A7, 'M', '慌'), (0x2F8A8, 'M', '慎'), (0x2F8A9, 'M', '慌'), @@ -7906,10 +8150,6 @@ def _seg_75(): (0x2F8C0, 'M', '揅'), (0x2F8C1, 'M', '掩'), (0x2F8C2, 'M', '㨮'), - ] - -def _seg_76(): - return [ (0x2F8C3, 'M', '摩'), (0x2F8C4, 'M', '摾'), (0x2F8C5, 'M', '撝'), @@ -7982,6 +8222,10 @@ def _seg_76(): (0x2F908, 'M', '港'), (0x2F909, 'M', '湮'), (0x2F90A, 'M', '㴳'), + ] + +def _seg_79() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2F90B, 'M', '滋'), (0x2F90C, 'M', '滇'), (0x2F90D, 'M', '𣻑'), @@ -8010,10 +8254,6 @@ def _seg_76(): (0x2F924, 'M', '犀'), (0x2F925, 'M', '犕'), (0x2F926, 'M', '𤜵'), - ] - -def _seg_77(): - return [ (0x2F927, 'M', '𤠔'), (0x2F928, 'M', '獺'), (0x2F929, 'M', '王'), @@ -8086,6 +8326,10 @@ def _seg_77(): (0x2F96F, 'M', '縂'), (0x2F970, 'M', '繅'), (0x2F971, 'M', '䌴'), + ] + +def _seg_80() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2F972, 'M', '𦈨'), (0x2F973, 'M', '𦉇'), (0x2F974, 'M', '䍙'), @@ -8114,10 +8358,6 @@ def _seg_77(): (0x2F98B, 'M', '舁'), (0x2F98C, 'M', '舄'), (0x2F98D, 'M', '辞'), - ] - -def _seg_78(): - return [ (0x2F98E, 'M', '䑫'), (0x2F98F, 'M', '芑'), (0x2F990, 'M', '芋'), @@ -8190,6 +8430,10 @@ def _seg_78(): (0x2F9D3, 'M', '𧲨'), (0x2F9D4, 'M', '貫'), (0x2F9D5, 'M', '賁'), + ] + +def _seg_81() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]: + return [ (0x2F9D6, 'M', '贛'), (0x2F9D7, 'M', '起'), (0x2F9D8, 'M', '𧼯'), @@ -8218,10 +8462,6 @@ def _seg_78(): (0x2F9EF, 'M', '䦕'), (0x2F9F0, 'M', '閷'), (0x2F9F1, 'M', '𨵷'), - ] - -def _seg_79(): - return [ (0x2F9F2, 'M', '䧦'), (0x2F9F3, 'M', '雃'), (0x2F9F4, 'M', '嶲'), @@ -8268,6 +8508,8 @@ def _seg_79(): (0x2FA1E, 'X'), (0x30000, 'V'), (0x3134B, 'X'), + (0x31350, 'V'), + (0x323B0, 'X'), (0xE0100, 'I'), (0xE01F0, 'X'), ] @@ -8353,4 +8595,6 @@ uts46data = tuple( + _seg_77() + _seg_78() + _seg_79() -) + + _seg_80() + + _seg_81() +) # type: Tuple[Union[Tuple[int, str], Tuple[int, str, str]], ...] diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__init__.py b/env/Lib/site-packages/pip/_vendor/msgpack/__init__.py index d6705e22..1300b866 100644 --- a/env/Lib/site-packages/pip/_vendor/msgpack/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/msgpack/__init__.py @@ -1,5 +1,4 @@ # coding: utf-8 -from ._version import version from .exceptions import * from .ext import ExtType, Timestamp @@ -7,6 +6,10 @@ import os import sys +version = (1, 0, 5) +__version__ = "1.0.5" + + if os.environ.get("MSGPACK_PUREPYTHON") or sys.version_info[0] == 2: from .fallback import Packer, unpackb, Unpacker else: diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index add4afe4f30d9337b32aa61801fc95913ccfcd1b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1442 zcmYe~<>g{vU|^UdaWFNGg@NHQh=Ytd7#J8F7#J9eFEB7Lq%fo~<}l<kMlmvi*i1Q0 zAt0JLhdGxeiY1pdij|Qeg(ZbGhb@W?OtVL^r?O>nEZ|IGTgX`Km&%^SmBJ#)kiwqL zRFsm!kiwC}oy!x&lgk^$o68r)$H<W9P$dBt=SLL}XUJ1yVMrCIT*Sx#f?zdhdLtR~ zm<$+FI8(S<7@`DIxKnsq7@~wycvJXV7@~wzg`-4Ld80&A1*61Lg`&h$Sc4ff`Cl?J zFfeE`-eNCHEh^5;&(mbQ#i*spbc@}!q9mlUAoUh!NM>$oaY<rs!AnrE_(ci%2D=A1 zI(x?lga)|=M22|y`@LiW8Nz&vEg&&DJGJN*dud)lVsduUEsjtyBef_QqynTLgjpCE z7+4t?7`#Ejs>Hy+P{NSLkjYTPw1lybv6i`paRFlu^8%(ChJ}m^K>^Je%%I6s6~U#T zpr8P<K_NdWD>b=9At66OAu%sSp}Z)wBvm1^M4=>KA)&aWC^a!RfeWlUI5kzlDmf>y zxY#NIq%*ZBK_M-_NFl$VBr`v+SP!hoPm{R_6w9|*!3N!80l8h1<rZW9EjEa0x7f1F z6N}P|Z?S=-Qj1nH6bUjgF#Kw8wu%WYPAw{qNzF;gEQ;~ZOLZyAEK60;RS5O-408<% z_6%_hR`B$5@%M8L_H>L1cJ*})4si`qFpCKY@QFz@(ap(E&nzy<%#KOTD~s{TOo}Pa zEJ@V`S(BKaS{zf5S)d<ZmYSE6U!<Q~oDLG#kB`sH%PfhH*DI(j;$dK55C#P!C`=jH z_!z+=$)HFDg)|6*LLMXw4s8)cXfuLBdjTUTl!F;G8LPs<fdL97^zbc8Eh#O^Qvg|> znxc?YS&~{zLhx!bfkPMUFioZ+UIqq+B7P773PNx=76~yhFx+AVnV%#J@(jqy3~WUp zkD+*lnSp@;?iC3J28J4j1q=%rYMDwHYnaj)GZ|{Yo&tNP2kae4`cp{EgZU|~C_fjT zNc14y2ujQ>PAyhQaIGjQN_0sqNlZ{E&q&RKD^p0$&nrpH%qvz%1*w3903_`oCoqUz zSd*A0(=C>w)Wnn`PH;vk;sf~~6bQFiQW8rNA)x>c4{%VhLGq6pC@et!WnkxEED{50 zmAJ(b56!7XpisKSm0FRU3Q5hkm_g11sV@TMu3Jp`#kZJ?D~oTjr{<Mq7Uk#NVopyj zxy1w3AD@|*mVb*QEior2DKR-45=kKU6@d!GD9-p~Xo9=N?U`GUUsU2+RFq!?jz)0I zfE{#;B_}^I<rXW5EWX8(Qkq+Eixor`Bl!v8F%FyD{FKt1R6CH{i$PhRhmnI(fQf^V egIS7EjERX+f{}+&ikX9pgOh`Yg^`7cg%JQ-hiTpb diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-39.pyc deleted file mode 100644 index 66be0c12af734ae3353ff772c42306861e6ea582..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 246 zcmYe~<>g{vU|^UdaWGYcfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?_G+UxH*_ zf|R~wVqjqK(`3BGUY1%^oSC1ulA(x|fdNANYH+rS2`x@7Dvn9bNy#jV@y|<jDatHM zRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-24N@?R2?+3sNi@;T$xqKLF3HS} zNzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+BkFVfE~P6vsD_+Y2#6;$5hu*uC& ODa}c>1G)G!$i)CgyFxPn diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-39.pyc deleted file mode 100644 index db4c9815e830afe6373dd977e3050f29038a7de9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1880 zcmYe~<>g{vU|^UdaWK`Ag@NHQh=Yt-85kHG7#J9eD;O9U+!<0BQW#qpQW#Sinwg^* z-5FAtQkYv9QkYX2o0+4S+!<0>QdnCUQdq%!W_N}ZwiNajh7|TxmQ==OmMB(th7^tz z&K8CgPN)c5DoYf*J3|Ur3U>=b3U?}dGjkM2Dnk@!DoYesDt8o53QsVDCT}vbn?P(v zn7afR7#LC+q8L*cqL@+`qnJ~ef*CZKZ}Erb6(lBSyH+Hp7L;V>=T)6{N-R!QNX|(t zE>=j(FH$JZ&rMZGg-I7H6eVUBr=}>BXJqE2DwKjXXXd5rad9aqC@A>(hqzinMHO-r zD<P^8+7<FkGE$2aN-`4j6pBleAhzVEf%T#}L{CA%Gfkl~zf_?-F|S0SBwrypu_QS| zAu%UMA+@L|zeoon0M-k4zCvbRaY<@oiXK?lZzanuj`;Yz#N5>Q_*-1@@wxdar8yur zPkek~X<`mkhCMz$B|kYnekDT@I|BoR_|@cW6%$&VT2vg9nv;@Q6yu+l>Qa<hma3qu z5bEa{<{A|28R8hM;OXb$@8=rq=@=92>gyUD;u@r2784NQ6O(A7o0FfOSzMBt9g~_@ z7UPqd6jPj8lBx>|@5J=f;+TTW0{!^1)V!4ZBK_Rrbdb0{BBb>SDvLm|2g1cn3=9k$ zj9@<QDCR+l;$Q|%rdwQ2rD<uYMQ)`zIesgdi<m*aV*wGM^osB-gv9}p;ACK603~&p zl^{MzR&x56miVW+B$g!l6@d(bm<<otBCsvo3=9l>pzH$m7>JMC7944p+bzE+H?hPO zlp3nUJoCyDb23vDpdkrLyt#=benlV~u(|;hTtY~00P#t716ObfDEok&z!j38uaK8o zT#}lC$68(n1_m)CYe9SrYe9|%7bglRaSF<|pn@cdB?Vl7M6sr@1v6-}-{N$wC@D$= z1$tF8oT-qBlwDKv6hL_|6(m?vl$e>5nU}7Rl30=m&AK5OnZ-yM6<I4Nr|0M8R4U}> zrRo-E<d-OD<mHzr6qgjGCgx`5rE7vS8>B3NWV~chLIV{)APi!I{NoJrG$<--7;6~f z8ETkn7~&aI7=jrz8T~YwZgD^iNKLuLnhNraCi5+p;?$h9B7RV^1nEPHMNlFFW$nzo z%#!$cRglS`WX-_H##ki;4*<RRc!+{zP$mMo1%yFt5C*#kq$`CHlvn(!<RC84NYYd& zN=;79EK5yM06PT|PGIXb8H)r#?m<n@x7g$3i%W{)<26Ap0eO~zu}Tox9bj2MO*Zr_ z$ObYDlnRT4K`ex^U>3-mMWB2l2Qn9=mV=Rnje`X&=BLREig#$i4K5psI6;PhGSe-t zu*96wRB+xX0;TLCP&&IM04ZgW<Upq1;tc>LVpt)6ix0#_sJX@KUzS>wmXlu&Htv=n tNE$^595hG-$lbR%Y#_z09VoDiL4FkA6krix5n>TyWnmT&U}0oo1OT!Nru+Z^ diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-39.pyc deleted file mode 100644 index 8044173388082122097ef9782479206aeb36172b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6308 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 MJd8YyV$5Q^0Dv@FRsaA1 diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-39.pyc deleted file mode 100644 index 8f9a25be63168dd71d7fbebd50724904a01f0e92..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26754 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 POgwCC%mVcc5Eu*qO%B`# diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/_version.py b/env/Lib/site-packages/pip/_vendor/msgpack/_version.py deleted file mode 100644 index 1c83c8ed..00000000 --- a/env/Lib/site-packages/pip/_vendor/msgpack/_version.py +++ /dev/null @@ -1 +0,0 @@ -version = (1, 0, 2) diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/ext.py b/env/Lib/site-packages/pip/_vendor/msgpack/ext.py index 4eb9dd65..23e0d6b4 100644 --- a/env/Lib/site-packages/pip/_vendor/msgpack/ext.py +++ b/env/Lib/site-packages/pip/_vendor/msgpack/ext.py @@ -56,10 +56,10 @@ class Timestamp(object): Note: Negative times (before the UNIX epoch) are represented as negative seconds + positive ns. """ if not isinstance(seconds, int_types): - raise TypeError("seconds must be an interger") + raise TypeError("seconds must be an integer") if not isinstance(nanoseconds, int_types): raise TypeError("nanoseconds must be an integer") - if not (0 <= nanoseconds < 10 ** 9): + if not (0 <= nanoseconds < 10**9): raise ValueError( "nanoseconds must be a non-negative integer less than 999999999." ) @@ -143,7 +143,7 @@ class Timestamp(object): :type unix_float: int or float. """ seconds = int(unix_sec // 1) - nanoseconds = int((unix_sec % 1) * 10 ** 9) + nanoseconds = int((unix_sec % 1) * 10**9) return Timestamp(seconds, nanoseconds) def to_unix(self): @@ -161,7 +161,7 @@ class Timestamp(object): :param int unix_ns: Posix timestamp in nanoseconds. :rtype: Timestamp """ - return Timestamp(*divmod(unix_ns, 10 ** 9)) + return Timestamp(*divmod(unix_ns, 10**9)) def to_unix_nano(self): """Get the timestamp as a unixtime in nanoseconds. @@ -169,7 +169,7 @@ class Timestamp(object): :returns: posix timestamp in nanoseconds :rtype: int """ - return self.seconds * 10 ** 9 + self.nanoseconds + return self.seconds * 10**9 + self.nanoseconds def to_datetime(self): """Get the timestamp as a UTC datetime. diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/fallback.py b/env/Lib/site-packages/pip/_vendor/msgpack/fallback.py index 0bfa94ea..e8cebc1b 100644 --- a/env/Lib/site-packages/pip/_vendor/msgpack/fallback.py +++ b/env/Lib/site-packages/pip/_vendor/msgpack/fallback.py @@ -1,5 +1,4 @@ """Fallback pure Python implementation of msgpack""" - from datetime import datetime as _DateTime import sys import struct @@ -12,7 +11,6 @@ if PY2: def dict_iteritems(d): return d.iteritems() - else: int_types = int unicode = str @@ -33,7 +31,6 @@ if sys.version_info < (3, 5): and e.args[0].startswith("maximum recursion depth exceeded") ) - else: def _is_recursionerror(e): @@ -69,7 +66,6 @@ if hasattr(sys, "pypy_version_info"): def getvalue(self): return self.builder.build() - else: USING_STRINGBUILDER = False from io import BytesIO as StringIO @@ -144,10 +140,41 @@ if sys.version_info < (2, 7, 6): """Explicit type cast for legacy struct.unpack_from""" return struct.unpack_from(f, bytes(b), o) - else: _unpack_from = struct.unpack_from +_NO_FORMAT_USED = "" +_MSGPACK_HEADERS = { + 0xC4: (1, _NO_FORMAT_USED, TYPE_BIN), + 0xC5: (2, ">H", TYPE_BIN), + 0xC6: (4, ">I", TYPE_BIN), + 0xC7: (2, "Bb", TYPE_EXT), + 0xC8: (3, ">Hb", TYPE_EXT), + 0xC9: (5, ">Ib", TYPE_EXT), + 0xCA: (4, ">f"), + 0xCB: (8, ">d"), + 0xCC: (1, _NO_FORMAT_USED), + 0xCD: (2, ">H"), + 0xCE: (4, ">I"), + 0xCF: (8, ">Q"), + 0xD0: (1, "b"), + 0xD1: (2, ">h"), + 0xD2: (4, ">i"), + 0xD3: (8, ">q"), + 0xD4: (1, "b1s", TYPE_EXT), + 0xD5: (2, "b2s", TYPE_EXT), + 0xD6: (4, "b4s", TYPE_EXT), + 0xD7: (8, "b8s", TYPE_EXT), + 0xD8: (16, "b16s", TYPE_EXT), + 0xD9: (1, _NO_FORMAT_USED, TYPE_RAW), + 0xDA: (2, ">H", TYPE_RAW), + 0xDB: (4, ">I", TYPE_RAW), + 0xDC: (2, ">H", TYPE_ARRAY), + 0xDD: (4, ">I", TYPE_ARRAY), + 0xDE: (2, ">H", TYPE_MAP), + 0xDF: (4, ">I", TYPE_MAP), +} + class Unpacker(object): """Streaming unpacker. @@ -229,7 +256,7 @@ class Unpacker(object): Example of streaming deserialize from socket:: - unpacker = Unpacker(max_buffer_size) + unpacker = Unpacker() while True: buf = sock.recv(1024**2) if not buf: @@ -291,7 +318,7 @@ class Unpacker(object): self._buf_checkpoint = 0 if not max_buffer_size: - max_buffer_size = 2 ** 31 - 1 + max_buffer_size = 2**31 - 1 if max_str_len == -1: max_str_len = max_buffer_size if max_bin_len == -1: @@ -354,7 +381,7 @@ class Unpacker(object): self._buffer.extend(view) def _consume(self): - """ Gets rid of the used parts of the buffer. """ + """Gets rid of the used parts of the buffer.""" self._stream_offset += self._buff_i - self._buf_checkpoint self._buf_checkpoint = self._buff_i @@ -396,6 +423,8 @@ class Unpacker(object): # Read from file remain_bytes = -remain_bytes + if remain_bytes + len(self._buffer) > self._max_buffer_size: + raise BufferFull while remain_bytes > 0: to_read_bytes = max(self._read_size, remain_bytes) read_data = self.file_like.read(to_read_bytes) @@ -409,7 +438,7 @@ class Unpacker(object): self._buff_i = 0 # rollback raise OutOfData - def _read_header(self, execute=EX_CONSTRUCT): + def _read_header(self): typ = TYPE_IMMEDIATE n = 0 obj = None @@ -424,205 +453,95 @@ class Unpacker(object): n = b & 0b00011111 typ = TYPE_RAW if n > self._max_str_len: - raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len) + raise ValueError("%s exceeds max_str_len(%s)" % (n, self._max_str_len)) obj = self._read(n) elif b & 0b11110000 == 0b10010000: n = b & 0b00001111 typ = TYPE_ARRAY if n > self._max_array_len: - raise ValueError("%s exceeds max_array_len(%s)", n, self._max_array_len) + raise ValueError( + "%s exceeds max_array_len(%s)" % (n, self._max_array_len) + ) elif b & 0b11110000 == 0b10000000: n = b & 0b00001111 typ = TYPE_MAP if n > self._max_map_len: - raise ValueError("%s exceeds max_map_len(%s)", n, self._max_map_len) + raise ValueError("%s exceeds max_map_len(%s)" % (n, self._max_map_len)) elif b == 0xC0: obj = None elif b == 0xC2: obj = False elif b == 0xC3: obj = True - elif b == 0xC4: - typ = TYPE_BIN - self._reserve(1) - n = self._buffer[self._buff_i] - self._buff_i += 1 - if n > self._max_bin_len: - raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len)) - obj = self._read(n) - elif b == 0xC5: - typ = TYPE_BIN - self._reserve(2) - n = _unpack_from(">H", self._buffer, self._buff_i)[0] - self._buff_i += 2 - if n > self._max_bin_len: - raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len)) - obj = self._read(n) - elif b == 0xC6: - typ = TYPE_BIN - self._reserve(4) - n = _unpack_from(">I", self._buffer, self._buff_i)[0] - self._buff_i += 4 + elif 0xC4 <= b <= 0xC6: + size, fmt, typ = _MSGPACK_HEADERS[b] + self._reserve(size) + if len(fmt) > 0: + n = _unpack_from(fmt, self._buffer, self._buff_i)[0] + else: + n = self._buffer[self._buff_i] + self._buff_i += size if n > self._max_bin_len: raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len)) obj = self._read(n) - elif b == 0xC7: # ext 8 - typ = TYPE_EXT - self._reserve(2) - L, n = _unpack_from("Bb", self._buffer, self._buff_i) - self._buff_i += 2 + elif 0xC7 <= b <= 0xC9: + size, fmt, typ = _MSGPACK_HEADERS[b] + self._reserve(size) + L, n = _unpack_from(fmt, self._buffer, self._buff_i) + self._buff_i += size if L > self._max_ext_len: raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len)) obj = self._read(L) - elif b == 0xC8: # ext 16 - typ = TYPE_EXT - self._reserve(3) - L, n = _unpack_from(">Hb", self._buffer, self._buff_i) - self._buff_i += 3 - if L > self._max_ext_len: - raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len)) - obj = self._read(L) - elif b == 0xC9: # ext 32 - typ = TYPE_EXT - self._reserve(5) - L, n = _unpack_from(">Ib", self._buffer, self._buff_i) - self._buff_i += 5 - if L > self._max_ext_len: - raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len)) - obj = self._read(L) - elif b == 0xCA: - self._reserve(4) - obj = _unpack_from(">f", self._buffer, self._buff_i)[0] - self._buff_i += 4 - elif b == 0xCB: - self._reserve(8) - obj = _unpack_from(">d", self._buffer, self._buff_i)[0] - self._buff_i += 8 - elif b == 0xCC: - self._reserve(1) - obj = self._buffer[self._buff_i] - self._buff_i += 1 - elif b == 0xCD: - self._reserve(2) - obj = _unpack_from(">H", self._buffer, self._buff_i)[0] - self._buff_i += 2 - elif b == 0xCE: - self._reserve(4) - obj = _unpack_from(">I", self._buffer, self._buff_i)[0] - self._buff_i += 4 - elif b == 0xCF: - self._reserve(8) - obj = _unpack_from(">Q", self._buffer, self._buff_i)[0] - self._buff_i += 8 - elif b == 0xD0: - self._reserve(1) - obj = _unpack_from("b", self._buffer, self._buff_i)[0] - self._buff_i += 1 - elif b == 0xD1: - self._reserve(2) - obj = _unpack_from(">h", self._buffer, self._buff_i)[0] - self._buff_i += 2 - elif b == 0xD2: - self._reserve(4) - obj = _unpack_from(">i", self._buffer, self._buff_i)[0] - self._buff_i += 4 - elif b == 0xD3: - self._reserve(8) - obj = _unpack_from(">q", self._buffer, self._buff_i)[0] - self._buff_i += 8 - elif b == 0xD4: # fixext 1 - typ = TYPE_EXT - if self._max_ext_len < 1: - raise ValueError("%s exceeds max_ext_len(%s)" % (1, self._max_ext_len)) - self._reserve(2) - n, obj = _unpack_from("b1s", self._buffer, self._buff_i) - self._buff_i += 2 - elif b == 0xD5: # fixext 2 - typ = TYPE_EXT - if self._max_ext_len < 2: - raise ValueError("%s exceeds max_ext_len(%s)" % (2, self._max_ext_len)) - self._reserve(3) - n, obj = _unpack_from("b2s", self._buffer, self._buff_i) - self._buff_i += 3 - elif b == 0xD6: # fixext 4 - typ = TYPE_EXT - if self._max_ext_len < 4: - raise ValueError("%s exceeds max_ext_len(%s)" % (4, self._max_ext_len)) - self._reserve(5) - n, obj = _unpack_from("b4s", self._buffer, self._buff_i) - self._buff_i += 5 - elif b == 0xD7: # fixext 8 - typ = TYPE_EXT - if self._max_ext_len < 8: - raise ValueError("%s exceeds max_ext_len(%s)" % (8, self._max_ext_len)) - self._reserve(9) - n, obj = _unpack_from("b8s", self._buffer, self._buff_i) - self._buff_i += 9 - elif b == 0xD8: # fixext 16 - typ = TYPE_EXT - if self._max_ext_len < 16: - raise ValueError("%s exceeds max_ext_len(%s)" % (16, self._max_ext_len)) - self._reserve(17) - n, obj = _unpack_from("b16s", self._buffer, self._buff_i) - self._buff_i += 17 - elif b == 0xD9: - typ = TYPE_RAW - self._reserve(1) - n = self._buffer[self._buff_i] - self._buff_i += 1 - if n > self._max_str_len: - raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len) - obj = self._read(n) - elif b == 0xDA: - typ = TYPE_RAW - self._reserve(2) - (n,) = _unpack_from(">H", self._buffer, self._buff_i) - self._buff_i += 2 - if n > self._max_str_len: - raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len) - obj = self._read(n) - elif b == 0xDB: - typ = TYPE_RAW - self._reserve(4) - (n,) = _unpack_from(">I", self._buffer, self._buff_i) - self._buff_i += 4 + elif 0xCA <= b <= 0xD3: + size, fmt = _MSGPACK_HEADERS[b] + self._reserve(size) + if len(fmt) > 0: + obj = _unpack_from(fmt, self._buffer, self._buff_i)[0] + else: + obj = self._buffer[self._buff_i] + self._buff_i += size + elif 0xD4 <= b <= 0xD8: + size, fmt, typ = _MSGPACK_HEADERS[b] + if self._max_ext_len < size: + raise ValueError( + "%s exceeds max_ext_len(%s)" % (size, self._max_ext_len) + ) + self._reserve(size + 1) + n, obj = _unpack_from(fmt, self._buffer, self._buff_i) + self._buff_i += size + 1 + elif 0xD9 <= b <= 0xDB: + size, fmt, typ = _MSGPACK_HEADERS[b] + self._reserve(size) + if len(fmt) > 0: + (n,) = _unpack_from(fmt, self._buffer, self._buff_i) + else: + n = self._buffer[self._buff_i] + self._buff_i += size if n > self._max_str_len: - raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len) + raise ValueError("%s exceeds max_str_len(%s)" % (n, self._max_str_len)) obj = self._read(n) - elif b == 0xDC: - typ = TYPE_ARRAY - self._reserve(2) - (n,) = _unpack_from(">H", self._buffer, self._buff_i) - self._buff_i += 2 + elif 0xDC <= b <= 0xDD: + size, fmt, typ = _MSGPACK_HEADERS[b] + self._reserve(size) + (n,) = _unpack_from(fmt, self._buffer, self._buff_i) + self._buff_i += size if n > self._max_array_len: - raise ValueError("%s exceeds max_array_len(%s)", n, self._max_array_len) - elif b == 0xDD: - typ = TYPE_ARRAY - self._reserve(4) - (n,) = _unpack_from(">I", self._buffer, self._buff_i) - self._buff_i += 4 - if n > self._max_array_len: - raise ValueError("%s exceeds max_array_len(%s)", n, self._max_array_len) - elif b == 0xDE: - self._reserve(2) - (n,) = _unpack_from(">H", self._buffer, self._buff_i) - self._buff_i += 2 - if n > self._max_map_len: - raise ValueError("%s exceeds max_map_len(%s)", n, self._max_map_len) - typ = TYPE_MAP - elif b == 0xDF: - self._reserve(4) - (n,) = _unpack_from(">I", self._buffer, self._buff_i) - self._buff_i += 4 + raise ValueError( + "%s exceeds max_array_len(%s)" % (n, self._max_array_len) + ) + elif 0xDE <= b <= 0xDF: + size, fmt, typ = _MSGPACK_HEADERS[b] + self._reserve(size) + (n,) = _unpack_from(fmt, self._buffer, self._buff_i) + self._buff_i += size if n > self._max_map_len: - raise ValueError("%s exceeds max_map_len(%s)", n, self._max_map_len) - typ = TYPE_MAP + raise ValueError("%s exceeds max_map_len(%s)" % (n, self._max_map_len)) else: raise FormatError("Unknown header: 0x%x" % b) return typ, n, obj def _unpack(self, execute=EX_CONSTRUCT): - typ, n, obj = self._read_header(execute) + typ, n, obj = self._read_header() if execute == EX_READ_ARRAY_HEADER: if typ != TYPE_ARRAY: @@ -883,20 +802,20 @@ class Packer(object): raise OverflowError("Integer value out of range") if check(obj, (bytes, bytearray)): n = len(obj) - if n >= 2 ** 32: + if n >= 2**32: raise ValueError("%s is too large" % type(obj).__name__) self._pack_bin_header(n) return self._buffer.write(obj) if check(obj, unicode): obj = obj.encode("utf-8", self._unicode_errors) n = len(obj) - if n >= 2 ** 32: + if n >= 2**32: raise ValueError("String is too large") self._pack_raw_header(n) return self._buffer.write(obj) if check(obj, memoryview): - n = len(obj) * obj.itemsize - if n >= 2 ** 32: + n = obj.nbytes + if n >= 2**32: raise ValueError("Memoryview is too large") self._pack_bin_header(n) return self._buffer.write(obj) @@ -953,6 +872,10 @@ class Packer(object): obj = self._default(obj) default_used = 1 continue + + if self._datetime and check(obj, _DateTime): + raise ValueError("Cannot serialize %r where tzinfo=None" % (obj,)) + raise TypeError("Cannot serialize %r" % (obj,)) def pack(self, obj): @@ -974,7 +897,7 @@ class Packer(object): return ret def pack_array_header(self, n): - if n >= 2 ** 32: + if n >= 2**32: raise ValueError self._pack_array_header(n) if self._autoreset: @@ -983,7 +906,7 @@ class Packer(object): return ret def pack_map_header(self, n): - if n >= 2 ** 32: + if n >= 2**32: raise ValueError self._pack_map_header(n) if self._autoreset: diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__about__.py b/env/Lib/site-packages/pip/_vendor/packaging/__about__.py index 4c43a968..3551bc2d 100644 --- a/env/Lib/site-packages/pip/_vendor/packaging/__about__.py +++ b/env/Lib/site-packages/pip/_vendor/packaging/__about__.py @@ -1,7 +1,6 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from __future__ import absolute_import, division, print_function __all__ = [ "__title__", @@ -18,7 +17,7 @@ __title__ = "packaging" __summary__ = "Core utilities for Python packages" __uri__ = "https://github.com/pypa/packaging" -__version__ = "20.9" +__version__ = "21.3" __author__ = "Donald Stufft and individual contributors" __email__ = "donald@stufft.io" diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__init__.py b/env/Lib/site-packages/pip/_vendor/packaging/__init__.py index a0cf67df..3c50c5dc 100644 --- a/env/Lib/site-packages/pip/_vendor/packaging/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/packaging/__init__.py @@ -1,7 +1,6 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from __future__ import absolute_import, division, print_function from .__about__ import ( __author__, diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-39.pyc deleted file mode 100644 index fecdb66800010426132b32b6f20e103bfe7cc6e0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 717 zcmYe~<>g{vU|^UdaWM5769dCz5C<7EF)%PVFfcF_yD%^?q%fo~<}l<kMlt3xMKR?v zM=>)pq%)*2En<vfNnws+O<{>*OJR*-PhpGVNMVoSOyP*)O5u#+PT@-B6k~|uN#PD= z(ByduGGCMV7Jp(=aehu|Noss%Zb5!g$t{kQ%(Bel%>2Atd<8|Bc_r~_rFqFEnfZB| z9Je^*<4ZD2a#G{tZ*j-R7nkPdCKgr3$KPU)k1s9Cgou`<7J+of$KT?Lk54Qu$;dB? zj|b^Y%}vbAfvCyJOis-!1{uQ}AD^6GP+63jo>2l)R*;ySotU1PmtLjhoL`ixP+F3i zlUb6PTC9+kU!)LFS(1^TrvOouT3n@=QBqP+Y^ATCo>`JnnxvPUpQ~R`S&*m?Q2{cB z#mGR<vP#n>KQA#SMIpGPG%c+}Au%sSAu|u;(Uj7}9EIfkypp2Kq|%c7qT(un6tGf< zVz5%Z%={`Tr(hRdBVFg5#M0tah5RA~$AZM<j8t7CJ%cJ9BLhPdT_XcSO9j<pKTTec zr_)MHN{dqC<BLGiR>aJ}z)-}(z`y_srNo?^`1m4LkPsV)U<VN#Ac7M_fKovbH;Bc< zz`(GQp-2G41`)rSovmU*i&Kk=V^VWcGK*sT^HN=kGRsmGbQMDVJi}arf;~eVgB3je zT>Sl9gFPK%f?a)GgF{?{6wG1*0(@c;O>}ee(=&@pGP7e+^U7j;GLvG8GfPr+AwiW| z98-{4pdVkBnwOGaga|+V`1r)6{L+&6c)fzkTO2mI`6;D2sdga$6bmshFo-a5aI-M7 MFtRYQFo8)%03R>ahX4Qo diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 200d3c409305fe272db30a88f5ce1adce2408cd1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 573 zcmYe~<>g{vU|^UdaWK`0iGkrUh=Yuo7#J8F7#J9eJs21mQW#Pga~N_NqZo6UqL^}- zqnH^PQkYVhb69d&qgZp<qS$iTqu6sfqBwFnqd0T9qPTLoqquW<qIeh?(iu`%7BNQg zrmzMxXtKQo*`djNi$5``I6tSfBsD%Ww;;c$<Q7LtW?5!&W`5o+zJj96yps5|(!Au7 z%>2BUj0_A6njE*d;^PxbOEU6{;^S}e#>Xe;7gQEyre~DI$KT?Nk5A1_%*=_8zr`IN zpOcxKnpd0(;S`tV<|Y<ZLKKx`mgIoM+2i9&i!vb!%2JC!w#LV6aujhhFfbH>f~AND z#Nq`JY#@RIL~w!#b_NCpKTST6Ytl+fN{dqC<BLE+Rm2REWno}o0J$bHDZjKNKE4R7 z8Kk8MVFK8EuuX7FZn4M5C+6hD$FF245(Jq8B7QYFTg8MHrxq2*q~@e#7RC7IrMeVl zmZd7_DunuZhPeg>dxkg$D|q_3`1`pAdpgDhyZX8YhqwkQn8gGH_{1cd=;q|7XBL-a zX2+!FmBsjECdCwImZa(yBqnDkrl%Ii6l50Y$Cst%rQ{dsLj*JP()HuxGxIV_;^XxS YDsOSv<mRW8=A_zzd{zu1M3^+V0kP7XzyJUM diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-39.pyc deleted file mode 100644 index 435f600ff43a89ee86ef147b255333fefc321460..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1171 zcmYe~<>g{vU|^UdaWFN5g@NHQh=Yuo7#J8F7#J9e>lhdqQW#Pga~N_NqZo6UqL^}- zqnH^%VoW(KQ7kFUDJ(gxxolBvj0~x4MJ_1}DXcl{xg1d(xtvj)xm;0Px!h6Qj0~wP zSv)BWk_;(q*-TNqa2|U$Qxsn+Ur|mfe;Q+yKptDFAc#)kNa1W@h!RR+3TDvcdI@rw zCi5-+#H8Z<oYIoi_{`jb{GyUu94VP)nZ=p;dAIlqiZb&`;?qj=l1no4^ZZ^iGB7Y` zGT!11i41U!clK~~_V)C1*JQcH?3h=1i^U}~x#SjWNNGV%>MfR#%7WCFAP>J}W?*1Q z2I&M@2*Mx%HU<U;c2H2LF)%Q=Gqf|bGo~@6Fs3lIaHKGGFg7#SGL<kaV60&R1w|&q zLY80#P1Y)XE(HYz1?QsF#FA8nM1`cp;#7s?oW$Z{h4Rdj42496+|-gpuz(&|WirS* zWDK$z#4na&U|>jPh+<4(h+;yvJc>DmIha9{rAiTGVm!h;o1FaQ#GGO~J-ARZ3&<oW z2C+d{8004&1_p)>#u~;Bh8pH(ka3KDD;Yq+l$=w1izP2HH}w`*Nk(RIJjesZw-{4a zGTmZ@uvtLH7x6MMF#KwCwu%WYPAw{qNzF;gEQ;~ZOLZyAEK60;RS5O-408<%_6%_h zR`B$5@%M8L_H>L1cJ*})4si`qFpCKY@QFz@(ap(E&nzy<%#KOTD~s{TOo}PaEJ@WZ zNKDR7OiwM2Dab6)k1tEjOUW<NhX`iorR&Eh=jRqAmgp5!-eQlB&r2<jk5>Zu3KW?P zOjVi$14a+3%TJT#7Ds$M$iMONx47ctbMsS5b5i5uZ}G&(7nUaGKxB%<7#JA9UM>=X zvqTvf7;bTb0s|bKiZBOoFcyKL?iPPZDk!xk7FEWB6@c|?GTmY+sVqnZo2bcLBmy!H z6eD0gU?mVMz^3z|dPEXr1t<y`IK)_sWI-ui806@*(vs4m)cE)!kpGK738)C9>K1cx zW$`Wc_>#(k%)Im>P<p<_2IYVfb`b~2a!wEdDim(<l%*DdGF5zLURwSw=72~e5Mg|a zxwxe07Ef_WQD$B`$gtGnTU_9z02Tqe1LAN{nt-stuII3Ugr*(HF~uOCiZF37@i4J4 RN-*;=^0BZmaxk$m0{|8HDbD}^ diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-39.pyc deleted file mode 100644 index 58a941566764676660502683697a93452f777b43..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2925 zcmYe~<>g{vU|^UdaWM56I|IXG5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlt3xMKR?v zM=>)pxHF_Mr7*WJq%fzlG&4uBrm{9OM6tOuq_Cv0wlJiyf<@U=*_#=nI8xYx88q2n zg3Q-szQv!IRGgnvT9O){nOl%wRC0?WC9^EEI5R)*7GFV8W?o5rT4`Q#NoIatGDrt9 zW`emYgn@w}l_82Tg&~S5g)xPxg&~SLg*k<#g&~S1g*An(g&~SHg*}C%g&~S9g)@b# zg&~SPg*%0(1>_pu6uuUQD9#lA6oD3oD6SO26rmP|DDD*DU<OT*TRfh5X_<MMC6ytS z1*yr5NY;bcAnXhZ7f=ADFa|SdGWp%&fN5FDu#)i>OL1yWS`j+~0|S`&)#_{&6Iz^F zR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux&p>F46_=Njzk7!&O3>lz&58l+$r z6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0ns#}nloSm4SS{zf5S)d<ZmYSE6U!)Ha z%*;#Ik1sAMDorjaElMrcE2zB15g%WaT2K@p&jE5iC?pw}szhNf2YFTxrUJv)%nS?+ zU|;hvFff!blrYvXG&43c1~aT=^jpbvizOqmIO7%z$oL|V>0p0D2v8~mSq)MV9}m)A zjKgY(ie#`XG|)k8i~wKB<mU!9dnHp5Cj$e+E!O;!jMO5q5QG5R$rc}<QxYF9faF<W zG|z(M3ENjB2#d)gAvg;hyKs9_<Kso}*^?R{k6{m5kk&BPFk~?{GX*mgfdXkI(=D#d z;>^6_lEl2^)LWeK@yR)f#l`XQxZIFh7#}Zz#|<EP+-~3lM=Q(?JPc4*6p4X6jKkM? zsqyhLcx(j8W7vo-HbWq>hQpfllK6N9Jl25Z30qSn4e|*%)^ORA8XvEM&mK@Df}9Uc zn+zZ}2!rzls5B^n1)C=0EdjsO^u&_PvQ$`-!<sMH<Ky#E)8peckn9zK>44@)umZo8 zJfKXJmzbLxAAgH0K0Y@;r8Eb`=82ClEKSUT$P{sdd<jbOMWFOpBnsk6f(R)P0gA06 zSrAJeM1VsBL4Z<o5i0`&14yVC6iOV794x31EI%NnvIu&Bf`SL5oI;5YXz5(VsS68I zNJ7I>LV*L$5GfX9u~|n(`3TO;MZBQk#%3)js!WNnme{fpe=-Lr3QHvGq;dF?$bu1X zo&qO6TVgB&Wh_uh56f5}HvZBPXSq}aO6-nASW4aEun3gBT#2xjxH1ucjZ*~5#-2o2 zMr6r|w|WB?7rw+;28u;c_JhSDhz-KnipL^0Tp0pXFa;u6Cxat}LQ2IVP{jbr)SyBO z!UC6Lppx7GWDbsU3?%QT$q6b-(@H^2r1<zEP`WDuCA=a~X?}|>KPf9UxddF~K^zRy jR3ry-I>I(E3uNUj4jV|JYzNX^49e{y%mQj`%mQiv!pJ7Y diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_typing.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_typing.cpython-39.pyc deleted file mode 100644 index 5c88f89de500b5c0b72e8e3320665be133bada84..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1528 zcmYe~<>g{vU|^UdaWGYZoq^#oh=Yuo7#J8F7#J9e^%xi!QW&BbQW#U1(wU+dQ<$Te zQkjaBQdm-0bC`2kqF5Li@;Fl1QkYs8qF7ScgBdhA65UxC7~JxU6!KCNOL8g|GII-Z zQgc)DN;31(6^cs|OEQxcN-7ILyv#g>g2d$P#PrO(bUiMvgxt!4$^->ng_4X^B$cTO ziFt`RmBpFG3MKjZISS>e3Z=!V3c4V&7_2q{VqStmZhlH>PO6SVc}8Y(23J8*epzNp zYOz9ceo?AIT4`Q#NoIatVoqjBC5V@j2y#_ojzUSk0?20dVvs0U4a7a}sd=eIi8(oy zItp+b%JWNeQWTO>LEg$QDoIUINGwq(D$Og&%mukK1>~p{h0HvKl8nR>g|x)tjLiHz z1zoPp5{1O%l46C#VueJ7ynNmK0(6Zj`KiSUdHE#@8Hr^eqbfnh>VnP9FH0@TNKH&p zNUG#YNiEJy&(q`Lax7NJEKw*aEy^oa$S*BHa$_dMoU+usl>DN^q#RIKWtM<kR;*B* zT98<jSdywxoL^d$oLa1qmS4mbP+5|ZpQm7?4`mqZDTHK{7V9XKWMqOuFC{f8u{c#B zIWZ6Hz|@L@)Z`Md?fIafC@4xTPR%RP;|j@FD9<m-R!A($FU?B<>(&7WtwLf>PJTHg zvLJB<4L?xWC#5PRrDkO2r6?pSxFzNkr|MR6<rhGr3M5}plv<XW2evP*C_fhzEP0^R zgBI{5l?AD~$@#gUNG%4tH3^(hQn*U;6^c@G^UG4fi6t*JH3j5rFbAXwl&nDBNK8&n zEiTRkg;z>uQED<M@urj(fvkc?upSpz2q;7#$xH#BzCh^}>T-qj(!?Tg0!UQI%S=wq zsZ_{I%mvv9O$x>Nkff2wm0VhsnO|D0keis9SCW{Sms$jNbx~?!a)v@iYEdf4^F^R& z2StM(7ndhecF_R^DKwMlLW8s@H7602A~SOf@{3A}6^b)pi52W9P+A4WH#jP+xVRJ) z6coS#T98?w7Y|7-dWifO4>c8HnnFlqfNQ+7hpV%<r=L4Sb7mT<s1?{qxUs1E_4M?( zxPnsCtQ0azN(zdt^!3v-OEOB6^pf*)^$WlWP#=^F^)ri$OH+&Wjg1V=xNh;HSbK{l zIkC9J?IozJ(qt?G6;sI|0>lSl5Sx*Kfx#J6cCj!pFw`&xGiWmUtz^(-y2T2L>-bx& zWr;bZsYM`JF!8I=*(xTqIJKxaCN(D|vna+tFV&?evka7JLj63$T!Vr=LmYz@JpEk! z{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgtCgnOYoE zkXfJ)4PSkTU}j#rJ~Vvw3M#=K(FeI1<N*doKTXzK?D6p_`N{F|AVy+NPJDb3$YZzI nAb|?j0d_tT!Op<IaErqRk~r-^%8Nn8Jc|qmI|~~N6CX1G)8pp^ diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-39.pyc deleted file mode 100644 index 0480d34e188df2c3536d4830f9aeb47d6a187009..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9299 zcmYe~<>g{vU|^UdaWIuZm4V?gh=Ytd85kHG7#J9e>zElBQW#Pga~N_NqZo6UqL^}- zqnH^%VoW(KQ7kD8DNH%6QLJE^Es70Hvq!O~Fr+Z&aO84EaprPGapiJH@#OMG@#gYH z@#XSI@#hLe3FHb!3FZn#2{AIHu%xi&2<M7KiGbN`Iik5@QDR^=dyaUnM3h9XWRxT$ zL#kNOffR-mjvT36=_u)3nJAfD*(ljuxhT0@`6&5Zg(!tw#VAEahE$nUrBtPKrc~uL zCP{`Um2`#_&P9w-s_qOaTq)cw3@O~HYR$}1>h26FJSn^_3@N-|zJ@zP3SSC;3quM& zn6K&1kRp&G*usz^n5xyx9Hs5fkRp^K+`^C|oT}Z-9HryVkRp;I+QN_`3g+v&Go*;6 zh_^7Lh=cihsXQqX&5Wr$DU!{MP7J9$DN;~c8cNGRX;~;O2c_kqv;ve?gwje-S{X{K zKxtJdtp=slp|l2+)&$W}`YB2&iYc-waw(E2k||nq*rE(l^%oeXXs773Ff3$b1i4Tb z>|Q;P`c$42eJE`Jr46C95tKHD(k37}$|%(+l_$j%#7^Z&F$2+2#;L{&3{%YEHt?rd zG&831r&xkzO;Sx37^YakWqDGp!S>sLWldA{Q%#&0qRdjcQq5A0#Tin~#2K0yqs&vy z7Z|44BI&YgW?W#gkRi%4l_$j>%C<`7Y-WhEPBl;EO0`V27H3Gc0_k>Qh_XqwPPIuD zNHqnCHZzJd*fB6NqzZv}se<ARQMM@#DUK}+QFbX|Db6V_EsRn2DXt*fQrtjfDod6_ zDod7QDod7ADod7gDod72Dod7Yiu)XnD7O@k6welhD0g>;6t5KT7KRjWaN6-m^=M{@ z@=Wnb@oiy<@=Ebb@o!;>@=ggz32b4A@<|Cw32tGC@^xoO2}ucUVMqxD>+(xs3TDs@ ze+kN&n#{NO6O)Sbb4p86<1=#$@{3AtainCHWfo`V=iTBfD9X$$iBBudOD@UG&-2sd zyv6R8UsRr0lyZyJy(qu5;1;`2W=U#MV$LnTfW)HWRM(2+)B=#&TRdQXP-<~$PD$}C zp1{)llGK#olA_GK^jlm}sYUtzMZWn(skb<b!D6m?DYv*G%;1v5qLP=43=9mKjJJ3o zV(}%F1*yfFjJJ40A_H9GojqKgy*>ThHJNS+c;=NQ=47S>7o;X<re&rU-Qt8ZHQ8@5 zJLXm1;&4vP$w^GgNxjA5l9^m`i^V6ixa1axKiH*-Ik#9tN(*vQZ?T5vW#;E;vfko_ zn(3QZl$~01OE@$yB{eNGFEzzEKer&UD6=>}@0J8y&^50tvnW3=H#M)sFEKau78^`k zN@`kSX--LeDndarDA18H$eZ9IQGkJgA(bJDF@+(DDTOhL85~K>MN$k53{|dN3JMAe zj(G~15Wgzqf*qz%o>;7qmS38eqN7k+oLW?@P@Iupnv<eXl$w@Wq)?Kt5a1f1U}|8Y z2iEVmlI0dhe0*MFZfbn|Ew1?Z-29Z%91xo)KEALtF$XHc9v`2QpBx{*lA%b2fdNAN zYIL@W2?f~^lbVx~Srp@+m+DfKS(d7xs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2?CR?p z9O4?JU=|Y);1iQ*qMMVSo>^RynH`gwR~F-wnG{o;S(2(-keHmEn4Vf3Q;=DpA77T5 zmy%zk4-w4FOV@|^v{<j85*!p-pxT3pfq{X85zHq!Jf%V582}Csr0~oyNG(bPC0lTi zCYF?><`$HsrYPj+DI_YCCFYc-DwJd-mMEm;rxxd_mnamM7J#yfLS_jxXp7`wA%zID zB2|zW$U*}oSA+N@yIKb1>KKTt6+qF1=FXCQg``wa8c0F7Qz0+EL?N{zv$#YdGp{%^ zB~>9mO`#+s6>JJpk|gK@kmY7bJ^=ACd;p3Qa5~mONyjNnEeui2Da<J>EeugCDXb}M zEeuhtDeNg6Eeug?DV)I!nq0S7{PI&$lR+lHat4SE!p<OTL2Zf}#u|orh7^WihLwzd znvAzt!I7fLbc>}pH7Bh|0~FHm#0n00P*Ts#%PfhHw*wghGL3<$iWg*+UVJ=6CK;6b zV0MDoAXRWXOBiYxvKX5ggBgm{L4^_1E#~5qBCuU68H+TrSjiqAUtCfYAMb=@BM;O@ zumpyMtPBhcU<*YU7#LC*7l5tIVk%*-VQ6Mt2r8$U{Hl0tstsy2stpy3YBlXNS#GhV z<rn29mfYfuk5A4?EG~|ZFH!)xMjJ$c!XGUSf`XzbwV)_I-VMoNu%Lj*V7Lqv9AKAm zFfcHbFf=iO0v{3(jJJgS@=H8(3vyCHg<fikYf({tQ4uzqIg3+^G81z$t5Us?tmXrU z30%rglO5s#MUV%SK!g^E&;=2oyi;TZVj<!e%mU{wH3kL-Tad{hS8_0Nuz+9@NECMp z1qC&tq=lu>U<OT=TO47DMVX+A0wXx!DFb8?C}qIY#Y)B^TmcVucL2zFAngoHRYEZH z^$?z4$%5{AoW3<?U|{fv8OOm`1mctBPu4I{nTFv>W>{(jWjRP{T*w&ApvmM{#i~?o zP^+ZLSfmGv3M^3#_G=i-aSTjV{9rqfJX&N5(h80{1ObjkQ0Wp1)5^hE1mctBFDCy2 z3{QcA9w{M%G8QyP7ny(@gv&26Fb6R(Rq^;25akhb1_p*`m_821A`t(USSBo|fUB7J zveY7Q>q@R5C$R*SmE#L4OEU8FK<zI`jsmN@C5)yIRPNsrhN?{~&B=kABmg(5C^aWF zu{iY>LIh?TLL@gaIU_SK^%g%|S8-)=NowvbKB(C+Ej-1Q#qlsjx7hQG!EJ|M?D@rd zAh-Mi$?L)7f59!#gX%{Tfm-<s?qxlwRj6LPC5l~`HMOFoC{dHG2o#S+E}&R*1rea) ztjHb2@?c<KNCqWeSZNMov%!+H1h@z*VO+pe!<51($p9f2GJ*2&N+!P|P+6zR49-rs z*d2X59fMtiZ!xE*maJsH#aMicG3ORz2}YS}larX6l#*yy%fP_!8DwoyAgGpRwzakW z#RS53w!fHcY=1E++Ey{u+5Td*`^9MUiw#sOXXf2v%FM%XFUZXx9~Sd~-3xIg$c;sy z!c!BHoQixw{zc0`Ae&o2;z0}y48IuFe=#bNZaOH};WWJ+X8JAW#JrSSO!-A5TX2iD z1k}vNX+<B*ieHQxzZf+!GBP}PK$RV+2rgl4W-5|MVFVT7H4H8cprEQ@2nIJ3G@1QS z3;>k^EDQ_`!Jym;ssYj&Y8Ya9Y8guyY8aatCo&bX1Vfs-nvAzZ;*;}Ji;`303qXCE z_#$v8Mw96llb*pX#!U2-z-5z@SzMBwpIcxz7v_a34Qxi}+2rIWC*~B}=^?aeGTq|J zEY8d;E=kNwPA%dDwKN!Su|w=EMzgCZiGhJ(7RU>rw9UZ8#mL7577IaXK7m3C-m+K$ zNlXkSj3rDZ%xTQcOvNHz3{4=9Gk`<Tql5)iD5fxGGZlG&!Zn3S60ACnsTm}~TEhSm z0fjC|7ObZU(xiigdM#58V^LlT>jJhKCQyBm!UkiDGo-MKGXyi_DS>r@%v%7GOW{c2 zY+-=t2I+vu8kb)YA1Dk#IT9oOKwc^ac^=d$s$qx~g2WzZAgPxrjDeA%kO|Ujas#yx z(=v;SOF(T!zIad}n^+PL=}W9+DgxClw-|HL0{0fDO?qlxYDGbj-DZ#*KzXT35mhr% z48qj@VpJ$f0I5#|l|dkfg9-x>#+l}77#A=sWI#!C;Oes|3uF#j-cDs;VAu%~2fIfJ zr+eUuP?NnVje&vT77IwEC?2GhAH-+QNzE(D1hH7M@-y=^nQyT{LZm1IB*>bXmzP?E z7A9czi$Gxx%5)6OBJ3RhnV7i#F)<7LWn$$4B|t_NMlL21MlMDXCa`Lhln4p}5C#`( zpr%s|Lk(jY1FQlDd37bzE#{nz;#<r`85qeORIcp@c>v^hA`FJL)gitBr4<MZWDmGk z04}2sz)aNSD2f8HBSAz2hyb-hia=#V5vVCs6ao?p2gNHWOM&7PghA;L<QK4~Kv7mD zRRU_fGuALJU|Psf!<5dnkg=JumN}duPl$z~gt=0OkpToF8S;1x7;2aou+%Vsl6?s% z%YgMPWUOVWVM$>qWhhE0VNYRNzya#<)G#e%Zf0y^tYN8Ps9|abbqARJZZT9T!^a*J zstpv2YC-)}aQ8qVF)u}-+DNgeR!@_&NC@Qm0uTXiQ3`@$nIkzruOu-uulN>MJfzo~ zUsPP=15yO)nSz^lnyf`7Ahk^S1x2MG21{{4YVs`>kb1Q6yu}fpT9%j-pI>kalt{!t z!NbJFD8<Ob$i~FQ#K*|N$i&F=pM|BU1{8`QX=Dt_E#O`wsK!II$w5udTbyuD`e`zw zH<7^+iXgzPNKi$52jmJ+g5zK;0`XDO3@8pkbpSZtKwZWfh6M~Yj3tZ<nQECzm};0x zn46i3R7zM<7#FbCFoNQ+iLnM0>P&uB`jC(YjR2tZtQA21F9o;Q6p(w>nrz@uy~Pz@ z3L8BFXG^fNia>p6NLVx9;zrVTiv`rO0{1a7LpnVbJeC9+RtGl`7??mAkcp846uyn1 z@CErC7QUdGgdNrby1>A|kj{|KSjz+|bYnNwGM6yaFe6n7O3*5S8C<+OLE0V*SV~xH zm}?lDnLq=%g<N1gphA3J4RZ{0ElVwHEn5jg4ND1IGgDDX340A=4NDeBGgB>l4O<pR zEk~XZh+oSNmSF?SaKKIGtYNQVt>I{9hL~N$oWfMbP`nD{jvD3^=4_@St{SEVEa~7u z<U+0zF3^B}3quVPsG<i|Mw)DXFaQ7l|6h}-C>E4{<6s0v#Q}<VP+?FEN}n|hv3!t< zqnQy}X~4=OO~zZyi8(o%&>Dgzvm_P0k|@dn4?Zz46oHDQDiv_@FHI~-h1M>`SZWAO zZb;1MfgFe^kJ%Cn3R3e@ZV6(T0d9#FfnpSr5<qze)b6ST4ZuRm?Bb$&P|jpa2aUoO z7Zrkx24&i!N)QX2YdLc=isQlKB)2$=U`(`BRn*47!0;ZFX+Yg>1|~Kp4n`3sE=Dm% zE=DdUE=C?k4kk869wrGU9!3sE9wxAQl<)<GEj&|!${AR{v6c}ud{PT)ax-N!7wOe7 z)-a_oOEQ!&)i7i+gGR{B8EP48K>bS=zbe^k1HIhDto)){JrFB156((1%CEh}nwFWD zm;-63vw$<sEgooJCnvQmH3!@Uzr_aWRckWeV#&-)%fH1A?TOrC$<EA6LG$`8VQ8}e zxhuuZ$iPqx>ivS+R&0zMjAD#MlR!BOma9NCD3^g+Dd2LX2;96XVN3xvMiok!N*J@4 zvsjuLYZ<^S)>_6qjufU^h7@LyXKNTr*s@ql*cWgtWGG=@zzHU~z$6Qp<OY*G3mH;a z7Vws^FW_4UniOMgWs+oA$XLRd#h$`8hdY=-lilwYA6n;$(V(adlqMMUUV>bx$z5ax zN(&Ys0yH931R4k{vH@}JK?G>rq{te?vIG&Ja=6G5)coYX#h#H^oLEv)bc?yTvKSly zMUz2lCV+?rkR?p{#kV+MeZO1m&<-A`-3sY|vO)TkMPO4wy|W@vMRZF9+QEZHOgy+p z02;>2EK4ndxEHNdmt$aH5CO#sB!P0V@Gx>Qu`seQGchtTvM{nCK@moluSFpBp!OXo zqTm>mNI@<s28~`I>KRbS0n6wl7r1%K7{!*t9?YQ0T_g)i0H7d+nFmVmphN;r0H7v$ zl}HH#xO)k%G-?>)K~=v83quJ@Weg)jEfXU{l>wwu0p)@$wi>1^wiG6D25_`8)iRf` z*MKYfaE3^R6oy)+I;K1>2yMV%0PD|GX+x(apu_)Gkjh_20o+SbNCgeTDI}ICfLj7D zK@Aj54shq-7MrhQkhg2lEpD(%=p+mWti&n;DTU-I=A8Uw@VL4r3uJ&3RIc1&OufaP zT2urY+eFJlMWAsy15oUM@&f}C6Qc+tA0rE+$bS~*Dt^d32)U!J;KpRpVo-|1Hbes& z9JB)242~G4Dn7Vv*hgAHaR!brkV`>jR0$)f*8^&XfyTG^Z6NwJszD7ZO*>5{aEO4* z6>KA$MWAs>J0$xNzJ&~^`e8IZK#36S0#FJsVQ6Lm^_x-{OBstKYM2%<f*Kr*(9#jw z*kejmVPs%%1(o56C8-LD(1_RL0*~Q?=7fS$OG=CKK*Rb9N%{FXsfl?CX+`<D@J2~q zI#@0}vn(|as#_s39n}6S0ZG8kL282NAva?bGK&=w^Az%-Gi3^iMd_uWF<;Q+Qa&il zg60(xb8-~&i{NGzBo>uG=Nc4JQcF^cazRsP$fhEBAS5FdSq5Yuk{+;MN-|Ovl1qz< zQu9g_0>C3>3I#>^$*IM~kf{q$IQVI@fOGyWw$g%>#FA8SJq1oYn#_=t46ZJPq2?e@ z$)P3bTO7~^U8)l(c0qZAfeTa<a52GCG)#piBjKUzm7oL+ig7f1z@>^l%nA-h4leM} zHK?r7WDL>t2TjnWm6ntirN+k>fzo&pDE$<HlJPALP)j_qB)_O=CdhQqfI!g<P^m0h zkXfJyokY_ss03yA%)Im>P=}=mG-6N$Y7pLH^nqk~Pz$jLRE`yKgNy;S!Hal7#<0hO zMl%viiopFwcF^Q2$QaNR<t;8yUjRJOT3iI`QGk0Hx7bQ53qVSQK?Z?_SBgYIEKqx^ zNF2lh4Z#&jf>@xz@>?vR)EdR%UjUkS%P+dc9v`2WlLMNT1dkd+CKN#3{339#1k_x< z#g?Cxm6}`v9^Hqukia8W;4xN?FvlQIM<*ZGB5#lf_=;0Y!1K?J;EC&7+~5gHf4_KV z-+)`3kkT;TKj0P*lo{se6Y6@4&B@>2$3Nf}7hE*x7B`gb8RF`Divu+8SCm>@e2dK| zz%j_x?-pASgoY_|jR-*KaSZYIEm{cjGpLRLmuI(_a!PJ7<)q$XN-ey_l$UyoDIJ7M ziYh?LK<zw8|DX=U1vdae4Kzp%4650{sRk(}ffE*}_j8NGCKo)NYX?dp#YaH3CKCrE z7&7Vb@G$Z)3NW!SsxS#Kb8rf<39t#U3kX4IHb%DpOiXP5n3&oAGO@7zVPa+b&BVs` zi;11>Cld$T4<=5w?@U~5-<Y`BzB2K!ePQBd`^?10_KAs~?IV)_+Xp5=w)af`nM6Sq zG8F$}<KSbq`_IH8!pO%Y0K!ZhV48=Khl!0*gi(Zvhna(eOBPgpvoONp4>leSApsUP NW)2<>84gYkX#f-5H&Flp diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-39.pyc deleted file mode 100644 index d42056248ced5aafe8868c86c2fe5e45cb488297..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4172 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 J;$h}u1^}4?I~xE1 diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc deleted file mode 100644 index 86b3f711973562313491c819d34b7fbd22dfd96e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20954 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 diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/tags.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/tags.cpython-39.pyc deleted file mode 100644 index 0bfdb1a79a6c8ce95d6d2cb22df79fa9a1c8a885..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18571 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 D5$Bw} diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-39.pyc deleted file mode 100644 index 09d01046c240055f8b96ebd19e5a7fb6041595b6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3639 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 O#l*$T!Oo$@p$q_h*Ppfk diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-39.pyc deleted file mode 100644 index f4437ce827b023287d76e6ede6dfebe88eb07b47..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12703 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 A9smFU diff --git a/env/Lib/site-packages/pip/_vendor/packaging/_compat.py b/env/Lib/site-packages/pip/_vendor/packaging/_compat.py deleted file mode 100644 index e54bd4ed..00000000 --- a/env/Lib/site-packages/pip/_vendor/packaging/_compat.py +++ /dev/null @@ -1,38 +0,0 @@ -# This file is dual licensed under the terms of the Apache License, Version -# 2.0, and the BSD License. See the LICENSE file in the root of this repository -# for complete details. -from __future__ import absolute_import, division, print_function - -import sys - -from ._typing import TYPE_CHECKING - -if TYPE_CHECKING: # pragma: no cover - from typing import Any, Dict, Tuple, Type - - -PY2 = sys.version_info[0] == 2 -PY3 = sys.version_info[0] == 3 - -# flake8: noqa - -if PY3: - string_types = (str,) -else: - string_types = (basestring,) - - -def with_metaclass(meta, *bases): - # type: (Type[Any], Tuple[Type[Any], ...]) -> Any - """ - Create a base class with a metaclass. - """ - # This requires a bit of explanation: the basic idea is to make a dummy - # metaclass for one level of class instantiation that replaces itself with - # the actual metaclass. - class metaclass(meta): # type: ignore - def __new__(cls, name, this_bases, d): - # type: (Type[Any], str, Tuple[Any], Dict[Any, Any]) -> Any - return meta(name, bases, d) - - return type.__new__(metaclass, "temporary_class", (), {}) diff --git a/env/Lib/site-packages/pip/_vendor/packaging/_structures.py b/env/Lib/site-packages/pip/_vendor/packaging/_structures.py index 800d5c55..90a6465f 100644 --- a/env/Lib/site-packages/pip/_vendor/packaging/_structures.py +++ b/env/Lib/site-packages/pip/_vendor/packaging/_structures.py @@ -1,85 +1,60 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from __future__ import absolute_import, division, print_function -class InfinityType(object): - def __repr__(self): - # type: () -> str +class InfinityType: + def __repr__(self) -> str: return "Infinity" - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash(repr(self)) - def __lt__(self, other): - # type: (object) -> bool + def __lt__(self, other: object) -> bool: return False - def __le__(self, other): - # type: (object) -> bool + def __le__(self, other: object) -> bool: return False - def __eq__(self, other): - # type: (object) -> bool + def __eq__(self, other: object) -> bool: return isinstance(other, self.__class__) - def __ne__(self, other): - # type: (object) -> bool - return not isinstance(other, self.__class__) - - def __gt__(self, other): - # type: (object) -> bool + def __gt__(self, other: object) -> bool: return True - def __ge__(self, other): - # type: (object) -> bool + def __ge__(self, other: object) -> bool: return True - def __neg__(self): - # type: (object) -> NegativeInfinityType + def __neg__(self: object) -> "NegativeInfinityType": return NegativeInfinity Infinity = InfinityType() -class NegativeInfinityType(object): - def __repr__(self): - # type: () -> str +class NegativeInfinityType: + def __repr__(self) -> str: return "-Infinity" - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash(repr(self)) - def __lt__(self, other): - # type: (object) -> bool + def __lt__(self, other: object) -> bool: return True - def __le__(self, other): - # type: (object) -> bool + def __le__(self, other: object) -> bool: return True - def __eq__(self, other): - # type: (object) -> bool + def __eq__(self, other: object) -> bool: return isinstance(other, self.__class__) - def __ne__(self, other): - # type: (object) -> bool - return not isinstance(other, self.__class__) - - def __gt__(self, other): - # type: (object) -> bool + def __gt__(self, other: object) -> bool: return False - def __ge__(self, other): - # type: (object) -> bool + def __ge__(self, other: object) -> bool: return False - def __neg__(self): - # type: (object) -> InfinityType + def __neg__(self: object) -> InfinityType: return Infinity diff --git a/env/Lib/site-packages/pip/_vendor/packaging/_typing.py b/env/Lib/site-packages/pip/_vendor/packaging/_typing.py deleted file mode 100644 index 2846133b..00000000 --- a/env/Lib/site-packages/pip/_vendor/packaging/_typing.py +++ /dev/null @@ -1,48 +0,0 @@ -"""For neatly implementing static typing in packaging. - -`mypy` - the static type analysis tool we use - uses the `typing` module, which -provides core functionality fundamental to mypy's functioning. - -Generally, `typing` would be imported at runtime and used in that fashion - -it acts as a no-op at runtime and does not have any run-time overhead by -design. - -As it turns out, `typing` is not vendorable - it uses separate sources for -Python 2/Python 3. Thus, this codebase can not expect it to be present. -To work around this, mypy allows the typing import to be behind a False-y -optional to prevent it from running at runtime and type-comments can be used -to remove the need for the types to be accessible directly during runtime. - -This module provides the False-y guard in a nicely named fashion so that a -curious maintainer can reach here to read this. - -In packaging, all static-typing related imports should be guarded as follows: - - from pip._vendor.packaging._typing import TYPE_CHECKING - - if TYPE_CHECKING: - from typing import ... - -Ref: https://github.com/python/mypy/issues/3216 -""" - -__all__ = ["TYPE_CHECKING", "cast"] - -# The TYPE_CHECKING constant defined by the typing module is False at runtime -# but True while type checking. -if False: # pragma: no cover - from typing import TYPE_CHECKING -else: - TYPE_CHECKING = False - -# typing's cast syntax requires calling typing.cast at runtime, but we don't -# want to import typing at runtime. Here, we inform the type checkers that -# we're importing `typing.cast` as `cast` and re-implement typing.cast's -# runtime behavior in a block that is ignored by type checkers. -if TYPE_CHECKING: # pragma: no cover - # not executed at runtime - from typing import cast -else: - # executed at runtime - def cast(type_, value): # noqa - return value diff --git a/env/Lib/site-packages/pip/_vendor/packaging/markers.py b/env/Lib/site-packages/pip/_vendor/packaging/markers.py index 69a60cf1..540e7a4d 100644 --- a/env/Lib/site-packages/pip/_vendor/packaging/markers.py +++ b/env/Lib/site-packages/pip/_vendor/packaging/markers.py @@ -1,12 +1,12 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from __future__ import absolute_import, division, print_function import operator import os import platform import sys +from typing import Any, Callable, Dict, List, Optional, Tuple, Union from pip._vendor.pyparsing import ( # noqa: N817 Forward, @@ -20,16 +20,8 @@ from pip._vendor.pyparsing import ( # noqa: N817 stringStart, ) -from ._compat import string_types -from ._typing import TYPE_CHECKING from .specifiers import InvalidSpecifier, Specifier -if TYPE_CHECKING: # pragma: no cover - from typing import Any, Callable, Dict, List, Optional, Tuple, Union - - Operator = Callable[[str, str], bool] - - __all__ = [ "InvalidMarker", "UndefinedComparison", @@ -38,6 +30,8 @@ __all__ = [ "default_environment", ] +Operator = Callable[[str, str], bool] + class InvalidMarker(ValueError): """ @@ -58,39 +52,32 @@ class UndefinedEnvironmentName(ValueError): """ -class Node(object): - def __init__(self, value): - # type: (Any) -> None +class Node: + def __init__(self, value: Any) -> None: self.value = value - def __str__(self): - # type: () -> str + def __str__(self) -> str: return str(self.value) - def __repr__(self): - # type: () -> str - return "<{0}({1!r})>".format(self.__class__.__name__, str(self)) + def __repr__(self) -> str: + return f"<{self.__class__.__name__}('{self}')>" - def serialize(self): - # type: () -> str + def serialize(self) -> str: raise NotImplementedError class Variable(Node): - def serialize(self): - # type: () -> str + def serialize(self) -> str: return str(self) class Value(Node): - def serialize(self): - # type: () -> str - return '"{0}"'.format(self) + def serialize(self) -> str: + return f'"{self}"' class Op(Node): - def serialize(self): - # type: () -> str + def serialize(self) -> str: return str(self) @@ -151,18 +138,18 @@ MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR) MARKER = stringStart + MARKER_EXPR + stringEnd -def _coerce_parse_result(results): - # type: (Union[ParseResults, List[Any]]) -> List[Any] +def _coerce_parse_result(results: Union[ParseResults, List[Any]]) -> List[Any]: if isinstance(results, ParseResults): return [_coerce_parse_result(i) for i in results] else: return results -def _format_marker(marker, first=True): - # type: (Union[List[str], Tuple[Node, ...], str], Optional[bool]) -> str +def _format_marker( + marker: Union[List[str], Tuple[Node, ...], str], first: Optional[bool] = True +) -> str: - assert isinstance(marker, (list, tuple, string_types)) + assert isinstance(marker, (list, tuple, str)) # Sometimes we have a structure like [[...]] which is a single item list # where the single item is itself it's own list. In that case we want skip @@ -187,7 +174,7 @@ def _format_marker(marker, first=True): return marker -_operators = { +_operators: Dict[str, Operator] = { "in": lambda lhs, rhs: lhs in rhs, "not in": lambda lhs, rhs: lhs not in rhs, "<": operator.lt, @@ -196,11 +183,10 @@ _operators = { "!=": operator.ne, ">=": operator.ge, ">": operator.gt, -} # type: Dict[str, Operator] +} -def _eval_op(lhs, op, rhs): - # type: (str, Op, str) -> bool +def _eval_op(lhs: str, op: Op, rhs: str) -> bool: try: spec = Specifier("".join([op.serialize(), rhs])) except InvalidSpecifier: @@ -208,40 +194,36 @@ def _eval_op(lhs, op, rhs): else: return spec.contains(lhs) - oper = _operators.get(op.serialize()) # type: Optional[Operator] + oper: Optional[Operator] = _operators.get(op.serialize()) if oper is None: - raise UndefinedComparison( - "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs) - ) + raise UndefinedComparison(f"Undefined {op!r} on {lhs!r} and {rhs!r}.") return oper(lhs, rhs) -class Undefined(object): +class Undefined: pass _undefined = Undefined() -def _get_env(environment, name): - # type: (Dict[str, str], str) -> str - value = environment.get(name, _undefined) # type: Union[str, Undefined] +def _get_env(environment: Dict[str, str], name: str) -> str: + value: Union[str, Undefined] = environment.get(name, _undefined) if isinstance(value, Undefined): raise UndefinedEnvironmentName( - "{0!r} does not exist in evaluation environment.".format(name) + f"{name!r} does not exist in evaluation environment." ) return value -def _evaluate_markers(markers, environment): - # type: (List[Any], Dict[str, str]) -> bool - groups = [[]] # type: List[List[bool]] +def _evaluate_markers(markers: List[Any], environment: Dict[str, str]) -> bool: + groups: List[List[bool]] = [[]] for marker in markers: - assert isinstance(marker, (list, tuple, string_types)) + assert isinstance(marker, (list, tuple, str)) if isinstance(marker, list): groups[-1].append(_evaluate_markers(marker, environment)) @@ -264,8 +246,7 @@ def _evaluate_markers(markers, environment): return any(all(item) for item in groups) -def format_full_version(info): - # type: (sys._version_info) -> str +def format_full_version(info: "sys._version_info") -> str: version = "{0.major}.{0.minor}.{0.micro}".format(info) kind = info.releaselevel if kind != "final": @@ -273,18 +254,9 @@ def format_full_version(info): return version -def default_environment(): - # type: () -> Dict[str, str] - if hasattr(sys, "implementation"): - # Ignoring the `sys.implementation` reference for type checking due to - # mypy not liking that the attribute doesn't exist in Python 2.7 when - # run with the `--py27` flag. - iver = format_full_version(sys.implementation.version) # type: ignore - implementation_name = sys.implementation.name # type: ignore - else: - iver = "0" - implementation_name = "" - +def default_environment() -> Dict[str, str]: + iver = format_full_version(sys.implementation.version) + implementation_name = sys.implementation.name return { "implementation_name": implementation_name, "implementation_version": iver, @@ -300,27 +272,23 @@ def default_environment(): } -class Marker(object): - def __init__(self, marker): - # type: (str) -> None +class Marker: + def __init__(self, marker: str) -> None: try: self._markers = _coerce_parse_result(MARKER.parseString(marker)) except ParseException as e: - err_str = "Invalid marker: {0!r}, parse error at {1!r}".format( - marker, marker[e.loc : e.loc + 8] + raise InvalidMarker( + f"Invalid marker: {marker!r}, parse error at " + f"{marker[e.loc : e.loc + 8]!r}" ) - raise InvalidMarker(err_str) - def __str__(self): - # type: () -> str + def __str__(self) -> str: return _format_marker(self._markers) - def __repr__(self): - # type: () -> str - return "<Marker({0!r})>".format(str(self)) + def __repr__(self) -> str: + return f"<Marker('{self}')>" - def evaluate(self, environment=None): - # type: (Optional[Dict[str, str]]) -> bool + def evaluate(self, environment: Optional[Dict[str, str]] = None) -> bool: """Evaluate a marker. Return the boolean from evaluating the given marker against the diff --git a/env/Lib/site-packages/pip/_vendor/packaging/requirements.py b/env/Lib/site-packages/pip/_vendor/packaging/requirements.py index c2a7fdac..1eab7dd6 100644 --- a/env/Lib/site-packages/pip/_vendor/packaging/requirements.py +++ b/env/Lib/site-packages/pip/_vendor/packaging/requirements.py @@ -1,13 +1,13 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from __future__ import absolute_import, division, print_function import re import string -import sys +import urllib.parse +from typing import List, Optional as TOptional, Set -from pip._vendor.pyparsing import ( # noqa: N817 +from pip._vendor.pyparsing import ( # noqa Combine, Literal as L, Optional, @@ -20,19 +20,9 @@ from pip._vendor.pyparsing import ( # noqa: N817 stringStart, ) -from ._typing import TYPE_CHECKING from .markers import MARKER_EXPR, Marker from .specifiers import LegacySpecifier, Specifier, SpecifierSet -if sys.version_info[0] >= 3: - from urllib import parse as urlparse # pragma: no cover -else: # pragma: no cover - import urlparse - - -if TYPE_CHECKING: # pragma: no cover - from typing import List, Optional as TOptional, Set - class InvalidRequirement(ValueError): """ @@ -70,7 +60,7 @@ VERSION_ONE = VERSION_PEP440 ^ VERSION_LEGACY VERSION_MANY = Combine( VERSION_ONE + ZeroOrMore(COMMA + VERSION_ONE), joinString=",", adjacent=False )("_raw_spec") -_VERSION_SPEC = Optional(((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY)) +_VERSION_SPEC = Optional((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY) _VERSION_SPEC.setParseAction(lambda s, l, t: t._raw_spec or "") VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier") @@ -94,7 +84,7 @@ REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd REQUIREMENT.parseString("x[]") -class Requirement(object): +class Requirement: """Parse a requirement. Parse a given requirement string into its parts, such as name, specifier, @@ -107,54 +97,50 @@ class Requirement(object): # the thing as well as the version? What about the markers? # TODO: Can we normalize the name and extra name? - def __init__(self, requirement_string): - # type: (str) -> None + def __init__(self, requirement_string: str) -> None: try: req = REQUIREMENT.parseString(requirement_string) except ParseException as e: raise InvalidRequirement( - 'Parse error at "{0!r}": {1}'.format( - requirement_string[e.loc : e.loc + 8], e.msg - ) + f'Parse error at "{ requirement_string[e.loc : e.loc + 8]!r}": {e.msg}' ) - self.name = req.name # type: str + self.name: str = req.name if req.url: - parsed_url = urlparse.urlparse(req.url) + parsed_url = urllib.parse.urlparse(req.url) if parsed_url.scheme == "file": - if urlparse.urlunparse(parsed_url) != req.url: + if urllib.parse.urlunparse(parsed_url) != req.url: raise InvalidRequirement("Invalid URL given") elif not (parsed_url.scheme and parsed_url.netloc) or ( not parsed_url.scheme and not parsed_url.netloc ): - raise InvalidRequirement("Invalid URL: {0}".format(req.url)) - self.url = req.url # type: TOptional[str] + raise InvalidRequirement(f"Invalid URL: {req.url}") + self.url: TOptional[str] = req.url else: self.url = None - self.extras = set(req.extras.asList() if req.extras else []) # type: Set[str] - self.specifier = SpecifierSet(req.specifier) # type: SpecifierSet - self.marker = req.marker if req.marker else None # type: TOptional[Marker] + self.extras: Set[str] = set(req.extras.asList() if req.extras else []) + self.specifier: SpecifierSet = SpecifierSet(req.specifier) + self.marker: TOptional[Marker] = req.marker if req.marker else None - def __str__(self): - # type: () -> str - parts = [self.name] # type: List[str] + def __str__(self) -> str: + parts: List[str] = [self.name] if self.extras: - parts.append("[{0}]".format(",".join(sorted(self.extras)))) + formatted_extras = ",".join(sorted(self.extras)) + parts.append(f"[{formatted_extras}]") if self.specifier: parts.append(str(self.specifier)) if self.url: - parts.append("@ {0}".format(self.url)) + parts.append(f"@ {self.url}") if self.marker: parts.append(" ") if self.marker: - parts.append("; {0}".format(self.marker)) + parts.append(f"; {self.marker}") return "".join(parts) - def __repr__(self): - # type: () -> str - return "<Requirement({0!r})>".format(str(self)) + def __repr__(self) -> str: + return f"<Requirement('{self}')>" diff --git a/env/Lib/site-packages/pip/_vendor/packaging/specifiers.py b/env/Lib/site-packages/pip/_vendor/packaging/specifiers.py index a6a83c1f..0e218a6f 100644 --- a/env/Lib/site-packages/pip/_vendor/packaging/specifiers.py +++ b/env/Lib/site-packages/pip/_vendor/packaging/specifiers.py @@ -1,25 +1,33 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from __future__ import absolute_import, division, print_function import abc import functools import itertools import re import warnings +from typing import ( + Callable, + Dict, + Iterable, + Iterator, + List, + Optional, + Pattern, + Set, + Tuple, + TypeVar, + Union, +) -from ._compat import string_types, with_metaclass -from ._typing import TYPE_CHECKING from .utils import canonicalize_version from .version import LegacyVersion, Version, parse -if TYPE_CHECKING: # pragma: no cover - from typing import Callable, Dict, Iterable, Iterator, List, Optional, Tuple, Union - - ParsedVersion = Union[Version, LegacyVersion] - UnparsedVersion = Union[Version, LegacyVersion, str] - CallableOperator = Callable[[ParsedVersion, str], bool] +ParsedVersion = Union[Version, LegacyVersion] +UnparsedVersion = Union[Version, LegacyVersion, str] +VersionTypeVar = TypeVar("VersionTypeVar", bound=UnparsedVersion) +CallableOperator = Callable[[ParsedVersion, str], bool] class InvalidSpecifier(ValueError): @@ -28,64 +36,51 @@ class InvalidSpecifier(ValueError): """ -class BaseSpecifier(with_metaclass(abc.ABCMeta, object)): # type: ignore +class BaseSpecifier(metaclass=abc.ABCMeta): @abc.abstractmethod - def __str__(self): - # type: () -> str + def __str__(self) -> str: """ Returns the str representation of this Specifier like object. This should be representative of the Specifier itself. """ @abc.abstractmethod - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: """ Returns a hash value for this Specifier like object. """ @abc.abstractmethod - def __eq__(self, other): - # type: (object) -> bool + def __eq__(self, other: object) -> bool: """ Returns a boolean representing whether or not the two Specifier like objects are equal. """ - @abc.abstractmethod - def __ne__(self, other): - # type: (object) -> bool - """ - Returns a boolean representing whether or not the two Specifier like - objects are not equal. - """ - @abc.abstractproperty - def prereleases(self): - # type: () -> Optional[bool] + def prereleases(self) -> Optional[bool]: """ Returns whether or not pre-releases as a whole are allowed by this specifier. """ @prereleases.setter - def prereleases(self, value): - # type: (bool) -> None + def prereleases(self, value: bool) -> None: """ Sets whether or not pre-releases as a whole are allowed by this specifier. """ @abc.abstractmethod - def contains(self, item, prereleases=None): - # type: (str, Optional[bool]) -> bool + def contains(self, item: str, prereleases: Optional[bool] = None) -> bool: """ Determines if the given item is contained within this specifier. """ @abc.abstractmethod - def filter(self, iterable, prereleases=None): - # type: (Iterable[UnparsedVersion], Optional[bool]) -> Iterable[UnparsedVersion] + def filter( + self, iterable: Iterable[VersionTypeVar], prereleases: Optional[bool] = None + ) -> Iterable[VersionTypeVar]: """ Takes an iterable of items and filters them so that only items which are contained within this specifier are allowed in it. @@ -94,48 +89,43 @@ class BaseSpecifier(with_metaclass(abc.ABCMeta, object)): # type: ignore class _IndividualSpecifier(BaseSpecifier): - _operators = {} # type: Dict[str, str] + _operators: Dict[str, str] = {} + _regex: Pattern[str] - def __init__(self, spec="", prereleases=None): - # type: (str, Optional[bool]) -> None + def __init__(self, spec: str = "", prereleases: Optional[bool] = None) -> None: match = self._regex.search(spec) if not match: - raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec)) + raise InvalidSpecifier(f"Invalid specifier: '{spec}'") - self._spec = ( + self._spec: Tuple[str, str] = ( match.group("operator").strip(), match.group("version").strip(), - ) # type: Tuple[str, str] + ) # Store whether or not this Specifier should accept prereleases self._prereleases = prereleases - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: pre = ( - ", prereleases={0!r}".format(self.prereleases) + f", prereleases={self.prereleases!r}" if self._prereleases is not None else "" ) - return "<{0}({1!r}{2})>".format(self.__class__.__name__, str(self), pre) + return f"<{self.__class__.__name__}({str(self)!r}{pre})>" - def __str__(self): - # type: () -> str - return "{0}{1}".format(*self._spec) + def __str__(self) -> str: + return "{}{}".format(*self._spec) @property - def _canonical_spec(self): - # type: () -> Tuple[str, Union[Version, str]] + def _canonical_spec(self) -> Tuple[str, str]: return self._spec[0], canonicalize_version(self._spec[1]) - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash(self._canonical_spec) - def __eq__(self, other): - # type: (object) -> bool - if isinstance(other, string_types): + def __eq__(self, other: object) -> bool: + if isinstance(other, str): try: other = self.__class__(str(other)) except InvalidSpecifier: @@ -145,57 +135,39 @@ class _IndividualSpecifier(BaseSpecifier): return self._canonical_spec == other._canonical_spec - def __ne__(self, other): - # type: (object) -> bool - if isinstance(other, string_types): - try: - other = self.__class__(str(other)) - except InvalidSpecifier: - return NotImplemented - elif not isinstance(other, self.__class__): - return NotImplemented - - return self._spec != other._spec - - def _get_operator(self, op): - # type: (str) -> CallableOperator - operator_callable = getattr( - self, "_compare_{0}".format(self._operators[op]) - ) # type: CallableOperator + def _get_operator(self, op: str) -> CallableOperator: + operator_callable: CallableOperator = getattr( + self, f"_compare_{self._operators[op]}" + ) return operator_callable - def _coerce_version(self, version): - # type: (UnparsedVersion) -> ParsedVersion + def _coerce_version(self, version: UnparsedVersion) -> ParsedVersion: if not isinstance(version, (LegacyVersion, Version)): version = parse(version) return version @property - def operator(self): - # type: () -> str + def operator(self) -> str: return self._spec[0] @property - def version(self): - # type: () -> str + def version(self) -> str: return self._spec[1] @property - def prereleases(self): - # type: () -> Optional[bool] + def prereleases(self) -> Optional[bool]: return self._prereleases @prereleases.setter - def prereleases(self, value): - # type: (bool) -> None + def prereleases(self, value: bool) -> None: self._prereleases = value - def __contains__(self, item): - # type: (str) -> bool + def __contains__(self, item: str) -> bool: return self.contains(item) - def contains(self, item, prereleases=None): - # type: (UnparsedVersion, Optional[bool]) -> bool + def contains( + self, item: UnparsedVersion, prereleases: Optional[bool] = None + ) -> bool: # Determine if prereleases are to be allowed or not. if prereleases is None: @@ -213,11 +185,12 @@ class _IndividualSpecifier(BaseSpecifier): # Actually do the comparison to determine if this item is contained # within this Specifier or not. - operator_callable = self._get_operator(self.operator) # type: CallableOperator + operator_callable: CallableOperator = self._get_operator(self.operator) return operator_callable(normalized_item, self.version) - def filter(self, iterable, prereleases=None): - # type: (Iterable[UnparsedVersion], Optional[bool]) -> Iterable[UnparsedVersion] + def filter( + self, iterable: Iterable[VersionTypeVar], prereleases: Optional[bool] = None + ) -> Iterable[VersionTypeVar]: yielded = False found_prereleases = [] @@ -231,7 +204,7 @@ class _IndividualSpecifier(BaseSpecifier): if self.contains(parsed_version, **kw): # If our version is a prerelease, and we were not set to allow - # prereleases, then we'll store it for later incase nothing + # prereleases, then we'll store it for later in case nothing # else matches this specifier. if parsed_version.is_prerelease and not ( prereleases or self.prereleases @@ -276,9 +249,8 @@ class LegacySpecifier(_IndividualSpecifier): ">": "greater_than", } - def __init__(self, spec="", prereleases=None): - # type: (str, Optional[bool]) -> None - super(LegacySpecifier, self).__init__(spec, prereleases) + def __init__(self, spec: str = "", prereleases: Optional[bool] = None) -> None: + super().__init__(spec, prereleases) warnings.warn( "Creating a LegacyVersion has been deprecated and will be " @@ -286,44 +258,37 @@ class LegacySpecifier(_IndividualSpecifier): DeprecationWarning, ) - def _coerce_version(self, version): - # type: (Union[ParsedVersion, str]) -> LegacyVersion + def _coerce_version(self, version: UnparsedVersion) -> LegacyVersion: if not isinstance(version, LegacyVersion): version = LegacyVersion(str(version)) return version - def _compare_equal(self, prospective, spec): - # type: (LegacyVersion, str) -> bool + def _compare_equal(self, prospective: LegacyVersion, spec: str) -> bool: return prospective == self._coerce_version(spec) - def _compare_not_equal(self, prospective, spec): - # type: (LegacyVersion, str) -> bool + def _compare_not_equal(self, prospective: LegacyVersion, spec: str) -> bool: return prospective != self._coerce_version(spec) - def _compare_less_than_equal(self, prospective, spec): - # type: (LegacyVersion, str) -> bool + def _compare_less_than_equal(self, prospective: LegacyVersion, spec: str) -> bool: return prospective <= self._coerce_version(spec) - def _compare_greater_than_equal(self, prospective, spec): - # type: (LegacyVersion, str) -> bool + def _compare_greater_than_equal( + self, prospective: LegacyVersion, spec: str + ) -> bool: return prospective >= self._coerce_version(spec) - def _compare_less_than(self, prospective, spec): - # type: (LegacyVersion, str) -> bool + def _compare_less_than(self, prospective: LegacyVersion, spec: str) -> bool: return prospective < self._coerce_version(spec) - def _compare_greater_than(self, prospective, spec): - # type: (LegacyVersion, str) -> bool + def _compare_greater_than(self, prospective: LegacyVersion, spec: str) -> bool: return prospective > self._coerce_version(spec) def _require_version_compare( - fn, # type: (Callable[[Specifier, ParsedVersion, str], bool]) -): - # type: (...) -> Callable[[Specifier, ParsedVersion, str], bool] + fn: Callable[["Specifier", ParsedVersion, str], bool] +) -> Callable[["Specifier", ParsedVersion, str], bool]: @functools.wraps(fn) - def wrapped(self, prospective, spec): - # type: (Specifier, ParsedVersion, str) -> bool + def wrapped(self: "Specifier", prospective: ParsedVersion, spec: str) -> bool: if not isinstance(prospective, Version): return False return fn(self, prospective, spec) @@ -440,8 +405,7 @@ class Specifier(_IndividualSpecifier): } @_require_version_compare - def _compare_compatible(self, prospective, spec): - # type: (ParsedVersion, str) -> bool + def _compare_compatible(self, prospective: ParsedVersion, spec: str) -> bool: # Compatible releases have an equivalent combination of >= and ==. That # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to @@ -450,15 +414,9 @@ class Specifier(_IndividualSpecifier): # the other specifiers. # We want everything but the last item in the version, but we want to - # ignore post and dev releases and we want to treat the pre-release as - # it's own separate segment. + # ignore suffix segments. prefix = ".".join( - list( - itertools.takewhile( - lambda x: (not x.startswith("post") and not x.startswith("dev")), - _version_split(spec), - ) - )[:-1] + list(itertools.takewhile(_is_not_suffix, _version_split(spec)))[:-1] ) # Add the prefix notation to the end of our string @@ -469,8 +427,7 @@ class Specifier(_IndividualSpecifier): ) @_require_version_compare - def _compare_equal(self, prospective, spec): - # type: (ParsedVersion, str) -> bool + def _compare_equal(self, prospective: ParsedVersion, spec: str) -> bool: # We need special logic to handle prefix matching if spec.endswith(".*"): @@ -510,13 +467,11 @@ class Specifier(_IndividualSpecifier): return prospective == spec_version @_require_version_compare - def _compare_not_equal(self, prospective, spec): - # type: (ParsedVersion, str) -> bool + def _compare_not_equal(self, prospective: ParsedVersion, spec: str) -> bool: return not self._compare_equal(prospective, spec) @_require_version_compare - def _compare_less_than_equal(self, prospective, spec): - # type: (ParsedVersion, str) -> bool + def _compare_less_than_equal(self, prospective: ParsedVersion, spec: str) -> bool: # NB: Local version identifiers are NOT permitted in the version # specifier, so local version labels can be universally removed from @@ -524,8 +479,9 @@ class Specifier(_IndividualSpecifier): return Version(prospective.public) <= Version(spec) @_require_version_compare - def _compare_greater_than_equal(self, prospective, spec): - # type: (ParsedVersion, str) -> bool + def _compare_greater_than_equal( + self, prospective: ParsedVersion, spec: str + ) -> bool: # NB: Local version identifiers are NOT permitted in the version # specifier, so local version labels can be universally removed from @@ -533,8 +489,7 @@ class Specifier(_IndividualSpecifier): return Version(prospective.public) >= Version(spec) @_require_version_compare - def _compare_less_than(self, prospective, spec_str): - # type: (ParsedVersion, str) -> bool + def _compare_less_than(self, prospective: ParsedVersion, spec_str: str) -> bool: # Convert our spec to a Version instance, since we'll want to work with # it as a version. @@ -560,8 +515,7 @@ class Specifier(_IndividualSpecifier): return True @_require_version_compare - def _compare_greater_than(self, prospective, spec_str): - # type: (ParsedVersion, str) -> bool + def _compare_greater_than(self, prospective: ParsedVersion, spec_str: str) -> bool: # Convert our spec to a Version instance, since we'll want to work with # it as a version. @@ -592,13 +546,11 @@ class Specifier(_IndividualSpecifier): # same version in the spec. return True - def _compare_arbitrary(self, prospective, spec): - # type: (Version, str) -> bool + def _compare_arbitrary(self, prospective: Version, spec: str) -> bool: return str(prospective).lower() == str(spec).lower() @property - def prereleases(self): - # type: () -> bool + def prereleases(self) -> bool: # If there is an explicit prereleases set for this, then we'll just # blindly use that. @@ -623,17 +575,15 @@ class Specifier(_IndividualSpecifier): return False @prereleases.setter - def prereleases(self, value): - # type: (bool) -> None + def prereleases(self, value: bool) -> None: self._prereleases = value _prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$") -def _version_split(version): - # type: (str) -> List[str] - result = [] # type: List[str] +def _version_split(version: str) -> List[str]: + result: List[str] = [] for item in version.split("."): match = _prefix_regex.search(item) if match: @@ -643,8 +593,13 @@ def _version_split(version): return result -def _pad_version(left, right): - # type: (List[str], List[str]) -> Tuple[List[str], List[str]] +def _is_not_suffix(segment: str) -> bool: + return not any( + segment.startswith(prefix) for prefix in ("dev", "a", "b", "rc", "post") + ) + + +def _pad_version(left: List[str], right: List[str]) -> Tuple[List[str], List[str]]: left_split, right_split = [], [] # Get the release segment of our versions @@ -663,8 +618,9 @@ def _pad_version(left, right): class SpecifierSet(BaseSpecifier): - def __init__(self, specifiers="", prereleases=None): - # type: (str, Optional[bool]) -> None + def __init__( + self, specifiers: str = "", prereleases: Optional[bool] = None + ) -> None: # Split on , to break each individual specifier into it's own item, and # strip each item to remove leading/trailing whitespace. @@ -672,7 +628,7 @@ class SpecifierSet(BaseSpecifier): # Parsed each individual specifier, attempting first to make it a # Specifier and falling back to a LegacySpecifier. - parsed = set() + parsed: Set[_IndividualSpecifier] = set() for specifier in split_specifiers: try: parsed.add(Specifier(specifier)) @@ -686,27 +642,23 @@ class SpecifierSet(BaseSpecifier): # we accept prereleases or not. self._prereleases = prereleases - def __repr__(self): - # type: () -> str + def __repr__(self) -> str: pre = ( - ", prereleases={0!r}".format(self.prereleases) + f", prereleases={self.prereleases!r}" if self._prereleases is not None else "" ) - return "<SpecifierSet({0!r}{1})>".format(str(self), pre) + return f"<SpecifierSet({str(self)!r}{pre})>" - def __str__(self): - # type: () -> str + def __str__(self) -> str: return ",".join(sorted(str(s) for s in self._specs)) - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash(self._specs) - def __and__(self, other): - # type: (Union[SpecifierSet, str]) -> SpecifierSet - if isinstance(other, string_types): + def __and__(self, other: Union["SpecifierSet", str]) -> "SpecifierSet": + if isinstance(other, str): other = SpecifierSet(other) elif not isinstance(other, SpecifierSet): return NotImplemented @@ -728,35 +680,22 @@ class SpecifierSet(BaseSpecifier): return specifier - def __eq__(self, other): - # type: (object) -> bool - if isinstance(other, (string_types, _IndividualSpecifier)): + def __eq__(self, other: object) -> bool: + if isinstance(other, (str, _IndividualSpecifier)): other = SpecifierSet(str(other)) elif not isinstance(other, SpecifierSet): return NotImplemented return self._specs == other._specs - def __ne__(self, other): - # type: (object) -> bool - if isinstance(other, (string_types, _IndividualSpecifier)): - other = SpecifierSet(str(other)) - elif not isinstance(other, SpecifierSet): - return NotImplemented - - return self._specs != other._specs - - def __len__(self): - # type: () -> int + def __len__(self) -> int: return len(self._specs) - def __iter__(self): - # type: () -> Iterator[_IndividualSpecifier] + def __iter__(self) -> Iterator[_IndividualSpecifier]: return iter(self._specs) @property - def prereleases(self): - # type: () -> Optional[bool] + def prereleases(self) -> Optional[bool]: # If we have been given an explicit prerelease modifier, then we'll # pass that through here. @@ -774,16 +713,15 @@ class SpecifierSet(BaseSpecifier): return any(s.prereleases for s in self._specs) @prereleases.setter - def prereleases(self, value): - # type: (bool) -> None + def prereleases(self, value: bool) -> None: self._prereleases = value - def __contains__(self, item): - # type: (Union[ParsedVersion, str]) -> bool + def __contains__(self, item: UnparsedVersion) -> bool: return self.contains(item) - def contains(self, item, prereleases=None): - # type: (Union[ParsedVersion, str], Optional[bool]) -> bool + def contains( + self, item: UnparsedVersion, prereleases: Optional[bool] = None + ) -> bool: # Ensure that our item is a Version or LegacyVersion instance. if not isinstance(item, (LegacyVersion, Version)): @@ -811,11 +749,8 @@ class SpecifierSet(BaseSpecifier): return all(s.contains(item, prereleases=prereleases) for s in self._specs) def filter( - self, - iterable, # type: Iterable[Union[ParsedVersion, str]] - prereleases=None, # type: Optional[bool] - ): - # type: (...) -> Iterable[Union[ParsedVersion, str]] + self, iterable: Iterable[VersionTypeVar], prereleases: Optional[bool] = None + ) -> Iterable[VersionTypeVar]: # Determine if we're forcing a prerelease or not, if we're not forcing # one for this particular filter call, then we'll use whatever the @@ -834,8 +769,11 @@ class SpecifierSet(BaseSpecifier): # which will filter out any pre-releases, unless there are no final # releases, and which will filter out LegacyVersion in general. else: - filtered = [] # type: List[Union[ParsedVersion, str]] - found_prereleases = [] # type: List[Union[ParsedVersion, str]] + filtered: List[VersionTypeVar] = [] + found_prereleases: List[VersionTypeVar] = [] + + item: UnparsedVersion + parsed_version: Union[Version, LegacyVersion] for item in iterable: # Ensure that we some kind of Version class for this item. diff --git a/env/Lib/site-packages/pip/_vendor/packaging/tags.py b/env/Lib/site-packages/pip/_vendor/packaging/tags.py index d637f1b6..9a3d25a7 100644 --- a/env/Lib/site-packages/pip/_vendor/packaging/tags.py +++ b/env/Lib/site-packages/pip/_vendor/packaging/tags.py @@ -2,81 +2,44 @@ # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from __future__ import absolute_import - -import distutils.util - -try: - from importlib.machinery import EXTENSION_SUFFIXES -except ImportError: # pragma: no cover - import imp - - EXTENSION_SUFFIXES = [x[0] for x in imp.get_suffixes()] - del imp -import collections import logging -import os import platform -import re -import struct import sys import sysconfig -import warnings - -from ._typing import TYPE_CHECKING, cast - -if TYPE_CHECKING: # pragma: no cover - from typing import ( - IO, - Dict, - FrozenSet, - Iterable, - Iterator, - List, - Optional, - Sequence, - Tuple, - Union, - ) - - PythonVersion = Sequence[int] - MacVersion = Tuple[int, int] - GlibcVersion = Tuple[int, int] - +from importlib.machinery import EXTENSION_SUFFIXES +from typing import ( + Dict, + FrozenSet, + Iterable, + Iterator, + List, + Optional, + Sequence, + Tuple, + Union, + cast, +) + +from . import _manylinux, _musllinux logger = logging.getLogger(__name__) -INTERPRETER_SHORT_NAMES = { +PythonVersion = Sequence[int] +MacVersion = Tuple[int, int] + +INTERPRETER_SHORT_NAMES: Dict[str, str] = { "python": "py", # Generic. "cpython": "cp", "pypy": "pp", "ironpython": "ip", "jython": "jy", -} # type: Dict[str, str] +} _32_BIT_INTERPRETER = sys.maxsize <= 2 ** 32 -_LEGACY_MANYLINUX_MAP = { - # CentOS 7 w/ glibc 2.17 (PEP 599) - (2, 17): "manylinux2014", - # CentOS 6 w/ glibc 2.12 (PEP 571) - (2, 12): "manylinux2010", - # CentOS 5 w/ glibc 2.5 (PEP 513) - (2, 5): "manylinux1", -} - -# If glibc ever changes its major version, we need to know what the last -# minor version was, so we can build the complete list of all versions. -# For now, guess what the highest minor version might be, assume it will -# be 50 for testing. Once this actually happens, update the dictionary -# with the actual value. -_LAST_GLIBC_MINOR = collections.defaultdict(lambda: 50) # type: Dict[int, int] -glibcVersion = collections.namedtuple("Version", ["major", "minor"]) - - -class Tag(object): +class Tag: """ A representation of the tag triple for a wheel. @@ -86,8 +49,7 @@ class Tag(object): __slots__ = ["_interpreter", "_abi", "_platform", "_hash"] - def __init__(self, interpreter, abi, platform): - # type: (str, str, str) -> None + def __init__(self, interpreter: str, abi: str, platform: str) -> None: self._interpreter = interpreter.lower() self._abi = abi.lower() self._platform = platform.lower() @@ -99,46 +61,39 @@ class Tag(object): self._hash = hash((self._interpreter, self._abi, self._platform)) @property - def interpreter(self): - # type: () -> str + def interpreter(self) -> str: return self._interpreter @property - def abi(self): - # type: () -> str + def abi(self) -> str: return self._abi @property - def platform(self): - # type: () -> str + def platform(self) -> str: return self._platform - def __eq__(self, other): - # type: (object) -> bool + def __eq__(self, other: object) -> bool: if not isinstance(other, Tag): return NotImplemented return ( - (self.platform == other.platform) - and (self.abi == other.abi) - and (self.interpreter == other.interpreter) + (self._hash == other._hash) # Short-circuit ASAP for perf reasons. + and (self._platform == other._platform) + and (self._abi == other._abi) + and (self._interpreter == other._interpreter) ) - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return self._hash - def __str__(self): - # type: () -> str - return "{}-{}-{}".format(self._interpreter, self._abi, self._platform) + def __str__(self) -> str: + return f"{self._interpreter}-{self._abi}-{self._platform}" - def __repr__(self): - # type: () -> str - return "<{self} @ {self_id}>".format(self=self, self_id=id(self)) + def __repr__(self) -> str: + return f"<{self} @ {id(self)}>" -def parse_tag(tag): - # type: (str) -> FrozenSet[Tag] +def parse_tag(tag: str) -> FrozenSet[Tag]: """ Parses the provided tag (e.g. `py3-none-any`) into a frozenset of Tag instances. @@ -154,24 +109,7 @@ def parse_tag(tag): return frozenset(tags) -def _warn_keyword_parameter(func_name, kwargs): - # type: (str, Dict[str, bool]) -> bool - """ - Backwards-compatibility with Python 2.7 to allow treating 'warn' as keyword-only. - """ - if not kwargs: - return False - elif len(kwargs) > 1 or "warn" not in kwargs: - kwargs.pop("warn", None) - arg = next(iter(kwargs.keys())) - raise TypeError( - "{}() got an unexpected keyword argument {!r}".format(func_name, arg) - ) - return kwargs["warn"] - - -def _get_config_var(name, warn=False): - # type: (str, bool) -> Union[int, str, None] +def _get_config_var(name: str, warn: bool = False) -> Union[int, str, None]: value = sysconfig.get_config_var(name) if value is None and warn: logger.debug( @@ -180,13 +118,11 @@ def _get_config_var(name, warn=False): return value -def _normalize_string(string): - # type: (str) -> str +def _normalize_string(string: str) -> str: return string.replace(".", "_").replace("-", "_") -def _abi3_applies(python_version): - # type: (PythonVersion) -> bool +def _abi3_applies(python_version: PythonVersion) -> bool: """ Determine if the Python version supports abi3. @@ -195,8 +131,7 @@ def _abi3_applies(python_version): return len(python_version) > 1 and tuple(python_version) >= (3, 2) -def _cpython_abis(py_version, warn=False): - # type: (PythonVersion, bool) -> List[str] +def _cpython_abis(py_version: PythonVersion, warn: bool = False) -> List[str]: py_version = tuple(py_version) # To allow for version comparison. abis = [] version = _version_nodot(py_version[:2]) @@ -222,7 +157,7 @@ def _cpython_abis(py_version, warn=False): elif debug: # Debug builds can also load "normal" extension modules. # We can also assume no UCS-4 or pymalloc requirement. - abis.append("cp{version}".format(version=version)) + abis.append(f"cp{version}") abis.insert( 0, "cp{version}{debug}{pymalloc}{ucs4}".format( @@ -233,12 +168,12 @@ def _cpython_abis(py_version, warn=False): def cpython_tags( - python_version=None, # type: Optional[PythonVersion] - abis=None, # type: Optional[Iterable[str]] - platforms=None, # type: Optional[Iterable[str]] - **kwargs # type: bool -): - # type: (...) -> Iterator[Tag] + python_version: Optional[PythonVersion] = None, + abis: Optional[Iterable[str]] = None, + platforms: Optional[Iterable[str]] = None, + *, + warn: bool = False, +) -> Iterator[Tag]: """ Yields the tags for a CPython interpreter. @@ -254,11 +189,10 @@ def cpython_tags( If 'abi3' or 'none' are specified in 'abis' then they will be yielded at their normal position and not at the beginning. """ - warn = _warn_keyword_parameter("cpython_tags", kwargs) if not python_version: python_version = sys.version_info[:2] - interpreter = "cp{}".format(_version_nodot(python_version[:2])) + interpreter = f"cp{_version_nodot(python_version[:2])}" if abis is None: if len(python_version) > 1: @@ -273,15 +207,13 @@ def cpython_tags( except ValueError: pass - platforms = list(platforms or _platform_tags()) + platforms = list(platforms or platform_tags()) for abi in abis: for platform_ in platforms: yield Tag(interpreter, abi, platform_) if _abi3_applies(python_version): - for tag in (Tag(interpreter, "abi3", platform_) for platform_ in platforms): - yield tag - for tag in (Tag(interpreter, "none", platform_) for platform_ in platforms): - yield tag + yield from (Tag(interpreter, "abi3", platform_) for platform_ in platforms) + yield from (Tag(interpreter, "none", platform_) for platform_ in platforms) if _abi3_applies(python_version): for minor_version in range(python_version[1] - 1, 1, -1): @@ -292,20 +224,19 @@ def cpython_tags( yield Tag(interpreter, "abi3", platform_) -def _generic_abi(): - # type: () -> Iterator[str] +def _generic_abi() -> Iterator[str]: abi = sysconfig.get_config_var("SOABI") if abi: yield _normalize_string(abi) def generic_tags( - interpreter=None, # type: Optional[str] - abis=None, # type: Optional[Iterable[str]] - platforms=None, # type: Optional[Iterable[str]] - **kwargs # type: bool -): - # type: (...) -> Iterator[Tag] + interpreter: Optional[str] = None, + abis: Optional[Iterable[str]] = None, + platforms: Optional[Iterable[str]] = None, + *, + warn: bool = False, +) -> Iterator[Tag]: """ Yields the tags for a generic interpreter. @@ -314,14 +245,13 @@ def generic_tags( The "none" ABI will be added if it was not explicitly provided. """ - warn = _warn_keyword_parameter("generic_tags", kwargs) if not interpreter: interp_name = interpreter_name() interp_version = interpreter_version(warn=warn) interpreter = "".join([interp_name, interp_version]) if abis is None: abis = _generic_abi() - platforms = list(platforms or _platform_tags()) + platforms = list(platforms or platform_tags()) abis = list(abis) if "none" not in abis: abis.append("none") @@ -330,8 +260,7 @@ def generic_tags( yield Tag(interpreter, abi, platform_) -def _py_interpreter_range(py_version): - # type: (PythonVersion) -> Iterator[str] +def _py_interpreter_range(py_version: PythonVersion) -> Iterator[str]: """ Yields Python versions in descending order. @@ -339,19 +268,18 @@ def _py_interpreter_range(py_version): all previous versions of that major version. """ if len(py_version) > 1: - yield "py{version}".format(version=_version_nodot(py_version[:2])) - yield "py{major}".format(major=py_version[0]) + yield f"py{_version_nodot(py_version[:2])}" + yield f"py{py_version[0]}" if len(py_version) > 1: for minor in range(py_version[1] - 1, -1, -1): - yield "py{version}".format(version=_version_nodot((py_version[0], minor))) + yield f"py{_version_nodot((py_version[0], minor))}" def compatible_tags( - python_version=None, # type: Optional[PythonVersion] - interpreter=None, # type: Optional[str] - platforms=None, # type: Optional[Iterable[str]] -): - # type: (...) -> Iterator[Tag] + python_version: Optional[PythonVersion] = None, + interpreter: Optional[str] = None, + platforms: Optional[Iterable[str]] = None, +) -> Iterator[Tag]: """ Yields the sequence of tags that are compatible with a specific version of Python. @@ -362,7 +290,7 @@ def compatible_tags( """ if not python_version: python_version = sys.version_info[:2] - platforms = list(platforms or _platform_tags()) + platforms = list(platforms or platform_tags()) for version in _py_interpreter_range(python_version): for platform_ in platforms: yield Tag(version, "none", platform_) @@ -372,8 +300,7 @@ def compatible_tags( yield Tag(version, "none", "any") -def _mac_arch(arch, is_32bit=_32_BIT_INTERPRETER): - # type: (str, bool) -> str +def _mac_arch(arch: str, is_32bit: bool = _32_BIT_INTERPRETER) -> str: if not is_32bit: return arch @@ -383,8 +310,7 @@ def _mac_arch(arch, is_32bit=_32_BIT_INTERPRETER): return "i386" -def _mac_binary_formats(version, cpu_arch): - # type: (MacVersion, str) -> List[str] +def _mac_binary_formats(version: MacVersion, cpu_arch: str) -> List[str]: formats = [cpu_arch] if cpu_arch == "x86_64": if version < (10, 4): @@ -416,8 +342,9 @@ def _mac_binary_formats(version, cpu_arch): return formats -def mac_platforms(version=None, arch=None): - # type: (Optional[MacVersion], Optional[str]) -> Iterator[str] +def mac_platforms( + version: Optional[MacVersion] = None, arch: Optional[str] = None +) -> Iterator[str]: """ Yields the platform tags for a macOS system. @@ -426,7 +353,7 @@ def mac_platforms(version=None, arch=None): generate platform tags for. Both parameters default to the appropriate value for the current system. """ - version_str, _, cpu_arch = platform.mac_ver() # type: ignore + version_str, _, cpu_arch = platform.mac_ver() if version is None: version = cast("MacVersion", tuple(map(int, version_str.split(".")[:2]))) else: @@ -487,320 +414,24 @@ def mac_platforms(version=None, arch=None): ) -# From PEP 513, PEP 600 -def _is_manylinux_compatible(name, arch, glibc_version): - # type: (str, str, GlibcVersion) -> bool - sys_glibc = _get_glibc_version() - if sys_glibc < glibc_version: - return False - # Check for presence of _manylinux module. - try: - import _manylinux # noqa - except ImportError: - pass - else: - if hasattr(_manylinux, "manylinux_compatible"): - result = _manylinux.manylinux_compatible( - glibc_version[0], glibc_version[1], arch - ) - if result is not None: - return bool(result) - else: - if glibc_version == (2, 5): - if hasattr(_manylinux, "manylinux1_compatible"): - return bool(_manylinux.manylinux1_compatible) - if glibc_version == (2, 12): - if hasattr(_manylinux, "manylinux2010_compatible"): - return bool(_manylinux.manylinux2010_compatible) - if glibc_version == (2, 17): - if hasattr(_manylinux, "manylinux2014_compatible"): - return bool(_manylinux.manylinux2014_compatible) - return True - - -def _glibc_version_string(): - # type: () -> Optional[str] - # Returns glibc version string, or None if not using glibc. - return _glibc_version_string_confstr() or _glibc_version_string_ctypes() - - -def _glibc_version_string_confstr(): - # type: () -> Optional[str] - """ - Primary implementation of glibc_version_string using os.confstr. - """ - # os.confstr is quite a bit faster than ctypes.DLL. It's also less likely - # to be broken or missing. This strategy is used in the standard library - # platform module. - # https://github.com/python/cpython/blob/fcf1d003bf4f0100c9d0921ff3d70e1127ca1b71/Lib/platform.py#L175-L183 - try: - # os.confstr("CS_GNU_LIBC_VERSION") returns a string like "glibc 2.17". - version_string = os.confstr( # type: ignore[attr-defined] # noqa: F821 - "CS_GNU_LIBC_VERSION" - ) - assert version_string is not None - _, version = version_string.split() # type: Tuple[str, str] - except (AssertionError, AttributeError, OSError, ValueError): - # os.confstr() or CS_GNU_LIBC_VERSION not available (or a bad value)... - return None - return version - - -def _glibc_version_string_ctypes(): - # type: () -> Optional[str] - """ - Fallback implementation of glibc_version_string using ctypes. - """ - try: - import ctypes - except ImportError: - return None - - # ctypes.CDLL(None) internally calls dlopen(NULL), and as the dlopen - # manpage says, "If filename is NULL, then the returned handle is for the - # main program". This way we can let the linker do the work to figure out - # which libc our process is actually using. - # - # We must also handle the special case where the executable is not a - # dynamically linked executable. This can occur when using musl libc, - # for example. In this situation, dlopen() will error, leading to an - # OSError. Interestingly, at least in the case of musl, there is no - # errno set on the OSError. The single string argument used to construct - # OSError comes from libc itself and is therefore not portable to - # hard code here. In any case, failure to call dlopen() means we - # can proceed, so we bail on our attempt. - try: - # Note: typeshed is wrong here so we are ignoring this line. - process_namespace = ctypes.CDLL(None) # type: ignore - except OSError: - return None - - try: - gnu_get_libc_version = process_namespace.gnu_get_libc_version - except AttributeError: - # Symbol doesn't exist -> therefore, we are not linked to - # glibc. - return None - - # Call gnu_get_libc_version, which returns a string like "2.5" - gnu_get_libc_version.restype = ctypes.c_char_p - version_str = gnu_get_libc_version() # type: str - # py2 / py3 compatibility: - if not isinstance(version_str, str): - version_str = version_str.decode("ascii") - - return version_str - - -def _parse_glibc_version(version_str): - # type: (str) -> Tuple[int, int] - # Parse glibc version. - # - # We use a regexp instead of str.split because we want to discard any - # random junk that might come after the minor version -- this might happen - # in patched/forked versions of glibc (e.g. Linaro's version of glibc - # uses version strings like "2.20-2014.11"). See gh-3588. - m = re.match(r"(?P<major>[0-9]+)\.(?P<minor>[0-9]+)", version_str) - if not m: - warnings.warn( - "Expected glibc version with 2 components major.minor," - " got: %s" % version_str, - RuntimeWarning, - ) - return -1, -1 - return (int(m.group("major")), int(m.group("minor"))) - - -_glibc_version = [] # type: List[Tuple[int, int]] - - -def _get_glibc_version(): - # type: () -> Tuple[int, int] - if _glibc_version: - return _glibc_version[0] - version_str = _glibc_version_string() - if version_str is None: - _glibc_version.append((-1, -1)) - else: - _glibc_version.append(_parse_glibc_version(version_str)) - return _glibc_version[0] - - -# Python does not provide platform information at sufficient granularity to -# identify the architecture of the running executable in some cases, so we -# determine it dynamically by reading the information from the running -# process. This only applies on Linux, which uses the ELF format. -class _ELFFileHeader(object): - # https://en.wikipedia.org/wiki/Executable_and_Linkable_Format#File_header - class _InvalidELFFileHeader(ValueError): - """ - An invalid ELF file header was found. - """ - - ELF_MAGIC_NUMBER = 0x7F454C46 - ELFCLASS32 = 1 - ELFCLASS64 = 2 - ELFDATA2LSB = 1 - ELFDATA2MSB = 2 - EM_386 = 3 - EM_S390 = 22 - EM_ARM = 40 - EM_X86_64 = 62 - EF_ARM_ABIMASK = 0xFF000000 - EF_ARM_ABI_VER5 = 0x05000000 - EF_ARM_ABI_FLOAT_HARD = 0x00000400 - - def __init__(self, file): - # type: (IO[bytes]) -> None - def unpack(fmt): - # type: (str) -> int - try: - (result,) = struct.unpack( - fmt, file.read(struct.calcsize(fmt)) - ) # type: (int, ) - except struct.error: - raise _ELFFileHeader._InvalidELFFileHeader() - return result - - self.e_ident_magic = unpack(">I") - if self.e_ident_magic != self.ELF_MAGIC_NUMBER: - raise _ELFFileHeader._InvalidELFFileHeader() - self.e_ident_class = unpack("B") - if self.e_ident_class not in {self.ELFCLASS32, self.ELFCLASS64}: - raise _ELFFileHeader._InvalidELFFileHeader() - self.e_ident_data = unpack("B") - if self.e_ident_data not in {self.ELFDATA2LSB, self.ELFDATA2MSB}: - raise _ELFFileHeader._InvalidELFFileHeader() - self.e_ident_version = unpack("B") - self.e_ident_osabi = unpack("B") - self.e_ident_abiversion = unpack("B") - self.e_ident_pad = file.read(7) - format_h = "<H" if self.e_ident_data == self.ELFDATA2LSB else ">H" - format_i = "<I" if self.e_ident_data == self.ELFDATA2LSB else ">I" - format_q = "<Q" if self.e_ident_data == self.ELFDATA2LSB else ">Q" - format_p = format_i if self.e_ident_class == self.ELFCLASS32 else format_q - self.e_type = unpack(format_h) - self.e_machine = unpack(format_h) - self.e_version = unpack(format_i) - self.e_entry = unpack(format_p) - self.e_phoff = unpack(format_p) - self.e_shoff = unpack(format_p) - self.e_flags = unpack(format_i) - self.e_ehsize = unpack(format_h) - self.e_phentsize = unpack(format_h) - self.e_phnum = unpack(format_h) - self.e_shentsize = unpack(format_h) - self.e_shnum = unpack(format_h) - self.e_shstrndx = unpack(format_h) - - -def _get_elf_header(): - # type: () -> Optional[_ELFFileHeader] - try: - with open(sys.executable, "rb") as f: - elf_header = _ELFFileHeader(f) - except (IOError, OSError, TypeError, _ELFFileHeader._InvalidELFFileHeader): - return None - return elf_header - - -def _is_linux_armhf(): - # type: () -> bool - # hard-float ABI can be detected from the ELF header of the running - # process - # https://static.docs.arm.com/ihi0044/g/aaelf32.pdf - elf_header = _get_elf_header() - if elf_header is None: - return False - result = elf_header.e_ident_class == elf_header.ELFCLASS32 - result &= elf_header.e_ident_data == elf_header.ELFDATA2LSB - result &= elf_header.e_machine == elf_header.EM_ARM - result &= ( - elf_header.e_flags & elf_header.EF_ARM_ABIMASK - ) == elf_header.EF_ARM_ABI_VER5 - result &= ( - elf_header.e_flags & elf_header.EF_ARM_ABI_FLOAT_HARD - ) == elf_header.EF_ARM_ABI_FLOAT_HARD - return result - - -def _is_linux_i686(): - # type: () -> bool - elf_header = _get_elf_header() - if elf_header is None: - return False - result = elf_header.e_ident_class == elf_header.ELFCLASS32 - result &= elf_header.e_ident_data == elf_header.ELFDATA2LSB - result &= elf_header.e_machine == elf_header.EM_386 - return result - - -def _have_compatible_manylinux_abi(arch): - # type: (str) -> bool - if arch == "armv7l": - return _is_linux_armhf() - if arch == "i686": - return _is_linux_i686() - return arch in {"x86_64", "aarch64", "ppc64", "ppc64le", "s390x"} - - -def _manylinux_tags(linux, arch): - # type: (str, str) -> Iterator[str] - # Oldest glibc to be supported regardless of architecture is (2, 17). - too_old_glibc2 = glibcVersion(2, 16) - if arch in {"x86_64", "i686"}: - # On x86/i686 also oldest glibc to be supported is (2, 5). - too_old_glibc2 = glibcVersion(2, 4) - current_glibc = glibcVersion(*_get_glibc_version()) - glibc_max_list = [current_glibc] - # We can assume compatibility across glibc major versions. - # https://sourceware.org/bugzilla/show_bug.cgi?id=24636 - # - # Build a list of maximum glibc versions so that we can - # output the canonical list of all glibc from current_glibc - # down to too_old_glibc2, including all intermediary versions. - for glibc_major in range(current_glibc.major - 1, 1, -1): - glibc_max_list.append(glibcVersion(glibc_major, _LAST_GLIBC_MINOR[glibc_major])) - for glibc_max in glibc_max_list: - if glibc_max.major == too_old_glibc2.major: - min_minor = too_old_glibc2.minor - else: - # For other glibc major versions oldest supported is (x, 0). - min_minor = -1 - for glibc_minor in range(glibc_max.minor, min_minor, -1): - glibc_version = (glibc_max.major, glibc_minor) - tag = "manylinux_{}_{}".format(*glibc_version) - if _is_manylinux_compatible(tag, arch, glibc_version): - yield linux.replace("linux", tag) - # Handle the legacy manylinux1, manylinux2010, manylinux2014 tags. - if glibc_version in _LEGACY_MANYLINUX_MAP: - legacy_tag = _LEGACY_MANYLINUX_MAP[glibc_version] - if _is_manylinux_compatible(legacy_tag, arch, glibc_version): - yield linux.replace("linux", legacy_tag) - - -def _linux_platforms(is_32bit=_32_BIT_INTERPRETER): - # type: (bool) -> Iterator[str] - linux = _normalize_string(distutils.util.get_platform()) +def _linux_platforms(is_32bit: bool = _32_BIT_INTERPRETER) -> Iterator[str]: + linux = _normalize_string(sysconfig.get_platform()) if is_32bit: if linux == "linux_x86_64": linux = "linux_i686" elif linux == "linux_aarch64": linux = "linux_armv7l" _, arch = linux.split("_", 1) - if _have_compatible_manylinux_abi(arch): - for tag in _manylinux_tags(linux, arch): - yield tag + yield from _manylinux.platform_tags(linux, arch) + yield from _musllinux.platform_tags(arch) yield linux -def _generic_platforms(): - # type: () -> Iterator[str] - yield _normalize_string(distutils.util.get_platform()) +def _generic_platforms() -> Iterator[str]: + yield _normalize_string(sysconfig.get_platform()) -def _platform_tags(): - # type: () -> Iterator[str] +def platform_tags() -> Iterator[str]: """ Provides the platform tags for this installation. """ @@ -812,25 +443,18 @@ def _platform_tags(): return _generic_platforms() -def interpreter_name(): - # type: () -> str +def interpreter_name() -> str: """ Returns the name of the running interpreter. """ - try: - name = sys.implementation.name # type: ignore - except AttributeError: # pragma: no cover - # Python 2.7 compatibility. - name = platform.python_implementation().lower() + name = sys.implementation.name return INTERPRETER_SHORT_NAMES.get(name) or name -def interpreter_version(**kwargs): - # type: (bool) -> str +def interpreter_version(*, warn: bool = False) -> str: """ Returns the version of the running interpreter. """ - warn = _warn_keyword_parameter("interpreter_version", kwargs) version = _get_config_var("py_version_nodot", warn=warn) if version: version = str(version) @@ -839,28 +463,25 @@ def interpreter_version(**kwargs): return version -def _version_nodot(version): - # type: (PythonVersion) -> str +def _version_nodot(version: PythonVersion) -> str: return "".join(map(str, version)) -def sys_tags(**kwargs): - # type: (bool) -> Iterator[Tag] +def sys_tags(*, warn: bool = False) -> Iterator[Tag]: """ Returns the sequence of tag triples for the running interpreter. The order of the sequence corresponds to priority order for the interpreter, from most to least important. """ - warn = _warn_keyword_parameter("sys_tags", kwargs) interp_name = interpreter_name() if interp_name == "cp": - for tag in cpython_tags(warn=warn): - yield tag + yield from cpython_tags(warn=warn) else: - for tag in generic_tags(): - yield tag + yield from generic_tags() - for tag in compatible_tags(): - yield tag + if interp_name == "pp": + yield from compatible_tags(interpreter="pp3") + else: + yield from compatible_tags() diff --git a/env/Lib/site-packages/pip/_vendor/packaging/utils.py b/env/Lib/site-packages/pip/_vendor/packaging/utils.py index 6e8c2a3e..bab11b80 100644 --- a/env/Lib/site-packages/pip/_vendor/packaging/utils.py +++ b/env/Lib/site-packages/pip/_vendor/packaging/utils.py @@ -1,22 +1,15 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from __future__ import absolute_import, division, print_function import re +from typing import FrozenSet, NewType, Tuple, Union, cast -from ._typing import TYPE_CHECKING, cast from .tags import Tag, parse_tag from .version import InvalidVersion, Version -if TYPE_CHECKING: # pragma: no cover - from typing import FrozenSet, NewType, Tuple, Union - - BuildTag = Union[Tuple[()], Tuple[int, str]] - NormalizedName = NewType("NormalizedName", str) -else: - BuildTag = tuple - NormalizedName = str +BuildTag = Union[Tuple[()], Tuple[int, str]] +NormalizedName = NewType("NormalizedName", str) class InvalidWheelFilename(ValueError): @@ -36,74 +29,75 @@ _canonicalize_regex = re.compile(r"[-_.]+") _build_tag_regex = re.compile(r"(\d+)(.*)") -def canonicalize_name(name): - # type: (str) -> NormalizedName +def canonicalize_name(name: str) -> NormalizedName: # This is taken from PEP 503. value = _canonicalize_regex.sub("-", name).lower() return cast(NormalizedName, value) -def canonicalize_version(version): - # type: (Union[Version, str]) -> Union[Version, str] +def canonicalize_version(version: Union[Version, str]) -> str: """ This is very similar to Version.__str__, but has one subtle difference with the way it handles the release segment. """ - if not isinstance(version, Version): + if isinstance(version, str): try: - version = Version(version) + parsed = Version(version) except InvalidVersion: # Legacy versions cannot be normalized return version + else: + parsed = version parts = [] # Epoch - if version.epoch != 0: - parts.append("{0}!".format(version.epoch)) + if parsed.epoch != 0: + parts.append(f"{parsed.epoch}!") # Release segment # NB: This strips trailing '.0's to normalize - parts.append(re.sub(r"(\.0)+$", "", ".".join(str(x) for x in version.release))) + parts.append(re.sub(r"(\.0)+$", "", ".".join(str(x) for x in parsed.release))) # Pre-release - if version.pre is not None: - parts.append("".join(str(x) for x in version.pre)) + if parsed.pre is not None: + parts.append("".join(str(x) for x in parsed.pre)) # Post-release - if version.post is not None: - parts.append(".post{0}".format(version.post)) + if parsed.post is not None: + parts.append(f".post{parsed.post}") # Development release - if version.dev is not None: - parts.append(".dev{0}".format(version.dev)) + if parsed.dev is not None: + parts.append(f".dev{parsed.dev}") # Local version segment - if version.local is not None: - parts.append("+{0}".format(version.local)) + if parsed.local is not None: + parts.append(f"+{parsed.local}") return "".join(parts) -def parse_wheel_filename(filename): - # type: (str) -> Tuple[NormalizedName, Version, BuildTag, FrozenSet[Tag]] +def parse_wheel_filename( + filename: str, +) -> Tuple[NormalizedName, Version, BuildTag, FrozenSet[Tag]]: if not filename.endswith(".whl"): raise InvalidWheelFilename( - "Invalid wheel filename (extension must be '.whl'): {0}".format(filename) + f"Invalid wheel filename (extension must be '.whl'): {filename}" ) filename = filename[:-4] dashes = filename.count("-") if dashes not in (4, 5): raise InvalidWheelFilename( - "Invalid wheel filename (wrong number of parts): {0}".format(filename) + f"Invalid wheel filename (wrong number of parts): {filename}" ) parts = filename.split("-", dashes - 2) name_part = parts[0] # See PEP 427 for the rules on escaping the project name if "__" in name_part or re.match(r"^[\w\d._]*$", name_part, re.UNICODE) is None: - raise InvalidWheelFilename("Invalid project name: {0}".format(filename)) + raise InvalidWheelFilename(f"Invalid project name: {filename}") name = canonicalize_name(name_part) version = Version(parts[1]) if dashes == 5: @@ -111,7 +105,7 @@ def parse_wheel_filename(filename): build_match = _build_tag_regex.match(build_part) if build_match is None: raise InvalidWheelFilename( - "Invalid build number: {0} in '{1}'".format(build_part, filename) + f"Invalid build number: {build_part} in '{filename}'" ) build = cast(BuildTag, (int(build_match.group(1)), build_match.group(2))) else: @@ -120,18 +114,22 @@ def parse_wheel_filename(filename): return (name, version, build, tags) -def parse_sdist_filename(filename): - # type: (str) -> Tuple[NormalizedName, Version] - if not filename.endswith(".tar.gz"): +def parse_sdist_filename(filename: str) -> Tuple[NormalizedName, Version]: + if filename.endswith(".tar.gz"): + file_stem = filename[: -len(".tar.gz")] + elif filename.endswith(".zip"): + file_stem = filename[: -len(".zip")] + else: raise InvalidSdistFilename( - "Invalid sdist filename (extension must be '.tar.gz'): {0}".format(filename) + f"Invalid sdist filename (extension must be '.tar.gz' or '.zip'):" + f" {filename}" ) # We are requiring a PEP 440 version, which cannot contain dashes, # so we split on the last dash. - name_part, sep, version_part = filename[:-7].rpartition("-") + name_part, sep, version_part = file_stem.rpartition("-") if not sep: - raise InvalidSdistFilename("Invalid sdist filename: {0}".format(filename)) + raise InvalidSdistFilename(f"Invalid sdist filename: {filename}") name = canonicalize_name(name_part) version = Version(version_part) diff --git a/env/Lib/site-packages/pip/_vendor/packaging/version.py b/env/Lib/site-packages/pip/_vendor/packaging/version.py index 517d91f2..de9a09a4 100644 --- a/env/Lib/site-packages/pip/_vendor/packaging/version.py +++ b/env/Lib/site-packages/pip/_vendor/packaging/version.py @@ -1,53 +1,45 @@ # This file is dual licensed under the terms of the Apache License, Version # 2.0, and the BSD License. See the LICENSE file in the root of this repository # for complete details. -from __future__ import absolute_import, division, print_function import collections import itertools import re import warnings +from typing import Callable, Iterator, List, Optional, SupportsInt, Tuple, Union -from ._structures import Infinity, NegativeInfinity -from ._typing import TYPE_CHECKING - -if TYPE_CHECKING: # pragma: no cover - from typing import Callable, Iterator, List, Optional, SupportsInt, Tuple, Union - - from ._structures import InfinityType, NegativeInfinityType - - InfiniteTypes = Union[InfinityType, NegativeInfinityType] - PrePostDevType = Union[InfiniteTypes, Tuple[str, int]] - SubLocalType = Union[InfiniteTypes, int, str] - LocalType = Union[ - NegativeInfinityType, - Tuple[ - Union[ - SubLocalType, - Tuple[SubLocalType, str], - Tuple[NegativeInfinityType, SubLocalType], - ], - ..., - ], - ] - CmpKey = Tuple[ - int, Tuple[int, ...], PrePostDevType, PrePostDevType, PrePostDevType, LocalType - ] - LegacyCmpKey = Tuple[int, Tuple[str, ...]] - VersionComparisonMethod = Callable[ - [Union[CmpKey, LegacyCmpKey], Union[CmpKey, LegacyCmpKey]], bool - ] +from ._structures import Infinity, InfinityType, NegativeInfinity, NegativeInfinityType __all__ = ["parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"] +InfiniteTypes = Union[InfinityType, NegativeInfinityType] +PrePostDevType = Union[InfiniteTypes, Tuple[str, int]] +SubLocalType = Union[InfiniteTypes, int, str] +LocalType = Union[ + NegativeInfinityType, + Tuple[ + Union[ + SubLocalType, + Tuple[SubLocalType, str], + Tuple[NegativeInfinityType, SubLocalType], + ], + ..., + ], +] +CmpKey = Tuple[ + int, Tuple[int, ...], PrePostDevType, PrePostDevType, PrePostDevType, LocalType +] +LegacyCmpKey = Tuple[int, Tuple[str, ...]] +VersionComparisonMethod = Callable[ + [Union[CmpKey, LegacyCmpKey], Union[CmpKey, LegacyCmpKey]], bool +] _Version = collections.namedtuple( "_Version", ["epoch", "release", "dev", "pre", "post", "local"] ) -def parse(version): - # type: (str) -> Union[LegacyVersion, Version] +def parse(version: str) -> Union["LegacyVersion", "Version"]: """ Parse the given version string and return either a :class:`Version` object or a :class:`LegacyVersion` object depending on if the given version is @@ -65,53 +57,46 @@ class InvalidVersion(ValueError): """ -class _BaseVersion(object): - _key = None # type: Union[CmpKey, LegacyCmpKey] +class _BaseVersion: + _key: Union[CmpKey, LegacyCmpKey] - def __hash__(self): - # type: () -> int + def __hash__(self) -> int: return hash(self._key) # Please keep the duplicated `isinstance` check # in the six comparisons hereunder # unless you find a way to avoid adding overhead function calls. - def __lt__(self, other): - # type: (_BaseVersion) -> bool + def __lt__(self, other: "_BaseVersion") -> bool: if not isinstance(other, _BaseVersion): return NotImplemented return self._key < other._key - def __le__(self, other): - # type: (_BaseVersion) -> bool + def __le__(self, other: "_BaseVersion") -> bool: if not isinstance(other, _BaseVersion): return NotImplemented return self._key <= other._key - def __eq__(self, other): - # type: (object) -> bool + def __eq__(self, other: object) -> bool: if not isinstance(other, _BaseVersion): return NotImplemented return self._key == other._key - def __ge__(self, other): - # type: (_BaseVersion) -> bool + def __ge__(self, other: "_BaseVersion") -> bool: if not isinstance(other, _BaseVersion): return NotImplemented return self._key >= other._key - def __gt__(self, other): - # type: (_BaseVersion) -> bool + def __gt__(self, other: "_BaseVersion") -> bool: if not isinstance(other, _BaseVersion): return NotImplemented return self._key > other._key - def __ne__(self, other): - # type: (object) -> bool + def __ne__(self, other: object) -> bool: if not isinstance(other, _BaseVersion): return NotImplemented @@ -119,8 +104,7 @@ class _BaseVersion(object): class LegacyVersion(_BaseVersion): - def __init__(self, version): - # type: (str) -> None + def __init__(self, version: str) -> None: self._version = str(version) self._key = _legacy_cmpkey(self._version) @@ -130,67 +114,54 @@ class LegacyVersion(_BaseVersion): DeprecationWarning, ) - def __str__(self): - # type: () -> str + def __str__(self) -> str: return self._version - def __repr__(self): - # type: () -> str - return "<LegacyVersion({0})>".format(repr(str(self))) + def __repr__(self) -> str: + return f"<LegacyVersion('{self}')>" @property - def public(self): - # type: () -> str + def public(self) -> str: return self._version @property - def base_version(self): - # type: () -> str + def base_version(self) -> str: return self._version @property - def epoch(self): - # type: () -> int + def epoch(self) -> int: return -1 @property - def release(self): - # type: () -> None + def release(self) -> None: return None @property - def pre(self): - # type: () -> None + def pre(self) -> None: return None @property - def post(self): - # type: () -> None + def post(self) -> None: return None @property - def dev(self): - # type: () -> None + def dev(self) -> None: return None @property - def local(self): - # type: () -> None + def local(self) -> None: return None @property - def is_prerelease(self): - # type: () -> bool + def is_prerelease(self) -> bool: return False @property - def is_postrelease(self): - # type: () -> bool + def is_postrelease(self) -> bool: return False @property - def is_devrelease(self): - # type: () -> bool + def is_devrelease(self) -> bool: return False @@ -205,8 +176,7 @@ _legacy_version_replacement_map = { } -def _parse_version_parts(s): - # type: (str) -> Iterator[str] +def _parse_version_parts(s: str) -> Iterator[str]: for part in _legacy_version_component_re.split(s): part = _legacy_version_replacement_map.get(part, part) @@ -223,8 +193,7 @@ def _parse_version_parts(s): yield "*final" -def _legacy_cmpkey(version): - # type: (str) -> LegacyCmpKey +def _legacy_cmpkey(version: str) -> LegacyCmpKey: # We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch # greater than or equal to 0. This will effectively put the LegacyVersion, @@ -234,7 +203,7 @@ def _legacy_cmpkey(version): # This scheme is taken from pkg_resources.parse_version setuptools prior to # it's adoption of the packaging library. - parts = [] # type: List[str] + parts: List[str] = [] for part in _parse_version_parts(version.lower()): if part.startswith("*"): # remove "-" before a prerelease tag @@ -289,13 +258,12 @@ class Version(_BaseVersion): _regex = re.compile(r"^\s*" + VERSION_PATTERN + r"\s*$", re.VERBOSE | re.IGNORECASE) - def __init__(self, version): - # type: (str) -> None + def __init__(self, version: str) -> None: # Validate the version and parse it into pieces match = self._regex.search(version) if not match: - raise InvalidVersion("Invalid version: '{0}'".format(version)) + raise InvalidVersion(f"Invalid version: '{version}'") # Store the parsed out pieces of the version self._version = _Version( @@ -319,17 +287,15 @@ class Version(_BaseVersion): self._version.local, ) - def __repr__(self): - # type: () -> str - return "<Version({0})>".format(repr(str(self))) + def __repr__(self) -> str: + return f"<Version('{self}')>" - def __str__(self): - # type: () -> str + def __str__(self) -> str: parts = [] # Epoch if self.epoch != 0: - parts.append("{0}!".format(self.epoch)) + parts.append(f"{self.epoch}!") # Release segment parts.append(".".join(str(x) for x in self.release)) @@ -340,67 +306,59 @@ class Version(_BaseVersion): # Post-release if self.post is not None: - parts.append(".post{0}".format(self.post)) + parts.append(f".post{self.post}") # Development release if self.dev is not None: - parts.append(".dev{0}".format(self.dev)) + parts.append(f".dev{self.dev}") # Local version segment if self.local is not None: - parts.append("+{0}".format(self.local)) + parts.append(f"+{self.local}") return "".join(parts) @property - def epoch(self): - # type: () -> int - _epoch = self._version.epoch # type: int + def epoch(self) -> int: + _epoch: int = self._version.epoch return _epoch @property - def release(self): - # type: () -> Tuple[int, ...] - _release = self._version.release # type: Tuple[int, ...] + def release(self) -> Tuple[int, ...]: + _release: Tuple[int, ...] = self._version.release return _release @property - def pre(self): - # type: () -> Optional[Tuple[str, int]] - _pre = self._version.pre # type: Optional[Tuple[str, int]] + def pre(self) -> Optional[Tuple[str, int]]: + _pre: Optional[Tuple[str, int]] = self._version.pre return _pre @property - def post(self): - # type: () -> Optional[Tuple[str, int]] + def post(self) -> Optional[int]: return self._version.post[1] if self._version.post else None @property - def dev(self): - # type: () -> Optional[Tuple[str, int]] + def dev(self) -> Optional[int]: return self._version.dev[1] if self._version.dev else None @property - def local(self): - # type: () -> Optional[str] + def local(self) -> Optional[str]: if self._version.local: return ".".join(str(x) for x in self._version.local) else: return None @property - def public(self): - # type: () -> str + def public(self) -> str: return str(self).split("+", 1)[0] @property - def base_version(self): - # type: () -> str + def base_version(self) -> str: parts = [] # Epoch if self.epoch != 0: - parts.append("{0}!".format(self.epoch)) + parts.append(f"{self.epoch}!") # Release segment parts.append(".".join(str(x) for x in self.release)) @@ -408,41 +366,33 @@ class Version(_BaseVersion): return "".join(parts) @property - def is_prerelease(self): - # type: () -> bool + def is_prerelease(self) -> bool: return self.dev is not None or self.pre is not None @property - def is_postrelease(self): - # type: () -> bool + def is_postrelease(self) -> bool: return self.post is not None @property - def is_devrelease(self): - # type: () -> bool + def is_devrelease(self) -> bool: return self.dev is not None @property - def major(self): - # type: () -> int + def major(self) -> int: return self.release[0] if len(self.release) >= 1 else 0 @property - def minor(self): - # type: () -> int + def minor(self) -> int: return self.release[1] if len(self.release) >= 2 else 0 @property - def micro(self): - # type: () -> int + def micro(self) -> int: return self.release[2] if len(self.release) >= 3 else 0 def _parse_letter_version( - letter, # type: str - number, # type: Union[str, bytes, SupportsInt] -): - # type: (...) -> Optional[Tuple[str, int]] + letter: str, number: Union[str, bytes, SupportsInt] +) -> Optional[Tuple[str, int]]: if letter: # We consider there to be an implicit 0 in a pre-release if there is @@ -479,8 +429,7 @@ def _parse_letter_version( _local_version_separators = re.compile(r"[\._-]") -def _parse_local_version(local): - # type: (str) -> Optional[LocalType] +def _parse_local_version(local: str) -> Optional[LocalType]: """ Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve"). """ @@ -493,14 +442,13 @@ def _parse_local_version(local): def _cmpkey( - epoch, # type: int - release, # type: Tuple[int, ...] - pre, # type: Optional[Tuple[str, int]] - post, # type: Optional[Tuple[str, int]] - dev, # type: Optional[Tuple[str, int]] - local, # type: Optional[Tuple[SubLocalType]] -): - # type: (...) -> CmpKey + epoch: int, + release: Tuple[int, ...], + pre: Optional[Tuple[str, int]], + post: Optional[Tuple[str, int]], + dev: Optional[Tuple[str, int]], + local: Optional[Tuple[SubLocalType]], +) -> CmpKey: # When we compare a release version, we want to compare it with all of the # trailing zeros removed. So we'll use a reverse the list, drop all the now @@ -516,7 +464,7 @@ def _cmpkey( # if there is not a pre or a post segment. If we have one of those then # the normal sorting rules will handle this case correctly. if pre is None and post is None and dev is not None: - _pre = NegativeInfinity # type: PrePostDevType + _pre: PrePostDevType = NegativeInfinity # Versions without a pre-release (except as noted above) should sort after # those with one. elif pre is None: @@ -526,21 +474,21 @@ def _cmpkey( # Versions without a post segment should sort before those with one. if post is None: - _post = NegativeInfinity # type: PrePostDevType + _post: PrePostDevType = NegativeInfinity else: _post = post # Versions without a development segment should sort after those with one. if dev is None: - _dev = Infinity # type: PrePostDevType + _dev: PrePostDevType = Infinity else: _dev = dev if local is None: # Versions without a local segment should sort before those with one. - _local = NegativeInfinity # type: LocalType + _local: LocalType = NegativeInfinity else: # Versions with a local segment need that segment parsed to implement # the sorting rules in PEP440. diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__init__.py b/env/Lib/site-packages/pip/_vendor/pep517/__init__.py deleted file mode 100644 index 3b07c639..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/__init__.py +++ /dev/null @@ -1,6 +0,0 @@ -"""Wrappers to build Python packages using PEP 517 hooks -""" - -__version__ = '0.10.0' - -from .wrappers import * # noqa: F401, F403 diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 589f580d2e21cc8fce9bd99ae00c77a5604a9f06..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 341 zcmYe~<>g{vU|^UdaWJ)sfq~&Mh=Yuo7#J8F7#J9eMHm<uQW&BbQW&EcQ<zeibC^OH zQdoi+G+C?6!iy3M3Q~)T6-x3Il1ejkQWOFzOEU8F6bcfPvlG)(ixo<XGxO3F0$c+W zObyKyGV=4Yi@B=U4D<{Q^bB4yGB7Y`GTvg;^3!C##U3A@lAjzOe~UXlzAUw<I5R&l zKK>R*In;`k3`J}V3=ra1y|YzJXmM&$aZGAXN@h`ve_pCfQD#}Hg04cSpJ$kBP_So+ zW3Ym!pNqerYp|zdOt7o3YjB8bkb+rEK!8t7qKR%!etKqcNoICTYF=54Pi9g~ab`)X zF3jCA1(^l<@nxxbDfvbE1*rw5hUWV5@tJv<CGqik1(mlrY;yBcN^?@}Kwc<jVPIfj IVP;_h0KtP{ApigX diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-39.pyc deleted file mode 100644 index 47792844f358eac82058d404fcabf681b685d821..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3590 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 N8tWe$8wVd3BLF4^vF-o> diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-39.pyc deleted file mode 100644 index 2b8bf48c8712b2a76b7d0cdf337614e9d9df0c53..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5125 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 SN?c-0j9~bOje~=ogAoA4wI6Q) diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-39.pyc deleted file mode 100644 index 1eabf2c0aa8cf34f5bc55418a9cc8a6424b94c4e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2966 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 DFnS8U diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-39.pyc deleted file mode 100644 index dd65d1d5cf54e43bedf76232d6b23291b7750c3a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1143 zcmYe~<>g{vU|^UdaWIvKnStRkh=Ytd7#J8F7#J9eGZ+{cQW&BbQW#U1au}l+!8B78 zQz}yya|)v*Lke>?YmrF`OA2cXLljF2TMBy%LlkSCKne#`gcBlC#gWPu#TL$xC&t2% z%3hho$N++=98qkM40%ij3@J>(44Pb35&@MZ8Tok%M*7AI$@#eji6xmynK_vyl`lcA z^Lxq6z`&5q1Y$!m3j+fK$g$oa$GR~vFqAOVfE}5_+{@grQp;Szn8j4XP{W+Yl*v%T zw1lybk&z*sA%%g3frX)&nUNt+z>uNX!T{_XMutcRMurrIU<OSVzgvvuzgSC4(sV6W zGT!1y%}dTt$;?Y%$$X0?zaTa57E4xfe%>vXl+xUSl`OZI^OLe}u@oehWZYuQE>A2< zFTTZ?wvwSpfPsPGSFN*EOlWaxQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vV zr=N?zpKGwEV@$BCuWN9KYmkCjOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOs%}AI za&}^RYH>_KW`TZuS!!NNevy7bYJsVtxjrQH^a?6(ag`TkmZZjm+zX2IVo;DVFbXgh z34sEW5gL#n3KX!Qz;p%$rVS)8!7&dGOsQJN62=8gHH-@x!x@;6f-soDkfB%)YY-L{ zfov;cWnf@f$y@|7yNHv4f#DWQPJUv_N~R)S1_p*Aeh>i)DR6KV34#=G7NsVpfZfao zatz26u$#p}ZU(s%<X#X4$$-p7O90JG{Tj%TpTd;FoXJR90$?gnDq;h<4P-|VJBY;% zB2b+Q4n`4#BY7B;afYb{JWQLJ`tgUS7Djk7`Q2hFN-6?bRV0SR9iX6*Kz4^F=Pma5 z_>}zQ_;^UDGZ$AD-{L7tEh^5;&x_B@OUnm4z6hlAmY`c^PO4viiCcbYUW#i`QGU@a zPQS$5R0xyZ(;v)$L=kET+~Tmw%}*)KNwoucycpy*7Df(64pu%U4i+vp4i*k}CPofM G9!3DN+~qw0 diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/dirtools.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/dirtools.cpython-39.pyc deleted file mode 100644 index 73b1646d7f274b7dcbf0798ac825a436804d8b46..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1375 zcmYe~<>g{vU|^UdaWFNLg@NHQh=Yuo85kHG7#J9eqZk+%QW#Pga~Pr^G-DJan9mf& z1g4pzn87ql6bqPUjba7UY*B2fOj+zHOexGQ49$#D94Ra*tSt;toGEN6>@5sYTq%sf z44ND-LALrOgGd-=WME+6WME(b2^Q-yFff!bEMQ#7P|HvyQo|6&z{n8JP{Oo;xrSjO zBO^l|4}xvL05+4U%E-AWHL)aBAyJ_uHMbzYD6yzgAtkdYHMu0es8S&_Pa#nuIX|x? zwW35JH!&|UJ+(;BPm|>q2S{~VW=`rY_T20g5a$+KaYkuLX3j0PqTG_A)KpEzTTCS> zD;bK|85kIT)jM0ogche3700CJq+}Mw_~)g%6lIpBD(EVN`gw-A1_gVDI0h?t`nmY~ zxdwYW#ss_ix(0{11}T`u1O)iRB%0{v<fmsAmt<zgq~?{y_+%!<6la#C>J}s>XD6no z7RMB17U;*9rRJsN7wH$I7ML2E>!)NEmE`B=6zdgK-eL#2F(tDI6qm&upzvenU}R$C zU@C%zA4m+0K@kd4<`0TgF9rsNDxngFEXEp!Ookf9C5(NH;S9kHEDR+~l`f17wM>i* zRZ=xfS<EHOSuEMiMFvd_;S7-sDU7vDbxe6&5ZZtN9^m0Vnc1ld3Ax!RnMDaY3Q46U z3Mu)i#R_@(B??7}nZ>CJiFpdC70IauC7Jno3YlpNB^jw)3JMBH(UO=`l$w}QsgPQc zSzJ=A2bT5IWWB|dUwn%dZ1OF3|6tdmqWq#;tf@ssdHJ{4TwNnPgF`f#Z?Pm6r5E2~ z%Pt4g%&8U0;3$F+ppXGaX=YJ;fe0u7Kq0}v!o(=V$j8XTSR@2WZJ=Za4k`u)29ORm z1_lOakm6~GB*+L(Y>X+43z=$}N>~=Kf)b$%Lu^qDb1g$Hb1h2^vkOD4K`m<uOBUM# z_8Nv7)`d*9Y+xQo4O<PvLZ({w8m0xDHS8%&;tVOw3z--h3Uz8&To__?2<qahVXI*W z>qsh;t6>Ue&}6AHaL&&wE-5NaE&&B`W}a?tYAz^|S7jC`fReI8T7Hp2A|jaeZZVes zV${FIpvirUDKq~TyHjOJYO$yPE%vI+0+5DV>`|EoZkai$;8b;sr93ew`xZ+<VoAm= zmaP2Dyj$!=sX1USM|n|ZNosLP(JfXmOOxXkOHqD)$t|{|(zLYHqFWqQnFaA+Gg(qH zi;8ctg4o4H(hLj?QS52O@eosrQggs8NL+z3RuL%pZ}FvM7R8t3$3xvE4~hy2Py{h? zF!C^pFmf>RG4e4AL1_WTA~gmE22F0Tvx~$S7#MDGK{I(yW>OIo0|P@53y9za5g>zZ v@j>OGWdJzSfYSolC?xkF9K~Uio1apelWGS_EybX;#KDLJnOPXQI61fh=nY@N diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-39.pyc deleted file mode 100644 index 1744d09a53c384ece5d60fe31713465a07fdfbf1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4508 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 Y%q+|tj2w(SaLmIb0IGJl1roW$06yuoXaE2J diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/meta.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/meta.cpython-39.pyc deleted file mode 100644 index 3e2ed2c3a3ab0fc6ebb48e6e14542442571237d6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2948 zcmYe~<>g{vU|^UdaWHj0Cj-M{5C<7^FfcGUFfcF_+c7dQq%cG=q%fv1<uFDuf@!8G zCNRw$#SErdqFBH*YZPmh0GP#=%O1tS$PmtuC&j{$%2^r4$N++1Ij$&<NQOKn0|u~K z<{a)^o+uu$S~;-VHjqk2kd4eaybw8v`V^KF)*QZE{wRJ%h7^_*wj6<6!6?C8p(r6R zpFKx7S0qX#S2RjAS1d{lEXI)|o+}Y0kt-P`nJX0~#mJD#v_LvlW+7vgYzk)zR|`Xw zT#9rGPYQ1fW0ZKRcp760UkZN<W0ZV~K#E`sLzF@);{wHn3{gs{N?FP&LMg&2BE3wE z3}BvUidc$xibyXrBSVTriew8zluD{hic~h!1jZt(RF!51MurroU<OT@DkG=T%$yX3 z+|-i9l*E!mg|z%4g+zsdqWrAX<PwF_;>^5sg#gz81ye(Fg^c|C>|#Bxm!R12(`3BG z5|CJu@sg2&fkBh;mH^lw*SxaKqWrwv)VvZ+rdt95sRgEn<{tU^+0KbMIjKdr#0yI^ zQ%mBDOOpzU@{?1Gi{pz*^YT)QG?{O)m!#$vq+}M|V$aP^$t;R5xWxyeO7i2YG7Hi& zb5b>#Z}FEU=47TMmZZiPR~DC~=HBAY$xlpyad?ySa|;qnpxk6;kUOE6oq>S?l&qXV z31<ca149kN0)|Y6g^ab#C5#K0QW$HP7cwz2)G#h!u3=ut$jAT|WdgHUni={-YFWS{ z%rz`vbqotwYgjTF7Bbbcmat{9FW{(QsbO8nRLfSvxqz#N4JyV2rnzfa7cwqn0_h89 zNMT@MU}0!xW@N|{Fk~q1G5{w&MutdGlrRJ{XtMZKiMi*OC?tX7r6{$qG_xqR*h)dQ zxJtz{uebyhjwuQ$m3fJ|naNO9DX9gic`2!R$(gCeRdOLkm7rKF$%o3q<2Ex-LA6+u z=ax)*YDqlI<oLAwqIj@n@#Pt*sX4cpbMn(~v1I0@<=^5i$SjD@gjiYx3c_0o1x2X^ ziAAaLFheo4GvycGVkt;0$+*Rmm7ke+i>)}Lv?Md<7E5k^S?Vp0q{QOXyu{p8P4-)? z;PiBhIW@2B7E4NMamg)~qSV6TTTCS>w>Ur%4pMiEtvJ85C^>Z{Ly<fK1H-RsXRDad z;?$zznADt<%%T|oyi}K>%(7GkU4>9T&oI}ZV9yZ8U<FS<7k@w3U{A-GU{_z);1Jg! z1+$od0H2sd6WyHr^vvRt%<P!dys{Xd%%qs&%#u{yg2d$P#PrnSn1aj#{rIxfyp;SR z{Q_|M)dzW2ub}c4S3Jo3V82U)5|R)obun@=@-T5Raxrl*@-Xr+@-Y@EGB7aQV$?%P zfUFD*44e!M4B!N~36ubt3b;xbY8aXsYne(IvzQhz*D%yD7D%NqE@Y}@EMci(Yz8Gm z)*2=-%~r!u!<51#$xy?zfIWqIA!9RhEprX?0*(^Sg^c|Hj0`1Q%?$lowJbF(3%F~T zQdlGzz=@ZqhPei07Bi?6LrZ*Z$cYalX)ZyQO#vlMR=-;;DVfD3RlMNzqMMYMoSmAN zQpE#h=z^o21D3Khd5gFi7#NB`p;ROcVu^qVQ2AX1%8NyyFuBE?o?3EC5TigSVgspV z0TBWq0u-j2thcxzsUbckv#3Z46wGXpf}ltOq(~A(fRYI~trRJM6tIHbstJlNF>rM8 zFbXkpFmf<5F$(-=Vc}uq07V%{J{eS!fs}wS69WSS$fe-;vSDCgC}C)3=vS&`1jSMc zV=pLf7(sCq&cK9}se>5|8H)8VLXOE#lM(D*O(t+YDgq@1O{QDyV8^8v-D1x#EdhH9 z&GkHB1@Vc+phD0B<Oxu?Ffej3axoU^FfcHnI2sgOpg;vX+6wIGEXD;)HK1~ip@bQn z*ceM#vRF$%$%!$Av6s1)sf4|R1C+>`L1iK50xnSb7tEl^R5hJTK|w*mJ+mw|Pa#nO z67UKsnMJ9|CHX~_3K~WE`6ZeP`Dvi~0+M-jz&eUjOG=CK6cY0kGII;^i%N1blk`A2 z2voo5xnvfX6lErrmSpDVDdZ=CY8kMm^30M9L@fmNwL)4^ey&1EMq-HqG;`{Km1;5- zse>X~161*FBa+uGuGETx#JrT!;?$xd9#GtKrj_O;m*nT?6yIVmNGvMJOw1_)#dHxU zcEQ1Siz73)0Gy$t1VFVJvhy@qZn1#;SOl`DNDE{oI2EHs5eujavI9j8C{Z)8fl`zJ zBM)Pd5l9EfrB$kqNa2>8pI4HYnFlJO3o4-%tzJofZVsqM%}C8DsN&Ss%`Yv{P01{( zV$#j8vU5o-F3HSG1P57Wo<ey>W^#r?NxnjHVp*y}Nk%H9oG(@=O3g_u0hNUyIdG{7 zvNjo%oM9N0#6k5UIE8>RPzl2V#)S;E3?)o83|Y)I3|TDAOpFZR?9S+?$$E>eAhD=8 zwdfWXn2t{@N-u^4A;@Dz+Mp<4yu|_*Mh}<V#LT=fP`H4SB`C=jnS&yQBR(D^6Cbb1 zT%^Rnz~JYnsd|e&K0YNsIX?atM`BSr*s5FXIr-`7nR)4u2o?nerXEPY5N4{n#Q{rS zMFt=x+@9cs=UP;hUlfH<4~}P0D!j!GZBl>}LKI6?W<fy|M`~UfINcS2+<S|oyeP4t zAhoC%TugzBqbQD)%p!1df@ES)`2fzzkPrbyKcvKiB);_25}*9^^wgqT9P#m>x-34v zh!5lqP+0~}ec&W=i_ftry%f}93IGRnkqO8PJc%hOpwI?OfCCOvrlAEghfQvNN@-3i zs4dJ;?83mnz`_J7+`yQLi4l|#`Jl8A6Az;RqX?r26BjcF9~VCl8wW23BMT!FBhx=N P78Vfe9~&D7D;FaG5;^V* diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-39.pyc deleted file mode 100644 index 9257929d62f2b2ea70c917bcd7872f56792a791d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10508 zcmYe~<>g{vU|^UdaWGXyn}Ojmh=Yt-7#J8F7#J9exfmH3QW#Pga~PsPG*b>^E>jc} zBZ$qI!yLt&!jQt8!;;Gy#hS|&#SRtch~h|LNMXt0%;k#W%H@vY&gF^Xfy(hl@uo1O zu;%dP@<;JAGNiDju;&Qm3PuTn*&I1Sxx!Jxj11`vDV&QKqeN1fQn*sMTNs)dqeR^q zQg~8$TNqM!Q^lH@qr}}AQutE%TNqOK!F&mKh7^Gm!4`%TK`>v^ogqaiMYx3_MHtMN zN|8$uNfB*fjFL`~PZ3KIZ()p*Ns&mAY+;C!b!SMCN|A11NRdvJYi5p;cV|eENs(<~ zNRdrt$Wmx#j#5lv3}(<&cnJz6KTXD4e98HFC8-r9xrup+>8VAUOt;t*lZp!xOEPY; zWaVe(X)@p9O3p}4&W=w`%*naM17YWvmK2nh++qt3aq$lg(PX^Eo|~OglA2ral97Rd zL6h+oTXKGGL1Kv}<1LZ+%)I!5qWt9e;^d;tf|7WU*_!OPgq#wSvs3d@Lh};K5;JoW zlX6mT@j=Br^U4x)GE;7Gd*tV5`(_pwXXd5f5(&*KE-fg?FDgk*@h?a%N-W9D&$}g= zlA4xSno|;AT$%*3CAGLXzNj=WFSY2FcwuQ~DmDp$fYbt0LvxVf&WSlWsYS`4(12l( z4>%bZ7(jx>It&a9B@E3BwG34vH4I@4j11unC5#K0Y8VzWGBV`xAlL>BDGb33D;fPX znTt3W7#MD`6=#%|WaivrE6Ob?N=?;dyv0<KvXY@loPmMiSG}`UOlWaxQE^OaPD*A` zjDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vVr=N?zpKGwEV@$BCuWN9KYmkCjOhAB7OrnWy zPJVi3aY<%&Oln?Pj8A4#OmSvOs%}AIa&}^RYH>_KW`TZuS!!NNevy6w*uVPaMTrFk zsYS(l1(mnhL9vyRStJ3<9U%8IFtIT*F>){!NkaV&3lA{O1j|Su^{EU|j42FJOeu^} z%qdJM%q<L2EGaC(44SM(JPZsBRj%QgIXMbRsR~7jnZ>Co3YlpNB^jv-NstIvNKVYl z%P#@RXXZkpQz0`CtRf>nKU)DBi+af*JHeJSFff4FAnXisE-25}FxD`{gM++Cn1O*| zCF3p5lA^@qRFEYrnQpNZr{<&;Ni#4&!W$guV87nth>y?A%PfhHR|XjcGLwO^N*bE* zkP@RFOr76KR*<H=#N5>Q_*-1@@wxdar8yurPkek~X<`mkhCMz$B|kYnzDN$$R#1F{ ztp*2<BFI)yvBbg1!Uz@tr8Af}!8FKC;6jT)So4CyS`&X*XBI1DLNb$HGRRi21q=)f zAU4PzaCnL_Ffc&EvxcdLA)c{@xrQO036z{6Vat4r2NbNSc`5NAzan^`tbB_-H?_Dp zF+Ek2rAQX!b5#(b1|rl!1lapv0^}WV;An!vfDPmnMm9z^#wu}W=tHwTBIJwYQB6P? z1M)k__+pSpz(ENT!3aubkR>476c`v7kdtjYLmDGE>2gG|v@@_UM6m`lXtEUXfr3;4 zElBh86mlVDkOC-y7GtJNkToD&ECntuN*HSxnwb_b)i8nz32?|V!$VV(<rZskX+dfc z*fMZ<+~Ne83l3XNCP*NHf(VqR<KvTa5{rxD;}Izsti=%IDUjb87zG%sL_kFuw48*8 zo+eun$k#=n6j!7K3P@0j2kXAY3pF=6H75sVHaKv#K<dB|1qup%m@VKC28m#VFenib zlUVsdA?xCsSP9Da&~hQEQX#1{Gbbg!I3=^V1ihHZ%uC5kPAo|+Rw&6xEK$fT0TmqT zC77WPasoIVV<{JkKrvDz1M(Hve_#UaKTs~U0QnE3oq@4R7F+cK4@^JYNfG2TGmt@` z=l};4NF*7Q9-yfYoZDC#7#P5=1O;&kLl)x#riBc(%r#6!5;e>Vm}{6oX{Cgv29y(- zQy6=h85vTTf*CZKt4u>OQWc=poI-ADNk)E(LVlV8s6NijO9vO6(2`vNQ3>j4GTmZM zE>F3|oSIkWr^$MYDZls@dum=;W>J3LEtcf`g34QLr3ER8C8<Rqr>$hU#hjd*Qlty2 zx_DD7N{SNWp{k4Yumqm~0|SE%$k&j%gNu=ck&CGaB#Pm4P)-N?98#I$_jw6x3S%z| z-0v=qMEh8wJR>tFRRPpSC`tu485AJR6g^F5u(!bexW!gnl9F0f<fqA21WMjT1|ZLY zvQv=}hy`+N5j%)w3?jhk1x$bwjUWR9gDZxwL82(N703_}2Kzb>Tqb~g4Jr?cL`s-b z7@HZJ7{O_P1=NtJWdgHV!6aJ^sN7&$$XLq^=CgxRMlB1J&AgDY7NU-$hNXrzooOLs z4NEq2QC10a3KPiG8fI{sdEu8|l$)57S)8hnn3tjeZnY^S!mD6V!L7%|rJ$go;F?!l zT9gXOW1w2PD7COOwYVfT1x2w!X0bwXL27blT4rjBLSnH(qC!z>PGSkD$pSJ=2W%F| zs-o25{G2jSuFY3SRLIFsP6V~n6iV|_Qj5T8H9fN|HBX^9zqBYhRRPp8f;uE9wWPEt zPa!c+Au*{qKc}=LRiP}ks5mn}50u(bod&W}4{T+X7>Hf0kXu>|Zc@NpRi%I`o|#vi znUacZttKZp0o-B%DZIs+S)7<ue2XhAF{d=uwWuh+s0fsUZ*k=17lB%`8AYJ%4dEsy z7N_3gNzTvB&Ce?+N=?hG&}6&C4e?Pt$Vaz0;h}hoD>11!9wK*(7sN(Laf8f;$?<_X za7jpc4^MfwAkv9>De>UA^aCYAAyE0k!NbVG#KS1Y!o$eJC<1E0fl?htISuj*xSUQv zs|iy?QkYX%S{S2PQdv`2Q`o?L6t)!66!sL37RD&{6ftnmg)xdFMI793VT|HTkpTBt z7^ApSB*A?Z#wcz`A0>(hTxdxZf!vn3i<yDJQ2|ysB^KqE=A|ek!XhChvnVyWB)_Oq zp(GzvD}d^P5{2^2k_?4Jg#gz81ye(FSR#a`5vzj4qQqRN0r4rBMOF%+!VwgMAVWZj z1QOH=aKm*JKs}tq%)HFJba09RCHjKOf};Ga)Z`MqlKk8pNJ@g54RS?FJhZ(7F&-=g za|t*b=zy|7L241qnK}w-Mftfz84qa$gL^?x(;*_@^oreF1w77$^mVKh9KrPgs22sv z%9(j(`Pracn2`#P0HoRh>{O_a3o1)8^7G<TD^in7OF$+-+!X*8RzL_Vl!6-bCHbHh zWqvlO$bh%$Aw>x&D%2qkQr7`h=LJRiWtl0dDLRnsnOaehnp^@d1k&<za`MYF^U|## zT6GnYb5pE91qP@kke{YdTvC*omtL$;lv+@fTAZ3!0;}pk*$!0BfN@cJX>Mv>NwGpn zKG;VJQ0JzC1F}57G$#d=vI-K5p-xZLOV?9SM+yjVZUXmh)gj41S0T9^>=K9zFda~y zUz81U3_OKF0vuWZL7f2(s<eDaiHBsJf^&XRQEG8PeqIX5(crLvg%VP-hB*bL9tH(Z zN@jA2LT+L~0muc=`WX}g3T25!nV`5+0JYG;Mwfv~vSO%v$}=*PGa#{$l&VmiTB3mI zIB3{q=I24I_e%!VVW2Vwgh6ajAp*k1L7*N3OA13NLlI92LoG`QV+~_7V+TV#Qw>uG zLp*a0bCD6aiOrb8)WT82?84B@Sj$|)+`$mfQp3{05YJk}TI^B6mc?GnTEp7G5YGW> zA8RuEC4+k3AnQOF)G`CLO+X#IVo?2?&QQY;D^SZ=!qCBx1+tQ9B2yttFr<&C$y5X? z`EGGRN&rylpviQLNzdRGW5G&BNV6JIo^sjbWEPizMk(w%KxHY&E;hz0UG$*=cneU^ z22_{j6x-<`bZT;fTRh;JqR0i@asrnXu;Qag4J0OnWo&}ExU%>b7b0)n62!=bnrsj^ zgUl`R1T{v$rm;aXSdlMC1neJo5DOGM;I@4g$Ty%?F9Qb$BMTE3BO9n`#>n)ajTzM0 zVqs)stdhj(OO$2|D5^otJ5Xg(tObg4hAf6!CUA#_p-Lcy5i%YE?ldywaX@GT2Ji?I zQ&o&3xa3W(03}%P;1VRwrGh&BiA9+?l?wS~sYOMZDWJ3rD!O59Ttt3>rd|aFh^Hax z5>$ZuX)+dhfrgrxA%O&{4{xy)6s4A-SDb<f)1U)G6G0&a>MJm?f<go|=uxGF5h57c zP=W@OTtG<^l;Vm(t=<}j1q>;SDNHqtnT!j;?e;`ZMg|7Y6j0HXR;d6Rmr(%K@R>!a zDd4~WrxuX+6BWucQd4svg(1j;kk$~Wodrs#pcYU{YC&pVN@`wmCAbR8Oat|fGV}9_ zbre9QniaGp1!)H1XeF?T3U;;%26{%ON;(Qk#i=Ew1tt0UImJq`2%ADOGK&>b@>7cy zK%+95dC57YDXB1Lg31=;mS1Kb*2)NEp=XIg5x5Bl>ae9M6r~oI=9GXOj@(g6EiBC} zOUy~lE6J$@7gZ_XJ~e0nC=njnh@eMA_$`_A)RK5;;1$QG<rl?+11}!z%Uk@(`FUxX z>G8#>C7_z3cqQX4E^w(H59(U4g!ZaI#THunC<<g?V3-R^5ugH&ft!ty<v*5E0H5U{ z7$Ym7{sTB=fN~`yWk5>E8m1cN6s9@M&=gY2$iNU#lv<Ejl&X-ZkdUCI2kHpxX6B{k zCnPAO<>!Ff%-{x5ZfZ$lN@7VOIMtMZVhq-RK|~}h$$+vFs1^W)J(!(Zo>QriT$Gv! zYSlwbg|?@_@dh281NFq=jhvL!w9LFzQ1SzXAEZ$RwiaZt4yZF;4jtnI#cpZ}Jnk~{ zKn*<jSgf9cXBsG7>40lGXsb#ArZ=%TJ2eH=a05rB0yGmq`Vt_gf$DgW58$Dq0Im>| z!Tu=9&xO>y8l`zTsl~+#@rj@|MSNOfP7cT-g-lrGr=Z}Lm{XjpiIkcY3LwEA4+~iI z6s5_0O9(Cpuj-3HDd-kInoTR2ib6nTFsQtQje>=P1VE~bB0wx~K@BEANunr>fq`KS zDA9q7As$FE#Pqky5Th6(<WAgaPXkn7Gp8_?G8PGxFw`)EYhZ>2j44bd44~Q?oEDj( zX^|zdjFExC37iI?(Ex7JDu5%M?6j7dlZu?u@)Xij^HPfvb3n-<vlx;NKnVz(I@H0b z0Ft5A;l%<d{z1{1nwNrzKac$K)Uwnfa3d2uI#ixm42sgS%>2?~P+|uS>!&CrRl?Jy zI-!76*8%sGLDm%~=B9#%9l$v*9v=C~2@2G{19>79*;bJIOCSX~#A`{Z3d#8epdNEc zK13X08p1Pvx41z%Qy@OqWWL1@F4GW7!KtnYl%h15AZ-m$a)YI`Xi)kBr!<fX^x`dw zfq`KkD5Zf$?-+PE7&*XWu1t(ff2(9LQX7&xNUrYe2DrLI)NY_U&&X^T)p6kQQAjEX z2E}$Lhya%+U;<pE#4s>0TmnTjIrSLW0+fL}P+0~t30#eVCkVg|99T7$!Ze2oQi)Y9 zhL#$63Sd*HUu=LID4<dT(y)LQ6JX2K;T0CRnnJI9;JF``!@!y}nQrle8R$7I5~)EM z2MS_vt^x-!m;i@!ECU0>Lr^$_TE-0Q;G+8<&a4Es2PI&+85kHiVPnB<jG*boEXEW@ zNrn`rY^EZa8ip*U1<Wa+aX#ieHW06tIfbQ$Ig_!LrG_Dkr6{R{HH&QlJBSS%3xw;A zs$pHgT*9z`V<7`bu7<USC56?7p@g%UVFF`6TP<4(TMbhtV=a3LR~B~-dkIesTMBzK zQwmcG2WY&xgtwWY-=dbIh9Qfuma~Q-i@%1mM4&{lhNGFWnX!hkhAkcB2B8|36i$%( zaE25H76ulEW@bi)JOM+7;&TQJj9?haz{pU-wLlnb16MO>G?S}_Yk^1#_d>=Aj72OZ zqF^3R3hzS5s3k~_4=krpB8EkdA1voqA`S`>kl(>-1VH*z1bdmA7{PoYu&SsM2~hn8 z5=#-5WC&+qLULy?gCWBN#^MTOmxBAAB7Q}nzUNC&%l;OtW3aQQ=Pi){*8o#P^LVFF zPal_fCr4**S3j3q!Z1+?KR&=Q#N!rQc6nk^dT|w3W?n&QiC$K5ejaEVJQLJnFVSRz z3_zQLCPBENqtYNHx426YliJ|v%3BP#xbpI09mre!(5f#UI*WIU7bcJj9-~wNbuf8A zi9a4XM|F#<2;2&fFH6kPlq~WFD}WB9#)Ddx;J)N7w$!}j{FGF14;3;F$_^SuD^4wd z40MX7r<SB;=A;%^7MG;vf)!`xrGqDji$IN*TU_NunI)<5U|+BnfR+jrfs!_)Ukd7) zforN;%*7=|kghRjQEFleL_KqQYDp1jmIOQjS_GQ91J8zOazlD^pxH0*q&(QIMWA4V zI22S6-Qog!7aY#F*dU7vZm~hS&$n1Wjb!vX5L8>f1!Y+`(5M0jA0r<V8zTo38zUbW zaxif*axn6Ny2vb`+L47(h>?Yn>8}c#03#103^OsZfI8BD*;siPIT)*?G3ri4cSDoe z&(BYj(NB}fFGQ0G!esQ*<i$B3R|HCQMFF592h<$_HxG+IHFpuHR4)P*Igl16xEMkZ z-~tIW(wYYH9cYe^gONoXoCAMxi8C>BadQbUFf#n(5(bkZT>M--;E`ESj~)~ja11K$ z!NbF#IUVGQQt%`xcz!>HwS^&yHI)st)CD|9%$~xL!r8(Q#Q`25W{BcU;R$BY<h{k~ zlb@cRS`-dhZBPa28w8~$rYJyXii;t2M501LW&vb=q9_&8$^x|mA;YL8kl6!}K?)kh zsi_K(2v#pv$jMJn2X&bt)9}znJxUP^@(c)r>n;z(^b2^+Mha-*05f<Dg9SWd!CJz$ zfPEoD3~1_`qlO`#vxIE{R}DiJ$3l=w?iz*#JPR2>tA2tRz!A!Oi?bvHl$Jq@QrJSk zOz_CdEw+@z)ZF~MTWlaFrWV~|%}Fgw&4J`D7LZ?Wv8ScPgS6h_NK1(aXP{ebX({;y zsd=~9K;j@x#U+VFC7RH2japEer~?sbu@0KPRAppfC<eFd7<m}knAjNEm<1U5n5x83 zA^<*ug)+7VD(gTP97dpuzJ?)-A(#O?;jhV9)CjT?Jg|gn?=3b^p^%qv1hN{GY8e=- zL{P1RD8R4`9wDH~SWut1gfWY0A!Ct54R{e&E0ZKcFhdOkIFMid|NsBLCi5+h)V!2p zQ2!SahU__@K51%!CgUyU+~Rb!Y<`QcC^a{~EHyqawH&0-6z)W(Dj8HKqAEmjD#%Zu z-~fjUX#N}&E-nnQBDIV)3=2RQG(88N*e_%QRUD8IV=ih26|`)SNG<9DwIm>e4!2l9 zjzM=Tb5UuYCCGuGStSNWF2*WBG$)qkVYI+OYQgRj0d?&dvcT@i0=Wmgk_{Gn%tfG7 zbBj4AKfMT)bYN==)Io8I8l6Sm3=9mmAa{WLjTx5^@AzqQ;V!ybLH_0`E=erOOomKO zgMDAr3$hJlJd)SJmV*neN(Kf7d62!J<jcXx!pgzR!OX<S#mvD{1d;<6o1mgosR%Tn zd5a4)iIZAUl9QPPDJ(&Ax3}2yi}gUY7PzVb*IPw}AZtP4bBhZxj0B$HE&@d>WNH^& zDRO{TK!Fk~c)3;)s0fADY?+V+YpKP>;41AFdpxMaA0H2{{cdr(RwSnufF?E3YA;BQ z1{w@30?i0RMx)vClR)!K;8M4!8ss>T_ppV@Ee;z<k!A<Vm*ACW9E_m4Mu3q6G_l9X i!^FeL!^FYO#K^@Vz$U;Uz%IbX#mU9VAt6xDU<ClBx|v@9 diff --git a/env/Lib/site-packages/pip/_vendor/pep517/build.py b/env/Lib/site-packages/pip/_vendor/pep517/build.py deleted file mode 100644 index f884bcf1..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/build.py +++ /dev/null @@ -1,127 +0,0 @@ -"""Build a project using PEP 517 hooks. -""" -import argparse -import logging -import os -from pip._vendor import toml -import shutil - -from .envbuild import BuildEnvironment -from .wrappers import Pep517HookCaller -from .dirtools import tempdir, mkdir_p -from .compat import FileNotFoundError - -log = logging.getLogger(__name__) - - -def validate_system(system): - """ - Ensure build system has the requisite fields. - """ - required = {'requires', 'build-backend'} - if not (required <= set(system)): - message = "Missing required fields: {missing}".format( - missing=required-set(system), - ) - raise ValueError(message) - - -def load_system(source_dir): - """ - Load the build system from a source dir (pyproject.toml). - """ - pyproject = os.path.join(source_dir, 'pyproject.toml') - with open(pyproject) as f: - pyproject_data = toml.load(f) - return pyproject_data['build-system'] - - -def compat_system(source_dir): - """ - Given a source dir, attempt to get a build system backend - and requirements from pyproject.toml. Fallback to - setuptools but only if the file was not found or a build - system was not indicated. - """ - try: - system = load_system(source_dir) - except (FileNotFoundError, KeyError): - system = {} - system.setdefault( - 'build-backend', - 'setuptools.build_meta:__legacy__', - ) - system.setdefault('requires', ['setuptools', 'wheel']) - return system - - -def _do_build(hooks, env, dist, dest): - get_requires_name = 'get_requires_for_build_{dist}'.format(**locals()) - get_requires = getattr(hooks, get_requires_name) - reqs = get_requires({}) - log.info('Got build requires: %s', reqs) - - env.pip_install(reqs) - log.info('Installed dynamic build dependencies') - - with tempdir() as td: - log.info('Trying to build %s in %s', dist, td) - build_name = 'build_{dist}'.format(**locals()) - build = getattr(hooks, build_name) - filename = build(td, {}) - source = os.path.join(td, filename) - shutil.move(source, os.path.join(dest, os.path.basename(filename))) - - -def build(source_dir, dist, dest=None, system=None): - system = system or load_system(source_dir) - dest = os.path.join(source_dir, dest or 'dist') - mkdir_p(dest) - - validate_system(system) - hooks = Pep517HookCaller( - source_dir, system['build-backend'], system.get('backend-path') - ) - - with BuildEnvironment() as env: - env.pip_install(system['requires']) - _do_build(hooks, env, dist, dest) - - -parser = argparse.ArgumentParser() -parser.add_argument( - 'source_dir', - help="A directory containing pyproject.toml", -) -parser.add_argument( - '--binary', '-b', - action='store_true', - default=False, -) -parser.add_argument( - '--source', '-s', - action='store_true', - default=False, -) -parser.add_argument( - '--out-dir', '-o', - help="Destination in which to save the builds relative to source dir", -) - - -def main(args): - log.warning('pep517.build is deprecated. ' - 'Consider switching to https://pypi.org/project/build/') - - # determine which dists to build - dists = list(filter(None, ( - 'sdist' if args.source or not args.binary else None, - 'wheel' if args.binary or not args.source else None, - ))) - - for dist in dists: - build(args.source_dir, dist, args.out_dir) - - -if __name__ == '__main__': - main(parser.parse_args()) diff --git a/env/Lib/site-packages/pip/_vendor/pep517/check.py b/env/Lib/site-packages/pip/_vendor/pep517/check.py deleted file mode 100644 index decab8a3..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/check.py +++ /dev/null @@ -1,206 +0,0 @@ -"""Check a project and backend by attempting to build using PEP 517 hooks. -""" -import argparse -import logging -import os -from os.path import isfile, join as pjoin -from pip._vendor.toml import TomlDecodeError, load as toml_load -import shutil -from subprocess import CalledProcessError -import sys -import tarfile -from tempfile import mkdtemp -import zipfile - -from .colorlog import enable_colourful_output -from .envbuild import BuildEnvironment -from .wrappers import Pep517HookCaller - -log = logging.getLogger(__name__) - - -def check_build_sdist(hooks, build_sys_requires): - with BuildEnvironment() as env: - try: - env.pip_install(build_sys_requires) - log.info('Installed static build dependencies') - except CalledProcessError: - log.error('Failed to install static build dependencies') - return False - - try: - reqs = hooks.get_requires_for_build_sdist({}) - log.info('Got build requires: %s', reqs) - except Exception: - log.error('Failure in get_requires_for_build_sdist', exc_info=True) - return False - - try: - env.pip_install(reqs) - log.info('Installed dynamic build dependencies') - except CalledProcessError: - log.error('Failed to install dynamic build dependencies') - return False - - td = mkdtemp() - log.info('Trying to build sdist in %s', td) - try: - try: - filename = hooks.build_sdist(td, {}) - log.info('build_sdist returned %r', filename) - except Exception: - log.info('Failure in build_sdist', exc_info=True) - return False - - if not filename.endswith('.tar.gz'): - log.error( - "Filename %s doesn't have .tar.gz extension", filename) - return False - - path = pjoin(td, filename) - if isfile(path): - log.info("Output file %s exists", path) - else: - log.error("Output file %s does not exist", path) - return False - - if tarfile.is_tarfile(path): - log.info("Output file is a tar file") - else: - log.error("Output file is not a tar file") - return False - - finally: - shutil.rmtree(td) - - return True - - -def check_build_wheel(hooks, build_sys_requires): - with BuildEnvironment() as env: - try: - env.pip_install(build_sys_requires) - log.info('Installed static build dependencies') - except CalledProcessError: - log.error('Failed to install static build dependencies') - return False - - try: - reqs = hooks.get_requires_for_build_wheel({}) - log.info('Got build requires: %s', reqs) - except Exception: - log.error('Failure in get_requires_for_build_sdist', exc_info=True) - return False - - try: - env.pip_install(reqs) - log.info('Installed dynamic build dependencies') - except CalledProcessError: - log.error('Failed to install dynamic build dependencies') - return False - - td = mkdtemp() - log.info('Trying to build wheel in %s', td) - try: - try: - filename = hooks.build_wheel(td, {}) - log.info('build_wheel returned %r', filename) - except Exception: - log.info('Failure in build_wheel', exc_info=True) - return False - - if not filename.endswith('.whl'): - log.error("Filename %s doesn't have .whl extension", filename) - return False - - path = pjoin(td, filename) - if isfile(path): - log.info("Output file %s exists", path) - else: - log.error("Output file %s does not exist", path) - return False - - if zipfile.is_zipfile(path): - log.info("Output file is a zip file") - else: - log.error("Output file is not a zip file") - return False - - finally: - shutil.rmtree(td) - - return True - - -def check(source_dir): - pyproject = pjoin(source_dir, 'pyproject.toml') - if isfile(pyproject): - log.info('Found pyproject.toml') - else: - log.error('Missing pyproject.toml') - return False - - try: - with open(pyproject) as f: - pyproject_data = toml_load(f) - # Ensure the mandatory data can be loaded - buildsys = pyproject_data['build-system'] - requires = buildsys['requires'] - backend = buildsys['build-backend'] - backend_path = buildsys.get('backend-path') - log.info('Loaded pyproject.toml') - except (TomlDecodeError, KeyError): - log.error("Invalid pyproject.toml", exc_info=True) - return False - - hooks = Pep517HookCaller(source_dir, backend, backend_path) - - sdist_ok = check_build_sdist(hooks, requires) - wheel_ok = check_build_wheel(hooks, requires) - - if not sdist_ok: - log.warning('Sdist checks failed; scroll up to see') - if not wheel_ok: - log.warning('Wheel checks failed') - - return sdist_ok - - -def main(argv=None): - log.warning('pep517.check is deprecated. ' - 'Consider switching to https://pypi.org/project/build/') - - ap = argparse.ArgumentParser() - ap.add_argument( - 'source_dir', - help="A directory containing pyproject.toml") - args = ap.parse_args(argv) - - enable_colourful_output() - - ok = check(args.source_dir) - - if ok: - print(ansi('Checks passed', 'green')) - else: - print(ansi('Checks failed', 'red')) - sys.exit(1) - - -ansi_codes = { - 'reset': '\x1b[0m', - 'bold': '\x1b[1m', - 'red': '\x1b[31m', - 'green': '\x1b[32m', -} - - -def ansi(s, attr): - if os.name != 'nt' and sys.stdout.isatty(): - return ansi_codes[attr] + str(s) + ansi_codes['reset'] - else: - return str(s) - - -if __name__ == '__main__': - main() diff --git a/env/Lib/site-packages/pip/_vendor/pep517/colorlog.py b/env/Lib/site-packages/pip/_vendor/pep517/colorlog.py deleted file mode 100644 index 69c8a59d..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/colorlog.py +++ /dev/null @@ -1,115 +0,0 @@ -"""Nicer log formatting with colours. - -Code copied from Tornado, Apache licensed. -""" -# Copyright 2012 Facebook -# -# Licensed under the Apache License, Version 2.0 (the "License"); you may -# not use this file except in compliance with the License. You may obtain -# a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT -# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the -# License for the specific language governing permissions and limitations -# under the License. - -import logging -import sys - -try: - import curses -except ImportError: - curses = None - - -def _stderr_supports_color(): - color = False - if curses and hasattr(sys.stderr, 'isatty') and sys.stderr.isatty(): - try: - curses.setupterm() - if curses.tigetnum("colors") > 0: - color = True - except Exception: - pass - return color - - -class LogFormatter(logging.Formatter): - """Log formatter with colour support - """ - DEFAULT_COLORS = { - logging.INFO: 2, # Green - logging.WARNING: 3, # Yellow - logging.ERROR: 1, # Red - logging.CRITICAL: 1, - } - - def __init__(self, color=True, datefmt=None): - r""" - :arg bool color: Enables color support. - :arg string fmt: Log message format. - It will be applied to the attributes dict of log records. The - text between ``%(color)s`` and ``%(end_color)s`` will be colored - depending on the level if color support is on. - :arg dict colors: color mappings from logging level to terminal color - code - :arg string datefmt: Datetime format. - Used for formatting ``(asctime)`` placeholder in ``prefix_fmt``. - .. versionchanged:: 3.2 - Added ``fmt`` and ``datefmt`` arguments. - """ - logging.Formatter.__init__(self, datefmt=datefmt) - self._colors = {} - if color and _stderr_supports_color(): - # The curses module has some str/bytes confusion in - # python3. Until version 3.2.3, most methods return - # bytes, but only accept strings. In addition, we want to - # output these strings with the logging module, which - # works with unicode strings. The explicit calls to - # unicode() below are harmless in python2 but will do the - # right conversion in python 3. - fg_color = (curses.tigetstr("setaf") or - curses.tigetstr("setf") or "") - if (3, 0) < sys.version_info < (3, 2, 3): - fg_color = str(fg_color, "ascii") - - for levelno, code in self.DEFAULT_COLORS.items(): - self._colors[levelno] = str( - curses.tparm(fg_color, code), "ascii") - self._normal = str(curses.tigetstr("sgr0"), "ascii") - - scr = curses.initscr() - self.termwidth = scr.getmaxyx()[1] - curses.endwin() - else: - self._normal = '' - # Default width is usually 80, but too wide is - # worse than too narrow - self.termwidth = 70 - - def formatMessage(self, record): - mlen = len(record.message) - right_text = '{initial}-{name}'.format(initial=record.levelname[0], - name=record.name) - if mlen + len(right_text) < self.termwidth: - space = ' ' * (self.termwidth - (mlen + len(right_text))) - else: - space = ' ' - - if record.levelno in self._colors: - start_color = self._colors[record.levelno] - end_color = self._normal - else: - start_color = end_color = '' - - return record.message + space + start_color + right_text + end_color - - -def enable_colourful_output(level=logging.INFO): - handler = logging.StreamHandler() - handler.setFormatter(LogFormatter()) - logging.root.addHandler(handler) - logging.root.setLevel(level) diff --git a/env/Lib/site-packages/pip/_vendor/pep517/compat.py b/env/Lib/site-packages/pip/_vendor/pep517/compat.py deleted file mode 100644 index 8432acb7..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/compat.py +++ /dev/null @@ -1,34 +0,0 @@ -"""Python 2/3 compatibility""" -import json -import sys - - -# Handle reading and writing JSON in UTF-8, on Python 3 and 2. - -if sys.version_info[0] >= 3: - # Python 3 - def write_json(obj, path, **kwargs): - with open(path, 'w', encoding='utf-8') as f: - json.dump(obj, f, **kwargs) - - def read_json(path): - with open(path, 'r', encoding='utf-8') as f: - return json.load(f) - -else: - # Python 2 - def write_json(obj, path, **kwargs): - with open(path, 'wb') as f: - json.dump(obj, f, encoding='utf-8', **kwargs) - - def read_json(path): - with open(path, 'rb') as f: - return json.load(f) - - -# FileNotFoundError - -try: - FileNotFoundError = FileNotFoundError -except NameError: - FileNotFoundError = IOError diff --git a/env/Lib/site-packages/pip/_vendor/pep517/dirtools.py b/env/Lib/site-packages/pip/_vendor/pep517/dirtools.py deleted file mode 100644 index 58c6ca0c..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/dirtools.py +++ /dev/null @@ -1,44 +0,0 @@ -import os -import io -import contextlib -import tempfile -import shutil -import errno -import zipfile - - -@contextlib.contextmanager -def tempdir(): - """Create a temporary directory in a context manager.""" - td = tempfile.mkdtemp() - try: - yield td - finally: - shutil.rmtree(td) - - -def mkdir_p(*args, **kwargs): - """Like `mkdir`, but does not raise an exception if the - directory already exists. - """ - try: - return os.mkdir(*args, **kwargs) - except OSError as exc: - if exc.errno != errno.EEXIST: - raise - - -def dir_to_zipfile(root): - """Construct an in-memory zip file for a directory.""" - buffer = io.BytesIO() - zip_file = zipfile.ZipFile(buffer, 'w') - for root, dirs, files in os.walk(root): - for path in dirs: - fs_path = os.path.join(root, path) - rel_path = os.path.relpath(fs_path, root) - zip_file.writestr(rel_path + '/', '') - for path in files: - fs_path = os.path.join(root, path) - rel_path = os.path.relpath(fs_path, root) - zip_file.write(fs_path, rel_path) - return zip_file diff --git a/env/Lib/site-packages/pip/_vendor/pep517/envbuild.py b/env/Lib/site-packages/pip/_vendor/pep517/envbuild.py deleted file mode 100644 index 4088dcdb..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/envbuild.py +++ /dev/null @@ -1,167 +0,0 @@ -"""Build wheels/sdists by installing build deps to a temporary environment. -""" - -import os -import logging -from pip._vendor import toml -import shutil -from subprocess import check_call -import sys -from sysconfig import get_paths -from tempfile import mkdtemp - -from .wrappers import Pep517HookCaller, LoggerWrapper - -log = logging.getLogger(__name__) - - -def _load_pyproject(source_dir): - with open(os.path.join(source_dir, 'pyproject.toml')) as f: - pyproject_data = toml.load(f) - buildsys = pyproject_data['build-system'] - return ( - buildsys['requires'], - buildsys['build-backend'], - buildsys.get('backend-path'), - ) - - -class BuildEnvironment(object): - """Context manager to install build deps in a simple temporary environment - - Based on code I wrote for pip, which is MIT licensed. - """ - # Copyright (c) 2008-2016 The pip developers (see AUTHORS.txt file) - # - # Permission is hereby granted, free of charge, to any person obtaining - # a copy of this software and associated documentation files (the - # "Software"), to deal in the Software without restriction, including - # without limitation the rights to use, copy, modify, merge, publish, - # distribute, sublicense, and/or sell copies of the Software, and to - # permit persons to whom the Software is furnished to do so, subject to - # the following conditions: - # - # The above copyright notice and this permission notice shall be - # included in all copies or substantial portions of the Software. - # - # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, - # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND - # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE - # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION - # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION - # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - - path = None - - def __init__(self, cleanup=True): - self._cleanup = cleanup - - def __enter__(self): - self.path = mkdtemp(prefix='pep517-build-env-') - log.info('Temporary build environment: %s', self.path) - - self.save_path = os.environ.get('PATH', None) - self.save_pythonpath = os.environ.get('PYTHONPATH', None) - - install_scheme = 'nt' if (os.name == 'nt') else 'posix_prefix' - install_dirs = get_paths(install_scheme, vars={ - 'base': self.path, - 'platbase': self.path, - }) - - scripts = install_dirs['scripts'] - if self.save_path: - os.environ['PATH'] = scripts + os.pathsep + self.save_path - else: - os.environ['PATH'] = scripts + os.pathsep + os.defpath - - if install_dirs['purelib'] == install_dirs['platlib']: - lib_dirs = install_dirs['purelib'] - else: - lib_dirs = install_dirs['purelib'] + os.pathsep + \ - install_dirs['platlib'] - if self.save_pythonpath: - os.environ['PYTHONPATH'] = lib_dirs + os.pathsep + \ - self.save_pythonpath - else: - os.environ['PYTHONPATH'] = lib_dirs - - return self - - def pip_install(self, reqs): - """Install dependencies into this env by calling pip in a subprocess""" - if not reqs: - return - log.info('Calling pip to install %s', reqs) - cmd = [ - sys.executable, '-m', 'pip', 'install', '--ignore-installed', - '--prefix', self.path] + list(reqs) - check_call( - cmd, - stdout=LoggerWrapper(log, logging.INFO), - stderr=LoggerWrapper(log, logging.ERROR), - ) - - def __exit__(self, exc_type, exc_val, exc_tb): - needs_cleanup = ( - self._cleanup and - self.path is not None and - os.path.isdir(self.path) - ) - if needs_cleanup: - shutil.rmtree(self.path) - - if self.save_path is None: - os.environ.pop('PATH', None) - else: - os.environ['PATH'] = self.save_path - - if self.save_pythonpath is None: - os.environ.pop('PYTHONPATH', None) - else: - os.environ['PYTHONPATH'] = self.save_pythonpath - - -def build_wheel(source_dir, wheel_dir, config_settings=None): - """Build a wheel from a source directory using PEP 517 hooks. - - :param str source_dir: Source directory containing pyproject.toml - :param str wheel_dir: Target directory to create wheel in - :param dict config_settings: Options to pass to build backend - - This is a blocking function which will run pip in a subprocess to install - build requirements. - """ - if config_settings is None: - config_settings = {} - requires, backend, backend_path = _load_pyproject(source_dir) - hooks = Pep517HookCaller(source_dir, backend, backend_path) - - with BuildEnvironment() as env: - env.pip_install(requires) - reqs = hooks.get_requires_for_build_wheel(config_settings) - env.pip_install(reqs) - return hooks.build_wheel(wheel_dir, config_settings) - - -def build_sdist(source_dir, sdist_dir, config_settings=None): - """Build an sdist from a source directory using PEP 517 hooks. - - :param str source_dir: Source directory containing pyproject.toml - :param str sdist_dir: Target directory to place sdist in - :param dict config_settings: Options to pass to build backend - - This is a blocking function which will run pip in a subprocess to install - build requirements. - """ - if config_settings is None: - config_settings = {} - requires, backend, backend_path = _load_pyproject(source_dir) - hooks = Pep517HookCaller(source_dir, backend, backend_path) - - with BuildEnvironment() as env: - env.pip_install(requires) - reqs = hooks.get_requires_for_build_sdist(config_settings) - env.pip_install(reqs) - return hooks.build_sdist(sdist_dir, config_settings) diff --git a/env/Lib/site-packages/pip/_vendor/pep517/in_process/__init__.py b/env/Lib/site-packages/pip/_vendor/pep517/in_process/__init__.py deleted file mode 100644 index c932313b..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/in_process/__init__.py +++ /dev/null @@ -1,17 +0,0 @@ -"""This is a subpackage because the directory is on sys.path for _in_process.py - -The subpackage should stay as empty as possible to avoid shadowing modules that -the backend might import. -""" -from os.path import dirname, abspath, join as pjoin -from contextlib import contextmanager - -try: - import importlib.resources as resources - - def _in_proc_script_path(): - return resources.path(__package__, '_in_process.py') -except ImportError: - @contextmanager - def _in_proc_script_path(): - yield pjoin(dirname(abspath(__file__)), '_in_process.py') diff --git a/env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index e2722f2ea3c2184a72df767f0512df0257b1aacd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 943 zcmYe~<>g{vU|^UdaWK`GiGkrUh=Ytd7#J8F7#J9e6Brm6QW&BbQW#U1au{=&qL^}- zqnLA9qF5P0V$3;gx$IHwj0{y0DU2yBIUKp1QJjnnDXb}MEeugy;S70lEDWjKl~Ifg zAehRY!VZ#YW{l#BWXNMOU`SyJX3*rQ+7XhGS*(y*tdOWsT$)snn4F!Mo~n?Pnw(f# zoT^Zgk*biAS(KVwl3!E_Qk9>lP+VE8SCCkep^%neq!6E(7hh16pPX7;tXELU#TAl~ zifm4CMt*5dib8QoVx>Z2u|jHYK?#^qkY8M!nUs^NP?E2ZSeBoeqEMWXn37+fnU}7R zo1apelUl4$l95=#1#&=AVsdtBUW!6)W_m`6LS}A3eo=`Y*Go{SX)@npPsuFGOUzBZ z#h#c{406{kmaP2DJWa-1e98HFC8-r9xrup+>8VA2$sirbn1z9X!5I|RJPZsBB@7D~ zOPEp^7cvDitYq@5;zRYCCi5-MqSWI2(xT+l;#(|Wi@4+Cp#c^jzmlN{6tQ69SC_L@ zOlWaxQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vVr=N?zpKGwEV@$BCuWN9K zYmkCjOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOsxH*J;+TTW0{!^1)V!4ZBK?BY z0#ieCeMC&?$H!;pWtPOp>lIYq5`p<6zBsukv!Em%<aCgSi<v-S!B_-hV+|URV6g-^ zXi6AMm`a$N8JihX7@L{G7#JB+7=js!*cccXG+A!37Jx#$2xMLnGXn#|Esps3w9K5; z_;_$|AQ9XQ3=Cik`9Z-B(!ju^$#aW6K0YNsIX?atdp;y>A<QZQMN$zj$W$(9eCA{( z6|sT@gdu4mCo@S89yLYmFe`3xdxDdSYf({t5t19g(FAhHEe;z<TC-yWxkiA2fq{ip Sgpr4diIInihlz)gi4g$Z4fziM diff --git a/env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/_in_process.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/_in_process.cpython-39.pyc deleted file mode 100644 index 3872c9f3274e7d6f9553553705736291542f8262..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8305 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 I$Z|0P06sI>2LJ#7 diff --git a/env/Lib/site-packages/pip/_vendor/pep517/in_process/_in_process.py b/env/Lib/site-packages/pip/_vendor/pep517/in_process/_in_process.py deleted file mode 100644 index a536b03e..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/in_process/_in_process.py +++ /dev/null @@ -1,280 +0,0 @@ -"""This is invoked in a subprocess to call the build backend hooks. - -It expects: -- Command line args: hook_name, control_dir -- Environment variables: - PEP517_BUILD_BACKEND=entry.point:spec - PEP517_BACKEND_PATH=paths (separated with os.pathsep) -- control_dir/input.json: - - {"kwargs": {...}} - -Results: -- control_dir/output.json - - {"return_val": ...} -""" -from glob import glob -from importlib import import_module -import json -import os -import os.path -from os.path import join as pjoin -import re -import shutil -import sys -import traceback - -# This file is run as a script, and `import compat` is not zip-safe, so we -# include write_json() and read_json() from compat.py. -# -# Handle reading and writing JSON in UTF-8, on Python 3 and 2. - -if sys.version_info[0] >= 3: - # Python 3 - def write_json(obj, path, **kwargs): - with open(path, 'w', encoding='utf-8') as f: - json.dump(obj, f, **kwargs) - - def read_json(path): - with open(path, 'r', encoding='utf-8') as f: - return json.load(f) - -else: - # Python 2 - def write_json(obj, path, **kwargs): - with open(path, 'wb') as f: - json.dump(obj, f, encoding='utf-8', **kwargs) - - def read_json(path): - with open(path, 'rb') as f: - return json.load(f) - - -class BackendUnavailable(Exception): - """Raised if we cannot import the backend""" - def __init__(self, traceback): - self.traceback = traceback - - -class BackendInvalid(Exception): - """Raised if the backend is invalid""" - def __init__(self, message): - self.message = message - - -class HookMissing(Exception): - """Raised if a hook is missing and we are not executing the fallback""" - - -def contained_in(filename, directory): - """Test if a file is located within the given directory.""" - filename = os.path.normcase(os.path.abspath(filename)) - directory = os.path.normcase(os.path.abspath(directory)) - return os.path.commonprefix([filename, directory]) == directory - - -def _build_backend(): - """Find and load the build backend""" - # Add in-tree backend directories to the front of sys.path. - backend_path = os.environ.get('PEP517_BACKEND_PATH') - if backend_path: - extra_pathitems = backend_path.split(os.pathsep) - sys.path[:0] = extra_pathitems - - ep = os.environ['PEP517_BUILD_BACKEND'] - mod_path, _, obj_path = ep.partition(':') - try: - obj = import_module(mod_path) - except ImportError: - raise BackendUnavailable(traceback.format_exc()) - - if backend_path: - if not any( - contained_in(obj.__file__, path) - for path in extra_pathitems - ): - raise BackendInvalid("Backend was not loaded from backend-path") - - if obj_path: - for path_part in obj_path.split('.'): - obj = getattr(obj, path_part) - return obj - - -def get_requires_for_build_wheel(config_settings): - """Invoke the optional get_requires_for_build_wheel hook - - Returns [] if the hook is not defined. - """ - backend = _build_backend() - try: - hook = backend.get_requires_for_build_wheel - except AttributeError: - return [] - else: - return hook(config_settings) - - -def prepare_metadata_for_build_wheel( - metadata_directory, config_settings, _allow_fallback): - """Invoke optional prepare_metadata_for_build_wheel - - Implements a fallback by building a wheel if the hook isn't defined, - unless _allow_fallback is False in which case HookMissing is raised. - """ - backend = _build_backend() - try: - hook = backend.prepare_metadata_for_build_wheel - except AttributeError: - if not _allow_fallback: - raise HookMissing() - return _get_wheel_metadata_from_wheel(backend, metadata_directory, - config_settings) - else: - return hook(metadata_directory, config_settings) - - -WHEEL_BUILT_MARKER = 'PEP517_ALREADY_BUILT_WHEEL' - - -def _dist_info_files(whl_zip): - """Identify the .dist-info folder inside a wheel ZipFile.""" - res = [] - for path in whl_zip.namelist(): - m = re.match(r'[^/\\]+-[^/\\]+\.dist-info/', path) - if m: - res.append(path) - if res: - return res - raise Exception("No .dist-info folder found in wheel") - - -def _get_wheel_metadata_from_wheel( - backend, metadata_directory, config_settings): - """Build a wheel and extract the metadata from it. - - Fallback for when the build backend does not - define the 'get_wheel_metadata' hook. - """ - from zipfile import ZipFile - whl_basename = backend.build_wheel(metadata_directory, config_settings) - with open(os.path.join(metadata_directory, WHEEL_BUILT_MARKER), 'wb'): - pass # Touch marker file - - whl_file = os.path.join(metadata_directory, whl_basename) - with ZipFile(whl_file) as zipf: - dist_info = _dist_info_files(zipf) - zipf.extractall(path=metadata_directory, members=dist_info) - return dist_info[0].split('/')[0] - - -def _find_already_built_wheel(metadata_directory): - """Check for a wheel already built during the get_wheel_metadata hook. - """ - if not metadata_directory: - return None - metadata_parent = os.path.dirname(metadata_directory) - if not os.path.isfile(pjoin(metadata_parent, WHEEL_BUILT_MARKER)): - return None - - whl_files = glob(os.path.join(metadata_parent, '*.whl')) - if not whl_files: - print('Found wheel built marker, but no .whl files') - return None - if len(whl_files) > 1: - print('Found multiple .whl files; unspecified behaviour. ' - 'Will call build_wheel.') - return None - - # Exactly one .whl file - return whl_files[0] - - -def build_wheel(wheel_directory, config_settings, metadata_directory=None): - """Invoke the mandatory build_wheel hook. - - If a wheel was already built in the - prepare_metadata_for_build_wheel fallback, this - will copy it rather than rebuilding the wheel. - """ - prebuilt_whl = _find_already_built_wheel(metadata_directory) - if prebuilt_whl: - shutil.copy2(prebuilt_whl, wheel_directory) - return os.path.basename(prebuilt_whl) - - return _build_backend().build_wheel(wheel_directory, config_settings, - metadata_directory) - - -def get_requires_for_build_sdist(config_settings): - """Invoke the optional get_requires_for_build_wheel hook - - Returns [] if the hook is not defined. - """ - backend = _build_backend() - try: - hook = backend.get_requires_for_build_sdist - except AttributeError: - return [] - else: - return hook(config_settings) - - -class _DummyException(Exception): - """Nothing should ever raise this exception""" - - -class GotUnsupportedOperation(Exception): - """For internal use when backend raises UnsupportedOperation""" - def __init__(self, traceback): - self.traceback = traceback - - -def build_sdist(sdist_directory, config_settings): - """Invoke the mandatory build_sdist hook.""" - backend = _build_backend() - try: - return backend.build_sdist(sdist_directory, config_settings) - except getattr(backend, 'UnsupportedOperation', _DummyException): - raise GotUnsupportedOperation(traceback.format_exc()) - - -HOOK_NAMES = { - 'get_requires_for_build_wheel', - 'prepare_metadata_for_build_wheel', - 'build_wheel', - 'get_requires_for_build_sdist', - 'build_sdist', -} - - -def main(): - if len(sys.argv) < 3: - sys.exit("Needs args: hook_name, control_dir") - hook_name = sys.argv[1] - control_dir = sys.argv[2] - if hook_name not in HOOK_NAMES: - sys.exit("Unknown hook: %s" % hook_name) - hook = globals()[hook_name] - - hook_input = read_json(pjoin(control_dir, 'input.json')) - - json_out = {'unsupported': False, 'return_val': None} - try: - json_out['return_val'] = hook(**hook_input['kwargs']) - except BackendUnavailable as e: - json_out['no_backend'] = True - json_out['traceback'] = e.traceback - except BackendInvalid as e: - json_out['backend_invalid'] = True - json_out['backend_error'] = e.message - except GotUnsupportedOperation as e: - json_out['unsupported'] = True - json_out['traceback'] = e.traceback - except HookMissing: - json_out['hook_missing'] = True - - write_json(json_out, pjoin(control_dir, 'output.json'), indent=2) - - -if __name__ == '__main__': - main() diff --git a/env/Lib/site-packages/pip/_vendor/pep517/meta.py b/env/Lib/site-packages/pip/_vendor/pep517/meta.py deleted file mode 100644 index d525de5c..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/meta.py +++ /dev/null @@ -1,92 +0,0 @@ -"""Build metadata for a project using PEP 517 hooks. -""" -import argparse -import logging -import os -import shutil -import functools - -try: - import importlib.metadata as imp_meta -except ImportError: - import importlib_metadata as imp_meta - -try: - from zipfile import Path -except ImportError: - from zipp import Path - -from .envbuild import BuildEnvironment -from .wrappers import Pep517HookCaller, quiet_subprocess_runner -from .dirtools import tempdir, mkdir_p, dir_to_zipfile -from .build import validate_system, load_system, compat_system - -log = logging.getLogger(__name__) - - -def _prep_meta(hooks, env, dest): - reqs = hooks.get_requires_for_build_wheel({}) - log.info('Got build requires: %s', reqs) - - env.pip_install(reqs) - log.info('Installed dynamic build dependencies') - - with tempdir() as td: - log.info('Trying to build metadata in %s', td) - filename = hooks.prepare_metadata_for_build_wheel(td, {}) - source = os.path.join(td, filename) - shutil.move(source, os.path.join(dest, os.path.basename(filename))) - - -def build(source_dir='.', dest=None, system=None): - system = system or load_system(source_dir) - dest = os.path.join(source_dir, dest or 'dist') - mkdir_p(dest) - validate_system(system) - hooks = Pep517HookCaller( - source_dir, system['build-backend'], system.get('backend-path') - ) - - with hooks.subprocess_runner(quiet_subprocess_runner): - with BuildEnvironment() as env: - env.pip_install(system['requires']) - _prep_meta(hooks, env, dest) - - -def build_as_zip(builder=build): - with tempdir() as out_dir: - builder(dest=out_dir) - return dir_to_zipfile(out_dir) - - -def load(root): - """ - Given a source directory (root) of a package, - return an importlib.metadata.Distribution object - with metadata build from that package. - """ - root = os.path.expanduser(root) - system = compat_system(root) - builder = functools.partial(build, source_dir=root, system=system) - path = Path(build_as_zip(builder)) - return imp_meta.PathDistribution(path) - - -parser = argparse.ArgumentParser() -parser.add_argument( - 'source_dir', - help="A directory containing pyproject.toml", -) -parser.add_argument( - '--out-dir', '-o', - help="Destination in which to save the builds relative to source dir", -) - - -def main(): - args = parser.parse_args() - build(args.source_dir, args.out_dir) - - -if __name__ == '__main__': - main() diff --git a/env/Lib/site-packages/pip/_vendor/pep517/wrappers.py b/env/Lib/site-packages/pip/_vendor/pep517/wrappers.py deleted file mode 100644 index 00974aa8..00000000 --- a/env/Lib/site-packages/pip/_vendor/pep517/wrappers.py +++ /dev/null @@ -1,318 +0,0 @@ -import threading -from contextlib import contextmanager -import os -from os.path import abspath, join as pjoin -import shutil -from subprocess import check_call, check_output, STDOUT -import sys -from tempfile import mkdtemp - -from . import compat -from .in_process import _in_proc_script_path - -__all__ = [ - 'BackendUnavailable', - 'BackendInvalid', - 'HookMissing', - 'UnsupportedOperation', - 'default_subprocess_runner', - 'quiet_subprocess_runner', - 'Pep517HookCaller', -] - - -@contextmanager -def tempdir(): - td = mkdtemp() - try: - yield td - finally: - shutil.rmtree(td) - - -class BackendUnavailable(Exception): - """Will be raised if the backend cannot be imported in the hook process.""" - def __init__(self, traceback): - self.traceback = traceback - - -class BackendInvalid(Exception): - """Will be raised if the backend is invalid.""" - def __init__(self, backend_name, backend_path, message): - self.backend_name = backend_name - self.backend_path = backend_path - self.message = message - - -class HookMissing(Exception): - """Will be raised on missing hooks.""" - def __init__(self, hook_name): - super(HookMissing, self).__init__(hook_name) - self.hook_name = hook_name - - -class UnsupportedOperation(Exception): - """May be raised by build_sdist if the backend indicates that it can't.""" - def __init__(self, traceback): - self.traceback = traceback - - -def default_subprocess_runner(cmd, cwd=None, extra_environ=None): - """The default method of calling the wrapper subprocess.""" - env = os.environ.copy() - if extra_environ: - env.update(extra_environ) - - check_call(cmd, cwd=cwd, env=env) - - -def quiet_subprocess_runner(cmd, cwd=None, extra_environ=None): - """A method of calling the wrapper subprocess while suppressing output.""" - env = os.environ.copy() - if extra_environ: - env.update(extra_environ) - - check_output(cmd, cwd=cwd, env=env, stderr=STDOUT) - - -def norm_and_check(source_tree, requested): - """Normalise and check a backend path. - - Ensure that the requested backend path is specified as a relative path, - and resolves to a location under the given source tree. - - Return an absolute version of the requested path. - """ - if os.path.isabs(requested): - raise ValueError("paths must be relative") - - abs_source = os.path.abspath(source_tree) - abs_requested = os.path.normpath(os.path.join(abs_source, requested)) - # We have to use commonprefix for Python 2.7 compatibility. So we - # normalise case to avoid problems because commonprefix is a character - # based comparison :-( - norm_source = os.path.normcase(abs_source) - norm_requested = os.path.normcase(abs_requested) - if os.path.commonprefix([norm_source, norm_requested]) != norm_source: - raise ValueError("paths must be inside source tree") - - return abs_requested - - -class Pep517HookCaller(object): - """A wrapper around a source directory to be built with a PEP 517 backend. - - :param source_dir: The path to the source directory, containing - pyproject.toml. - :param build_backend: The build backend spec, as per PEP 517, from - pyproject.toml. - :param backend_path: The backend path, as per PEP 517, from pyproject.toml. - :param runner: A callable that invokes the wrapper subprocess. - :param python_executable: The Python executable used to invoke the backend - - The 'runner', if provided, must expect the following: - - - cmd: a list of strings representing the command and arguments to - execute, as would be passed to e.g. 'subprocess.check_call'. - - cwd: a string representing the working directory that must be - used for the subprocess. Corresponds to the provided source_dir. - - extra_environ: a dict mapping environment variable names to values - which must be set for the subprocess execution. - """ - def __init__( - self, - source_dir, - build_backend, - backend_path=None, - runner=None, - python_executable=None, - ): - if runner is None: - runner = default_subprocess_runner - - self.source_dir = abspath(source_dir) - self.build_backend = build_backend - if backend_path: - backend_path = [ - norm_and_check(self.source_dir, p) for p in backend_path - ] - self.backend_path = backend_path - self._subprocess_runner = runner - if not python_executable: - python_executable = sys.executable - self.python_executable = python_executable - - @contextmanager - def subprocess_runner(self, runner): - """A context manager for temporarily overriding the default subprocess - runner. - """ - prev = self._subprocess_runner - self._subprocess_runner = runner - try: - yield - finally: - self._subprocess_runner = prev - - def get_requires_for_build_wheel(self, config_settings=None): - """Identify packages required for building a wheel - - Returns a list of dependency specifications, e.g.:: - - ["wheel >= 0.25", "setuptools"] - - This does not include requirements specified in pyproject.toml. - It returns the result of calling the equivalently named hook in a - subprocess. - """ - return self._call_hook('get_requires_for_build_wheel', { - 'config_settings': config_settings - }) - - def prepare_metadata_for_build_wheel( - self, metadata_directory, config_settings=None, - _allow_fallback=True): - """Prepare a ``*.dist-info`` folder with metadata for this project. - - Returns the name of the newly created folder. - - If the build backend defines a hook with this name, it will be called - in a subprocess. If not, the backend will be asked to build a wheel, - and the dist-info extracted from that (unless _allow_fallback is - False). - """ - return self._call_hook('prepare_metadata_for_build_wheel', { - 'metadata_directory': abspath(metadata_directory), - 'config_settings': config_settings, - '_allow_fallback': _allow_fallback, - }) - - def build_wheel( - self, wheel_directory, config_settings=None, - metadata_directory=None): - """Build a wheel from this project. - - Returns the name of the newly created file. - - In general, this will call the 'build_wheel' hook in the backend. - However, if that was previously called by - 'prepare_metadata_for_build_wheel', and the same metadata_directory is - used, the previously built wheel will be copied to wheel_directory. - """ - if metadata_directory is not None: - metadata_directory = abspath(metadata_directory) - return self._call_hook('build_wheel', { - 'wheel_directory': abspath(wheel_directory), - 'config_settings': config_settings, - 'metadata_directory': metadata_directory, - }) - - def get_requires_for_build_sdist(self, config_settings=None): - """Identify packages required for building a wheel - - Returns a list of dependency specifications, e.g.:: - - ["setuptools >= 26"] - - This does not include requirements specified in pyproject.toml. - It returns the result of calling the equivalently named hook in a - subprocess. - """ - return self._call_hook('get_requires_for_build_sdist', { - 'config_settings': config_settings - }) - - def build_sdist(self, sdist_directory, config_settings=None): - """Build an sdist from this project. - - Returns the name of the newly created file. - - This calls the 'build_sdist' backend hook in a subprocess. - """ - return self._call_hook('build_sdist', { - 'sdist_directory': abspath(sdist_directory), - 'config_settings': config_settings, - }) - - def _call_hook(self, hook_name, kwargs): - # On Python 2, pytoml returns Unicode values (which is correct) but the - # environment passed to check_call needs to contain string values. We - # convert here by encoding using ASCII (the backend can only contain - # letters, digits and _, . and : characters, and will be used as a - # Python identifier, so non-ASCII content is wrong on Python 2 in - # any case). - # For backend_path, we use sys.getfilesystemencoding. - if sys.version_info[0] == 2: - build_backend = self.build_backend.encode('ASCII') - else: - build_backend = self.build_backend - extra_environ = {'PEP517_BUILD_BACKEND': build_backend} - - if self.backend_path: - backend_path = os.pathsep.join(self.backend_path) - if sys.version_info[0] == 2: - backend_path = backend_path.encode(sys.getfilesystemencoding()) - extra_environ['PEP517_BACKEND_PATH'] = backend_path - - with tempdir() as td: - hook_input = {'kwargs': kwargs} - compat.write_json(hook_input, pjoin(td, 'input.json'), - indent=2) - - # Run the hook in a subprocess - with _in_proc_script_path() as script: - python = self.python_executable - self._subprocess_runner( - [python, abspath(str(script)), hook_name, td], - cwd=self.source_dir, - extra_environ=extra_environ - ) - - data = compat.read_json(pjoin(td, 'output.json')) - if data.get('unsupported'): - raise UnsupportedOperation(data.get('traceback', '')) - if data.get('no_backend'): - raise BackendUnavailable(data.get('traceback', '')) - if data.get('backend_invalid'): - raise BackendInvalid( - backend_name=self.build_backend, - backend_path=self.backend_path, - message=data.get('backend_error', '') - ) - if data.get('hook_missing'): - raise HookMissing(hook_name) - return data['return_val'] - - -class LoggerWrapper(threading.Thread): - """ - Read messages from a pipe and redirect them - to a logger (see python's logging module). - """ - - def __init__(self, logger, level): - threading.Thread.__init__(self) - self.daemon = True - - self.logger = logger - self.level = level - - # create the pipe and reader - self.fd_read, self.fd_write = os.pipe() - self.reader = os.fdopen(self.fd_read) - - self.start() - - def fileno(self): - return self.fd_write - - @staticmethod - def remove_newline(msg): - return msg[:-1] if msg.endswith(os.linesep) else msg - - def run(self): - for line in self.reader: - self._write(self.remove_newline(line)) - - def _write(self, message): - self.logger.log(self.level, message) diff --git a/env/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py b/env/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py index a457ff27..ad279407 100644 --- a/env/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py @@ -1,4 +1,3 @@ -# coding: utf-8 """ Package resource API -------------------- @@ -13,9 +12,10 @@ The package resource API is designed to work with normal filesystem packages, .egg files, and unpacked .egg files. It can also work in a limited way with .zip files and with custom PEP 302 loaders that support the ``get_data()`` method. -""" -from __future__ import absolute_import +This module is deprecated. Users are directed to :mod:`importlib.resources`, +:mod:`importlib.metadata` and :pypi:`packaging` instead. +""" import sys import os @@ -37,10 +37,10 @@ import email.parser import errno import tempfile import textwrap -import itertools import inspect import ntpath import posixpath +import importlib from pkgutil import get_importer try: @@ -54,13 +54,12 @@ try: except NameError: FileExistsError = OSError -from pip._vendor import six -from pip._vendor.six.moves import urllib, map, filter - # capture these to bypass sandboxing from os import utime + try: from os import mkdir, rename, unlink + WRITE_SUPPORT = True except ImportError: # no write support, probably under GAE @@ -71,31 +70,30 @@ from os.path import isdir, split try: import importlib.machinery as importlib_machinery + # access attribute to force import under delayed import mechanisms. importlib_machinery.__name__ except ImportError: importlib_machinery = None -from . import py31compat -from pip._vendor import appdirs +from pip._internal.utils._jaraco_text import ( + yield_lines, + drop_comment, + join_continuation, +) + +from pip._vendor import platformdirs from pip._vendor import packaging + __import__('pip._vendor.packaging.version') __import__('pip._vendor.packaging.specifiers') __import__('pip._vendor.packaging.requirements') __import__('pip._vendor.packaging.markers') +__import__('pip._vendor.packaging.utils') - -__metaclass__ = type - - -if (3, 0) < sys.version_info < (3, 5): +if sys.version_info < (3, 5): raise RuntimeError("Python 3.5 or later is required") -if six.PY2: - # Those builtin exceptions are only defined in Python 3 - PermissionError = None - NotADirectoryError = None - # declare some globals that will be defined later to # satisfy the linters. require = None @@ -117,6 +115,17 @@ _namespace_handlers = None _namespace_packages = None +warnings.warn( + "pkg_resources is deprecated as an API. " + "See https://setuptools.pypa.io/en/latest/pkg_resources.html", + DeprecationWarning, + stacklevel=2 +) + + +_PEP440_FALLBACK = re.compile(r"^v?(?P<safe>(?:[0-9]+!)?[0-9]+(?:\.[0-9]+)*)", re.I) + + class PEP440Warning(RuntimeWarning): """ Used when there is an issue with a version or specifier not complying with @@ -124,11 +133,7 @@ class PEP440Warning(RuntimeWarning): """ -def parse_version(v): - try: - return packaging.version.Version(v) - except packaging.version.InvalidVersion: - return packaging.version.LegacyVersion(v) +parse_version = packaging.version.Version _state_vars = {} @@ -178,10 +183,10 @@ def get_supported_platform(): """Return this platform's maximum compatible version. distutils.util.get_platform() normally reports the minimum version - of Mac OS X that would be required to *use* extensions produced by + of macOS that would be required to *use* extensions produced by distutils. But what we want when checking compatibility is to know the - version of Mac OS X that we are *running*. To allow usage of packages that - explicitly require a newer version of Mac OS X, we must also know the + version of macOS that we are *running*. To allow usage of packages that + explicitly require a newer version of macOS, we must also know the current version of the OS. If this condition occurs for any other platform with a version in its @@ -191,60 +196,96 @@ def get_supported_platform(): m = macosVersionString.match(plat) if m is not None and sys.platform == "darwin": try: - plat = 'macosx-%s-%s' % ('.'.join(_macosx_vers()[:2]), m.group(3)) + plat = 'macosx-%s-%s' % ('.'.join(_macos_vers()[:2]), m.group(3)) except ValueError: - # not Mac OS X + # not macOS pass return plat __all__ = [ # Basic resource access and distribution/entry point discovery - 'require', 'run_script', 'get_provider', 'get_distribution', - 'load_entry_point', 'get_entry_map', 'get_entry_info', + 'require', + 'run_script', + 'get_provider', + 'get_distribution', + 'load_entry_point', + 'get_entry_map', + 'get_entry_info', 'iter_entry_points', - 'resource_string', 'resource_stream', 'resource_filename', - 'resource_listdir', 'resource_exists', 'resource_isdir', - + 'resource_string', + 'resource_stream', + 'resource_filename', + 'resource_listdir', + 'resource_exists', + 'resource_isdir', # Environmental control - 'declare_namespace', 'working_set', 'add_activation_listener', - 'find_distributions', 'set_extraction_path', 'cleanup_resources', + 'declare_namespace', + 'working_set', + 'add_activation_listener', + 'find_distributions', + 'set_extraction_path', + 'cleanup_resources', 'get_default_cache', - # Primary implementation classes - 'Environment', 'WorkingSet', 'ResourceManager', - 'Distribution', 'Requirement', 'EntryPoint', - + 'Environment', + 'WorkingSet', + 'ResourceManager', + 'Distribution', + 'Requirement', + 'EntryPoint', # Exceptions - 'ResolutionError', 'VersionConflict', 'DistributionNotFound', - 'UnknownExtra', 'ExtractionError', - + 'ResolutionError', + 'VersionConflict', + 'DistributionNotFound', + 'UnknownExtra', + 'ExtractionError', # Warnings 'PEP440Warning', - # Parsing functions and string utilities - 'parse_requirements', 'parse_version', 'safe_name', 'safe_version', - 'get_platform', 'compatible_platforms', 'yield_lines', 'split_sections', - 'safe_extra', 'to_filename', 'invalid_marker', 'evaluate_marker', - + 'parse_requirements', + 'parse_version', + 'safe_name', + 'safe_version', + 'get_platform', + 'compatible_platforms', + 'yield_lines', + 'split_sections', + 'safe_extra', + 'to_filename', + 'invalid_marker', + 'evaluate_marker', # filesystem utilities - 'ensure_directory', 'normalize_path', - + 'ensure_directory', + 'normalize_path', # Distribution "precedence" constants - 'EGG_DIST', 'BINARY_DIST', 'SOURCE_DIST', 'CHECKOUT_DIST', 'DEVELOP_DIST', - + 'EGG_DIST', + 'BINARY_DIST', + 'SOURCE_DIST', + 'CHECKOUT_DIST', + 'DEVELOP_DIST', # "Provider" interfaces, implementations, and registration/lookup APIs - 'IMetadataProvider', 'IResourceProvider', 'FileMetadata', - 'PathMetadata', 'EggMetadata', 'EmptyProvider', 'empty_provider', - 'NullProvider', 'EggProvider', 'DefaultProvider', 'ZipProvider', - 'register_finder', 'register_namespace_handler', 'register_loader_type', - 'fixup_namespace_packages', 'get_importer', - + 'IMetadataProvider', + 'IResourceProvider', + 'FileMetadata', + 'PathMetadata', + 'EggMetadata', + 'EmptyProvider', + 'empty_provider', + 'NullProvider', + 'EggProvider', + 'DefaultProvider', + 'ZipProvider', + 'register_finder', + 'register_namespace_handler', + 'register_loader_type', + 'fixup_namespace_packages', + 'get_importer', # Warnings 'PkgResourcesDeprecationWarning', - # Deprecated/backward compatibility only - 'run_main', 'AvailableDistributions', + 'run_main', + 'AvailableDistributions', ] @@ -303,8 +344,10 @@ class ContextualVersionConflict(VersionConflict): class DistributionNotFound(ResolutionError): """A requested distribution was not found""" - _template = ("The '{self.req}' distribution was not found " - "and is required by {self.requirers_str}") + _template = ( + "The '{self.req}' distribution was not found " + "and is required by {self.requirers_str}" + ) @property def req(self): @@ -364,7 +407,7 @@ def get_provider(moduleOrReq): return _find_adapter(_provider_factories, loader)(module) -def _macosx_vers(_cache=[]): +def _macos_vers(_cache=[]): if not _cache: version = platform.mac_ver()[0] # fallback for MacPorts @@ -380,7 +423,7 @@ def _macosx_vers(_cache=[]): return _cache[0] -def _macosx_arch(machine): +def _macos_arch(machine): return {'PowerPC': 'ppc', 'Power_Macintosh': 'ppc'}.get(machine, machine) @@ -388,18 +431,19 @@ def get_build_platform(): """Return this platform's string for platform-specific distributions XXX Currently this is the same as ``distutils.util.get_platform()``, but it - needs some hacks for Linux and Mac OS X. + needs some hacks for Linux and macOS. """ from sysconfig import get_platform plat = get_platform() if sys.platform == "darwin" and not plat.startswith('macosx-'): try: - version = _macosx_vers() + version = _macos_vers() machine = os.uname()[4].replace(" ", "_") return "macosx-%d.%d-%s" % ( - int(version[0]), int(version[1]), - _macosx_arch(machine), + int(version[0]), + int(version[1]), + _macos_arch(machine), ) except ValueError: # if someone is running a non-Mac darwin system, this will fall @@ -425,7 +469,7 @@ def compatible_platforms(provided, required): # easy case return True - # Mac OS X special cases + # macOS special cases reqMac = macosVersionString.match(required) if reqMac: provMac = macosVersionString.match(provided) @@ -434,20 +478,23 @@ def compatible_platforms(provided, required): if not provMac: # this is backwards compatibility for packages built before # setuptools 0.6. All packages built after this point will - # use the new macosx designation. + # use the new macOS designation. provDarwin = darwinVersionString.match(provided) if provDarwin: dversion = int(provDarwin.group(1)) macosversion = "%s.%s" % (reqMac.group(1), reqMac.group(2)) - if dversion == 7 and macosversion >= "10.3" or \ - dversion == 8 and macosversion >= "10.4": + if ( + dversion == 7 + and macosversion >= "10.3" + or dversion == 8 + and macosversion >= "10.4" + ): return True - # egg isn't macosx or legacy darwin + # egg isn't macOS or legacy darwin return False # are they the same major version and machine type? - if provMac.group(1) != reqMac.group(1) or \ - provMac.group(3) != reqMac.group(3): + if provMac.group(1) != reqMac.group(1) or provMac.group(3) != reqMac.group(3): return False # is the required OS major update >= the provided one? @@ -475,7 +522,7 @@ run_main = run_script def get_distribution(dist): """Return a current distribution object for a Requirement or string""" - if isinstance(dist, six.string_types): + if isinstance(dist, str): dist = Requirement.parse(dist) if isinstance(dist, Requirement): dist = get_provider(dist) @@ -509,8 +556,8 @@ class IMetadataProvider: def get_metadata_lines(name): """Yield named metadata resource as list of non-blank non-comment lines - Leading and trailing whitespace is stripped from each line, and lines - with ``#`` as the first non-blank character are omitted.""" + Leading and trailing whitespace is stripped from each line, and lines + with ``#`` as the first non-blank character are omitted.""" def metadata_isdir(name): """Is the named metadata a directory? (like ``os.path.isdir()``)""" @@ -558,6 +605,7 @@ class WorkingSet: self.entries = [] self.entry_keys = {} self.by_key = {} + self.normalized_to_canonical_keys = {} self.callbacks = [] if entries is None: @@ -638,6 +686,14 @@ class WorkingSet: is returned. """ dist = self.by_key.get(req.key) + + if dist is None: + canonical_key = self.normalized_to_canonical_keys.get(req.key) + + if canonical_key is not None: + req.key = canonical_key + dist = self.by_key.get(canonical_key) + if dist is not None and dist not in req: # XXX add more info raise VersionConflict(dist, req) @@ -706,14 +762,22 @@ class WorkingSet: return self.by_key[dist.key] = dist + normalized_name = packaging.utils.canonicalize_name(dist.key) + self.normalized_to_canonical_keys[normalized_name] = dist.key if dist.key not in keys: keys.append(dist.key) if dist.key not in keys2: keys2.append(dist.key) self._added_new(dist) - def resolve(self, requirements, env=None, installer=None, - replace_conflicting=False, extras=None): + def resolve( + self, + requirements, + env=None, + installer=None, + replace_conflicting=False, + extras=None, + ): """List all distributions needed to (recursively) meet `requirements` `requirements` must be a sequence of ``Requirement`` objects. `env`, @@ -762,33 +826,9 @@ class WorkingSet: if not req_extras.markers_pass(req, extras): continue - dist = best.get(req.key) - if dist is None: - # Find the best distribution and add it to the map - dist = self.by_key.get(req.key) - if dist is None or (dist not in req and replace_conflicting): - ws = self - if env is None: - if dist is None: - env = Environment(self.entries) - else: - # Use an empty environment and workingset to avoid - # any further conflicts with the conflicting - # distribution - env = Environment([]) - ws = WorkingSet([]) - dist = best[req.key] = env.best_match( - req, ws, installer, - replace_conflicting=replace_conflicting - ) - if dist is None: - requirers = required_by.get(req, None) - raise DistributionNotFound(req, requirers) - to_activate.append(dist) - if dist not in req: - # Oops, the "best" so far conflicts with a dependency - dependent_req = required_by[req] - raise VersionConflict(dist, req).with_context(dependent_req) + dist = self._resolve_dist( + req, best, replace_conflicting, env, installer, required_by, to_activate + ) # push the new requirements onto the stack new_requirements = dist.requires(req.extras)[::-1] @@ -804,8 +844,38 @@ class WorkingSet: # return list of distros to activate return to_activate - def find_plugins( - self, plugin_env, full_env=None, installer=None, fallback=True): + def _resolve_dist( + self, req, best, replace_conflicting, env, installer, required_by, to_activate + ): + dist = best.get(req.key) + if dist is None: + # Find the best distribution and add it to the map + dist = self.by_key.get(req.key) + if dist is None or (dist not in req and replace_conflicting): + ws = self + if env is None: + if dist is None: + env = Environment(self.entries) + else: + # Use an empty environment and workingset to avoid + # any further conflicts with the conflicting + # distribution + env = Environment([]) + ws = WorkingSet([]) + dist = best[req.key] = env.best_match( + req, ws, installer, replace_conflicting=replace_conflicting + ) + if dist is None: + requirers = required_by.get(req, None) + raise DistributionNotFound(req, requirers) + to_activate.append(dist) + if dist not in req: + # Oops, the "best" so far conflicts with a dependency + dependent_req = required_by[req] + raise VersionConflict(dist, req).with_context(dependent_req) + return dist + + def find_plugins(self, plugin_env, full_env=None, installer=None, fallback=True): """Find all activatable distributions in `plugin_env` Example usage:: @@ -858,9 +928,7 @@ class WorkingSet: list(map(shadow_set.add, self)) for project_name in plugin_projects: - for dist in plugin_env[project_name]: - req = [dist.as_requirement()] try: @@ -924,15 +992,19 @@ class WorkingSet: def __getstate__(self): return ( - self.entries[:], self.entry_keys.copy(), self.by_key.copy(), - self.callbacks[:] + self.entries[:], + self.entry_keys.copy(), + self.by_key.copy(), + self.normalized_to_canonical_keys.copy(), + self.callbacks[:], ) - def __setstate__(self, e_k_b_c): - entries, keys, by_key, callbacks = e_k_b_c + def __setstate__(self, e_k_b_n_c): + entries, keys, by_key, normalized_to_canonical_keys, callbacks = e_k_b_n_c self.entries = entries[:] self.entry_keys = keys.copy() self.by_key = by_key.copy() + self.normalized_to_canonical_keys = normalized_to_canonical_keys.copy() self.callbacks = callbacks[:] @@ -960,8 +1032,8 @@ class Environment: """Searchable snapshot of distributions on a search path""" def __init__( - self, search_path=None, platform=get_supported_platform(), - python=PY_MAJOR): + self, search_path=None, platform=get_supported_platform(), python=PY_MAJOR + ): """Snapshot distributions available on a search path Any distributions found on `search_path` are added to the environment. @@ -1028,16 +1100,14 @@ class Environment: return self._distmap.get(distribution_key, []) def add(self, dist): - """Add `dist` if we ``can_add()`` it and it has not already been added - """ + """Add `dist` if we ``can_add()`` it and it has not already been added""" if self.can_add(dist) and dist.has_version(): dists = self._distmap.setdefault(dist.key, []) if dist not in dists: dists.append(dist) dists.sort(key=operator.attrgetter('hashcmp'), reverse=True) - def best_match( - self, req, working_set, installer=None, replace_conflicting=False): + def best_match(self, req, working_set, installer=None, replace_conflicting=False): """Find distribution best matching `req` and usable on `working_set` This calls the ``find(req)`` method of the `working_set` to see if a @@ -1124,6 +1194,7 @@ class ExtractionError(RuntimeError): class ResourceManager: """Manage resource extraction and packages""" + extraction_path = None def __init__(self): @@ -1135,9 +1206,7 @@ class ResourceManager: def resource_isdir(self, package_or_requirement, resource_name): """Is the named resource an existing directory?""" - return get_provider(package_or_requirement).resource_isdir( - resource_name - ) + return get_provider(package_or_requirement).resource_isdir(resource_name) def resource_filename(self, package_or_requirement, resource_name): """Return a true filesystem path for specified resource""" @@ -1159,9 +1228,7 @@ class ResourceManager: def resource_listdir(self, package_or_requirement, resource_name): """List the contents of the named resource directory""" - return get_provider(package_or_requirement).resource_listdir( - resource_name - ) + return get_provider(package_or_requirement).resource_listdir(resource_name) def extraction_error(self): """Give an error message for problems extracting file(s)""" @@ -1169,7 +1236,8 @@ class ResourceManager: old_exc = sys.exc_info()[1] cache_path = self.extraction_path or get_default_cache() - tmpl = textwrap.dedent(""" + tmpl = textwrap.dedent( + """ Can't extract file(s) to egg cache The following error occurred while trying to extract file(s) @@ -1184,7 +1252,8 @@ class ResourceManager: Perhaps your account does not have write access to this directory? You can change the cache directory by setting the PYTHON_EGG_CACHE environment variable to point to an accessible directory. - """).lstrip() + """ + ).lstrip() err = ExtractionError(tmpl.format(**locals())) err.manager = self err.cache_path = cache_path @@ -1234,12 +1303,13 @@ class ResourceManager: mode = os.stat(path).st_mode if mode & stat.S_IWOTH or mode & stat.S_IWGRP: msg = ( - "%s is writable by group/others and vulnerable to attack " - "when " - "used with get_resource_filename. Consider a more secure " + "Extraction path is writable by group/others " + "and vulnerable to attack when " + "used with get_resource_filename ({path}). " + "Consider a more secure " "location (set with .set_extraction_path or the " - "PYTHON_EGG_CACHE environment variable)." % path - ) + "PYTHON_EGG_CACHE environment variable)." + ).format(**locals()) warnings.warn(msg, UserWarning) def postprocess(self, tempname, filename): @@ -1282,9 +1352,7 @@ class ResourceManager: ``cleanup_resources()``.) """ if self.cached_files: - raise ValueError( - "Can't change extraction path, files already extracted" - ) + raise ValueError("Can't change extraction path, files already extracted") self.extraction_path = path @@ -1308,9 +1376,8 @@ def get_default_cache(): or a platform-relevant user cache dir for an app named "Python-Eggs". """ - return ( - os.environ.get('PYTHON_EGG_CACHE') - or appdirs.user_cache_dir(appname='Python-Eggs') + return os.environ.get('PYTHON_EGG_CACHE') or platformdirs.user_cache_dir( + appname='Python-Eggs' ) @@ -1334,6 +1401,38 @@ def safe_version(version): return re.sub('[^A-Za-z0-9.]+', '-', version) +def _forgiving_version(version): + """Fallback when ``safe_version`` is not safe enough + >>> parse_version(_forgiving_version('0.23ubuntu1')) + <Version('0.23.dev0+sanitized.ubuntu1')> + >>> parse_version(_forgiving_version('0.23-')) + <Version('0.23.dev0+sanitized')> + >>> parse_version(_forgiving_version('0.-_')) + <Version('0.dev0+sanitized')> + >>> parse_version(_forgiving_version('42.+?1')) + <Version('42.dev0+sanitized.1')> + >>> parse_version(_forgiving_version('hello world')) + <Version('0.dev0+sanitized.hello.world')> + """ + version = version.replace(' ', '.') + match = _PEP440_FALLBACK.search(version) + if match: + safe = match["safe"] + rest = version[len(safe):] + else: + safe = "0" + rest = version + local = f"sanitized.{_safe_segment(rest)}".strip(".") + return f"{safe}.dev0+{local}" + + +def _safe_segment(segment): + """Convert an arbitrary string into a safe segment""" + segment = re.sub('[^A-Za-z0-9.]+', '-', segment) + segment = re.sub('-[^A-Za-z0-9]+', '-', segment) + return re.sub(r'\.[^A-Za-z0-9]+', '.', segment).strip(".-") + + def safe_extra(extra): """Convert an arbitrary string to a standard 'extra' name @@ -1377,7 +1476,7 @@ def evaluate_marker(text, extra=None): marker = packaging.markers.Marker(text) return marker.evaluate() except packaging.markers.InvalidMarker as e: - raise SyntaxError(e) + raise SyntaxError(e) from e class NullProvider: @@ -1418,8 +1517,6 @@ class NullProvider: return "" path = self._get_metadata_path(name) value = self._get(path) - if six.PY2: - return value try: return value.decode('utf-8') except UnicodeDecodeError as exc: @@ -1449,21 +1546,27 @@ class NullProvider: script = 'scripts/' + script_name if not self.has_metadata(script): raise ResolutionError( - "Script {script!r} not found in metadata at {self.egg_info!r}" - .format(**locals()), + "Script {script!r} not found in metadata at {self.egg_info!r}".format( + **locals() + ), ) script_text = self.get_metadata(script).replace('\r\n', '\n') script_text = script_text.replace('\r', '\n') script_filename = self._fn(self.egg_info, script) namespace['__file__'] = script_filename if os.path.exists(script_filename): - source = open(script_filename).read() + with open(script_filename) as fid: + source = fid.read() code = compile(source, script_filename, 'exec') exec(code, namespace, namespace) else: from linecache import cache + cache[script_filename] = ( - len(script_text), 0, script_text.split('\n'), script_filename + len(script_text), + 0, + script_text.split('\n'), + script_filename, ) script_code = compile(script_text, script_filename, 'exec') exec(script_code, namespace, namespace) @@ -1493,7 +1596,7 @@ class NullProvider: def _validate_resource_path(path): """ Validate the resource paths according to the docs. - https://setuptools.readthedocs.io/en/latest/pkg_resources.html#basic-resource-access + https://setuptools.pypa.io/en/latest/pkg_resources.html#basic-resource-access >>> warned = getfixture('recwarn') >>> warnings.simplefilter('always') @@ -1543,9 +1646,9 @@ is not allowed. AttributeError: ... """ invalid = ( - os.path.pardir in path.split(posixpath.sep) or - posixpath.isabs(path) or - ntpath.isabs(path) + os.path.pardir in path.split(posixpath.sep) + or posixpath.isabs(path) + or ntpath.isabs(path) ) if not invalid: return @@ -1558,10 +1661,9 @@ is not allowed. # for compatibility, warn; in future # raise ValueError(msg) - warnings.warn( + issue_warning( msg[:-1] + " and will raise exceptions in a future release.", DeprecationWarning, - stacklevel=4, ) def _get(self, path): @@ -1575,26 +1677,35 @@ is not allowed. register_loader_type(object, NullProvider) +def _parents(path): + """ + yield all parents of path including path + """ + last = None + while path != last: + yield path + last = path + path, _ = os.path.split(path) + + class EggProvider(NullProvider): """Provider based on a virtual filesystem""" def __init__(self, module): - NullProvider.__init__(self, module) + super().__init__(module) self._setup_prefix() def _setup_prefix(self): - # we assume here that our metadata may be nested inside a "basket" - # of multiple eggs; that's why we use module_path instead of .archive - path = self.module_path - old = None - while path != old: - if _is_egg_path(path): - self.egg_name = os.path.basename(path) - self.egg_info = os.path.join(path, 'EGG-INFO') - self.egg_root = path - break - old = path - path, base = os.path.split(path) + # Assume that metadata may be nested inside a "basket" + # of multiple eggs and use module_path instead of .archive. + eggs = filter(_is_egg_path, _parents(self.module_path)) + egg = next(eggs, None) + egg and self._set_egg(egg) + + def _set_egg(self, path): + self.egg_name = os.path.basename(path) + self.egg_info = os.path.join(path, 'EGG-INFO') + self.egg_root = path class DefaultProvider(EggProvider): @@ -1618,7 +1729,10 @@ class DefaultProvider(EggProvider): @classmethod def _register(cls): - loader_names = 'SourceFileLoader', 'SourcelessFileLoader', + loader_names = ( + 'SourceFileLoader', + 'SourcelessFileLoader', + ) for name in loader_names: loader_cls = getattr(importlib_machinery, name, type(None)) register_loader_type(loader_cls, cls) @@ -1678,6 +1792,7 @@ class MemoizedZipManifests(ZipManifests): """ Memoized zipfile manifests. """ + manifest_mod = collections.namedtuple('manifest_mod', 'manifest mtime') def load(self, path): @@ -1701,7 +1816,7 @@ class ZipProvider(EggProvider): _zip_manifests = MemoizedZipManifests() def __init__(self, module): - EggProvider.__init__(self, module) + super().__init__(module) self.zip_pre = self.loader.archive + os.sep def _zipinfo_name(self, fspath): @@ -1711,20 +1826,16 @@ class ZipProvider(EggProvider): if fspath == self.loader.archive: return '' if fspath.startswith(self.zip_pre): - return fspath[len(self.zip_pre):] - raise AssertionError( - "%s is not a subpath of %s" % (fspath, self.zip_pre) - ) + return fspath[len(self.zip_pre) :] + raise AssertionError("%s is not a subpath of %s" % (fspath, self.zip_pre)) def _parts(self, zip_path): # Convert a zipfile subpath into an egg-relative path part list. # pseudo-fs path fspath = self.zip_pre + zip_path if fspath.startswith(self.egg_root + os.sep): - return fspath[len(self.egg_root) + 1:].split(os.sep) - raise AssertionError( - "%s is not a subpath of %s" % (fspath, self.egg_root) - ) + return fspath[len(self.egg_root) + 1 :].split(os.sep) + raise AssertionError("%s is not a subpath of %s" % (fspath, self.egg_root)) @property def zipinfo(self): @@ -1752,26 +1863,22 @@ class ZipProvider(EggProvider): timestamp = time.mktime(date_time) return timestamp, size - def _extract_resource(self, manager, zip_path): - + # FIXME: 'ZipProvider._extract_resource' is too complex (12) + def _extract_resource(self, manager, zip_path): # noqa: C901 if zip_path in self._index(): for name in self._index()[zip_path]: - last = self._extract_resource( - manager, os.path.join(zip_path, name) - ) + last = self._extract_resource(manager, os.path.join(zip_path, name)) # return the extracted directory name return os.path.dirname(last) timestamp, size = self._get_date_and_size(self.zipinfo[zip_path]) if not WRITE_SUPPORT: - raise IOError('"os.rename" and "os.unlink" are not supported ' - 'on this platform') - try: - - real_path = manager.get_cache_path( - self.egg_name, self._parts(zip_path) + raise IOError( + '"os.rename" and "os.unlink" are not supported ' 'on this platform' ) + try: + real_path = manager.get_cache_path(self.egg_name, self._parts(zip_path)) if self._is_current(real_path, zip_path): return real_path @@ -1900,8 +2007,7 @@ class FileMetadata(EmptyProvider): return metadata def _warn_on_replacement(self, metadata): - # Python 2.7 compat for: replacement_char = '�' - replacement_char = b'\xef\xbf\xbd'.decode('utf-8') + replacement_char = '�' if replacement_char in metadata: tmpl = "{self.path} could not be properly decoded in UTF-8" msg = tmpl.format(**locals()) @@ -1991,7 +2097,7 @@ def find_eggs_in_zip(importer, path_item, only=False): dists = find_eggs_in_zip(zipimport.zipimporter(subpath), subpath) for dist in dists: yield dist - elif subitem.lower().endswith('.dist-info'): + elif subitem.lower().endswith(('.dist-info', '.egg-info')): subpath = os.path.join(path_item, subitem) submeta = EggMetadata(zipimport.zipimporter(subpath)) submeta.egg_info = subpath @@ -2008,58 +2114,21 @@ def find_nothing(importer, path_item, only=False): register_finder(object, find_nothing) -def _by_version_descending(names): - """ - Given a list of filenames, return them in descending order - by version number. - - >>> names = 'bar', 'foo', 'Python-2.7.10.egg', 'Python-2.7.2.egg' - >>> _by_version_descending(names) - ['Python-2.7.10.egg', 'Python-2.7.2.egg', 'foo', 'bar'] - >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.egg' - >>> _by_version_descending(names) - ['Setuptools-1.2.3.egg', 'Setuptools-1.2.3b1.egg'] - >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.post1.egg' - >>> _by_version_descending(names) - ['Setuptools-1.2.3.post1.egg', 'Setuptools-1.2.3b1.egg'] - """ - def _by_version(name): - """ - Parse each component of the filename - """ - name, ext = os.path.splitext(name) - parts = itertools.chain(name.split('-'), [ext]) - return [packaging.version.parse(part) for part in parts] - - return sorted(names, key=_by_version, reverse=True) - - def find_on_path(importer, path_item, only=False): """Yield distributions accessible on a sys.path directory""" path_item = _normalize_cached(path_item) if _is_unpacked_egg(path_item): yield Distribution.from_filename( - path_item, metadata=PathMetadata( - path_item, os.path.join(path_item, 'EGG-INFO') - ) + path_item, + metadata=PathMetadata(path_item, os.path.join(path_item, 'EGG-INFO')), ) return - entries = safe_listdir(path_item) - - # for performance, before sorting by version, - # screen entries for only those that will yield - # distributions - filtered = ( - entry - for entry in entries - if dist_factory(path_item, entry, only) - ) + entries = (os.path.join(path_item, child) for child in safe_listdir(path_item)) # scan for .egg and .egg-info in directory - path_item_entries = _by_version_descending(filtered) - for entry in path_item_entries: + for entry in sorted(entries): fullpath = os.path.join(path_item, entry) factory = dist_factory(path_item, entry, only) for dist in factory(fullpath): @@ -2067,19 +2136,21 @@ def find_on_path(importer, path_item, only=False): def dist_factory(path_item, entry, only): - """ - Return a dist_factory for a path_item and entry - """ + """Return a dist_factory for the given entry.""" lower = entry.lower() - is_meta = any(map(lower.endswith, ('.egg-info', '.dist-info'))) + is_egg_info = lower.endswith('.egg-info') + is_dist_info = lower.endswith('.dist-info') and os.path.isdir( + os.path.join(path_item, entry) + ) + is_meta = is_egg_info or is_dist_info return ( distributions_from_metadata - if is_meta else - find_distributions - if not only and _is_egg_path(entry) else - resolve_egg_link - if not only and lower.endswith('.egg-link') else - NoDists() + if is_meta + else find_distributions + if not only and _is_egg_path(entry) + else resolve_egg_link + if not only and lower.endswith('.egg-link') + else NoDists() ) @@ -2091,10 +2162,9 @@ class NoDists: >>> list(NoDists()('anything')) [] """ + def __bool__(self): return False - if six.PY2: - __nonzero__ = __bool__ def __call__(self, fullpath): return iter(()) @@ -2111,12 +2181,7 @@ def safe_listdir(path): except OSError as e: # Ignore the directory if does not exist, not a directory or # permission denied - ignorable = ( - e.errno in (errno.ENOTDIR, errno.EACCES, errno.ENOENT) - # Python 2 on Windows needs to be handled this way :( - or getattr(e, "winerror", None) == 267 - ) - if not ignorable: + if e.errno not in (errno.ENOTDIR, errno.EACCES, errno.ENOENT): raise return () @@ -2132,7 +2197,10 @@ def distributions_from_metadata(path): metadata = FileMetadata(path) entry = os.path.basename(path) yield Distribution.from_location( - root, entry, metadata, precedence=DEVELOP_DIST, + root, + entry, + metadata, + precedence=DEVELOP_DIST, ) @@ -2154,17 +2222,16 @@ def resolve_egg_link(path): """ referenced_paths = non_empty_lines(path) resolved_paths = ( - os.path.join(os.path.dirname(path), ref) - for ref in referenced_paths + os.path.join(os.path.dirname(path), ref) for ref in referenced_paths ) dist_groups = map(find_distributions, resolved_paths) return next(dist_groups, ()) -register_finder(pkgutil.ImpImporter, find_on_path) +if hasattr(pkgutil, 'ImpImporter'): + register_finder(pkgutil.ImpImporter, find_on_path) -if hasattr(importlib_machinery, 'FileFinder'): - register_finder(importlib_machinery.FileFinder, find_on_path) +register_finder(importlib_machinery.FileFinder, find_on_path) _declare_state('dict', _namespace_handlers={}) _declare_state('dict', _namespace_packages={}) @@ -2195,10 +2262,16 @@ def _handle_ns(packageName, path_item): if importer is None: return None - # capture warnings due to #1111 - with warnings.catch_warnings(): - warnings.simplefilter("ignore") - loader = importer.find_module(packageName) + # use find_spec (PEP 451) and fall-back to find_module (PEP 302) + try: + spec = importer.find_spec(packageName) + except AttributeError: + # capture warnings due to #1111 + with warnings.catch_warnings(): + warnings.simplefilter("ignore") + loader = importer.find_module(packageName) + else: + loader = spec.loader if spec else None if loader is None: return None @@ -2214,7 +2287,7 @@ def _handle_ns(packageName, path_item): if subpath is not None: path = module.__path__ path.append(subpath) - loader.load_module(packageName) + importlib.import_module(packageName) _rebuild_mod_path(path, packageName, module) return subpath @@ -2256,6 +2329,15 @@ def _rebuild_mod_path(orig_path, package_name, module): def declare_namespace(packageName): """Declare that package 'packageName' is a namespace package""" + msg = ( + f"Deprecated call to `pkg_resources.declare_namespace({packageName!r})`.\n" + "Implementing implicit namespace packages (as specified in PEP 420) " + "is preferred to `pkg_resources.declare_namespace`. " + "See https://setuptools.pypa.io/en/latest/references/" + "keywords.html#keyword-namespace-packages" + ) + warnings.warn(msg, DeprecationWarning, stacklevel=2) + _imp.acquire_lock() try: if packageName in _namespace_packages: @@ -2270,8 +2352,8 @@ def declare_namespace(packageName): __import__(parent) try: path = sys.modules[parent].__path__ - except AttributeError: - raise TypeError("Not a package:", parent) + except AttributeError as e: + raise TypeError("Not a package:", parent) from e # Track what packages are namespaces, so when new path items are added, # they can be updated @@ -2312,11 +2394,11 @@ def file_ns_handler(importer, path_item, packageName, module): return subpath -register_namespace_handler(pkgutil.ImpImporter, file_ns_handler) -register_namespace_handler(zipimport.zipimporter, file_ns_handler) +if hasattr(pkgutil, 'ImpImporter'): + register_namespace_handler(pkgutil.ImpImporter, file_ns_handler) -if hasattr(importlib_machinery, 'FileFinder'): - register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler) +register_namespace_handler(zipimport.zipimporter, file_ns_handler) +register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler) def null_ns_handler(importer, path_item, packageName, module): @@ -2354,16 +2436,23 @@ def _is_egg_path(path): """ Determine if given path appears to be an egg. """ - return path.lower().endswith('.egg') + return _is_zip_egg(path) or _is_unpacked_egg(path) + + +def _is_zip_egg(path): + return ( + path.lower().endswith('.egg') + and os.path.isfile(path) + and zipfile.is_zipfile(path) + ) def _is_unpacked_egg(path): """ Determine if given path appears to be an unpacked egg. """ - return ( - _is_egg_path(path) and - os.path.isfile(os.path.join(path, 'EGG-INFO', 'PKG-INFO')) + return path.lower().endswith('.egg') and os.path.isfile( + os.path.join(path, 'EGG-INFO', 'PKG-INFO') ) @@ -2375,20 +2464,6 @@ def _set_parent_ns(packageName): setattr(sys.modules[parent], name, sys.modules[packageName]) -def yield_lines(strs): - """Yield non-empty/non-comment lines of a string or sequence""" - if isinstance(strs, six.string_types): - for s in strs.splitlines(): - s = s.strip() - # skip blank lines/comments - if s and not s.startswith('#'): - yield s - else: - for ss in strs: - for s in yield_lines(ss): - yield s - - MODULE = re.compile(r"\w+(\.\w+)*$").match EGG_NAME = re.compile( r""" @@ -2450,7 +2525,7 @@ class EntryPoint: try: return functools.reduce(getattr, self.attrs, module) except AttributeError as exc: - raise ImportError(str(exc)) + raise ImportError(str(exc)) from exc def require(self, env=None, installer=None): if self.extras and not self.dist: @@ -2536,22 +2611,15 @@ class EntryPoint: return maps -def _remove_md5_fragment(location): - if not location: - return '' - parsed = urllib.parse.urlparse(location) - if parsed[-1].startswith('md5='): - return urllib.parse.urlunparse(parsed[:-1] + ('',)) - return location - - def _version_from_file(lines): """ Given an iterable of lines from a Metadata file, return the value of the Version field, if present, or None otherwise. """ + def is_version_line(line): return line.lower().startswith('version:') + version_lines = filter(is_version_line, lines) line = next(iter(version_lines), '') _, _, value = line.partition(':') @@ -2560,12 +2628,19 @@ def _version_from_file(lines): class Distribution: """Wrap an actual or potential sys.path entry w/metadata""" + PKG_INFO = 'PKG-INFO' def __init__( - self, location=None, metadata=None, project_name=None, - version=None, py_version=PY_MAJOR, platform=None, - precedence=EGG_DIST): + self, + location=None, + metadata=None, + project_name=None, + version=None, + py_version=PY_MAJOR, + platform=None, + precedence=EGG_DIST, + ): self.project_name = safe_name(project_name or 'Unknown') if version is not None: self._version = safe_version(version) @@ -2588,8 +2663,13 @@ class Distribution: 'name', 'ver', 'pyver', 'plat' ) return cls( - location, metadata, project_name=project_name, version=version, - py_version=py_version, platform=platform, **kw + location, + metadata, + project_name=project_name, + version=version, + py_version=py_version, + platform=platform, + **kw, )._reload_version() def _reload_version(self): @@ -2598,10 +2678,10 @@ class Distribution: @property def hashcmp(self): return ( - self.parsed_version, + self._forgiving_parsed_version, self.precedence, self.key, - _remove_md5_fragment(self.location), + self.location, self.py_version or '', self.platform or '', ) @@ -2645,48 +2725,55 @@ class Distribution: @property def parsed_version(self): if not hasattr(self, "_parsed_version"): - self._parsed_version = parse_version(self.version) + try: + self._parsed_version = parse_version(self.version) + except packaging.version.InvalidVersion as ex: + info = f"(package: {self.project_name})" + if hasattr(ex, "add_note"): + ex.add_note(info) # PEP 678 + raise + raise packaging.version.InvalidVersion(f"{str(ex)} {info}") from None return self._parsed_version - def _warn_legacy_version(self): - LV = packaging.version.LegacyVersion - is_legacy = isinstance(self._parsed_version, LV) - if not is_legacy: - return + @property + def _forgiving_parsed_version(self): + try: + return self.parsed_version + except packaging.version.InvalidVersion as ex: + self._parsed_version = parse_version(_forgiving_version(self.version)) - # While an empty version is technically a legacy version and - # is not a valid PEP 440 version, it's also unlikely to - # actually come from someone and instead it is more likely that - # it comes from setuptools attempting to parse a filename and - # including it in the list. So for that we'll gate this warning - # on if the version is anything at all or not. - if not self.version: - return + notes = "\n".join(getattr(ex, "__notes__", [])) # PEP 678 + msg = f"""!!\n\n + ************************************************************************* + {str(ex)}\n{notes} + + This is a long overdue deprecation. + For the time being, `pkg_resources` will use `{self._parsed_version}` + as a replacement to avoid breaking existing environments, + but no future compatibility is guaranteed. - tmpl = textwrap.dedent(""" - '{project_name} ({version})' is being parsed as a legacy, - non PEP 440, - version. You may find odd behavior and sort order. - In particular it will be sorted as less than 0.0. It - is recommended to migrate to PEP 440 compatible - versions. - """).strip().replace('\n', ' ') + If you maintain package {self.project_name} you should implement + the relevant changes to adequate the project to PEP 440 immediately. + ************************************************************************* + \n\n!! + """ + warnings.warn(msg, DeprecationWarning) - warnings.warn(tmpl.format(**vars(self)), PEP440Warning) + return self._parsed_version @property def version(self): try: return self._version - except AttributeError: + except AttributeError as e: version = self._get_version() if version is None: path = self._get_metadata_path_for_display(self.PKG_INFO) - msg = ( - "Missing 'Version:' header and/or {} file at path: {}" - ).format(self.PKG_INFO, path) - raise ValueError(msg, self) + msg = ("Missing 'Version:' header and/or {} file at path: {}").format( + self.PKG_INFO, path + ) + raise ValueError(msg, self) from e return version @@ -2714,8 +2801,7 @@ class Distribution: reqs = dm.pop(extra) new_extra, _, marker = extra.partition(':') fails_marker = marker and ( - invalid_marker(marker) - or not evaluate_marker(marker) + invalid_marker(marker) or not evaluate_marker(marker) ) if fails_marker: reqs = [] @@ -2739,10 +2825,10 @@ class Distribution: for ext in extras: try: deps.extend(dm[safe_extra(ext)]) - except KeyError: + except KeyError as e: raise UnknownExtra( "%s has no such extra feature %r" % (self, ext) - ) + ) from e return deps def _get_metadata_path_for_display(self, name): @@ -2787,8 +2873,9 @@ class Distribution: def egg_name(self): """Return what this distribution's standard .egg filename should be""" filename = "%s-%s-py%s" % ( - to_filename(self.project_name), to_filename(self.version), - self.py_version or PY_MAJOR + to_filename(self.project_name), + to_filename(self.version), + self.py_version or PY_MAJOR, ) if self.platform: @@ -2818,21 +2905,13 @@ class Distribution: def __dir__(self): return list( set(super(Distribution, self).__dir__()) - | set( - attr for attr in self._provider.__dir__() - if not attr.startswith('_') - ) + | set(attr for attr in self._provider.__dir__() if not attr.startswith('_')) ) - if not hasattr(object, '__dir__'): - # python 2.7 not supported - del __dir__ - @classmethod def from_filename(cls, filename, metadata=None, **kw): return cls.from_location( - _normalize_cached(filename), os.path.basename(filename), metadata, - **kw + _normalize_cached(filename), os.path.basename(filename), metadata, **kw ) def as_requirement(self): @@ -2867,7 +2946,8 @@ class Distribution: """Return the EntryPoint object for `group`+`name`, or ``None``""" return self.get_entry_map(group).get(name) - def insert_on(self, path, loc=None, replace=False): + # FIXME: 'Distribution.insert_on' is too complex (13) + def insert_on(self, path, loc=None, replace=False): # noqa: C901 """Ensure self.location is on path If replace=False (default): @@ -2943,14 +3023,18 @@ class Distribution: nsp = dict.fromkeys(self._get_metadata('namespace_packages.txt')) loc = normalize_path(self.location) for modname in self._get_metadata('top_level.txt'): - if (modname not in sys.modules or modname in nsp - or modname in _namespace_packages): + if ( + modname not in sys.modules + or modname in nsp + or modname in _namespace_packages + ): continue if modname in ('pkg_resources', 'setuptools', 'site'): continue fn = getattr(sys.modules[modname], '__file__', None) - if fn and (normalize_path(fn).startswith(loc) or - fn.startswith(self.location)): + if fn and ( + normalize_path(fn).startswith(loc) or fn.startswith(self.location) + ): continue issue_warning( "Module %s was already imported from %s, but %s is being added" @@ -2963,6 +3047,9 @@ class Distribution: except ValueError: issue_warning("Unbuilt egg for " + repr(self)) return False + except SystemError: + # TODO: remove this except clause when python/cpython#103632 is fixed. + return False return True def clone(self, **kw): @@ -3002,6 +3089,7 @@ class DistInfoDistribution(Distribution): Wrap an actual or potential sys.path entry w/metadata, .dist-info style. """ + PKG_INFO = 'METADATA' EQEQ = re.compile(r"([\(,])\s*(\d.*?)\s*([,\)])") @@ -3037,12 +3125,12 @@ class DistInfoDistribution(Distribution): if not req.marker or req.marker.evaluate({'extra': extra}): yield req - common = frozenset(reqs_for_extra(None)) + common = types.MappingProxyType(dict.fromkeys(reqs_for_extra(None))) dm[None].extend(common) for extra in self._parsed_pkg_info.get_all('Provides-Extra') or []: s_extra = safe_extra(extra.strip()) - dm[s_extra] = list(frozenset(reqs_for_extra(extra)) - common) + dm[s_extra] = [r for r in reqs_for_extra(extra) if r not in common] return dm @@ -3067,45 +3155,27 @@ def issue_warning(*args, **kw): warnings.warn(stacklevel=level + 1, *args, **kw) -class RequirementParseError(ValueError): - def __str__(self): - return ' '.join(self.args) - - def parse_requirements(strs): - """Yield ``Requirement`` objects for each specification in `strs` + """ + Yield ``Requirement`` objects for each specification in `strs`. `strs` must be a string, or a (possibly-nested) iterable thereof. """ - # create a steppable iterator, so we can handle \-continuations - lines = iter(yield_lines(strs)) + return map(Requirement, join_continuation(map(drop_comment, yield_lines(strs)))) - for line in lines: - # Drop comments -- a hash without a space may be in a URL. - if ' #' in line: - line = line[:line.find(' #')] - # If there is a line continuation, drop it, and append the next line. - if line.endswith('\\'): - line = line[:-2].strip() - try: - line += next(lines) - except StopIteration: - return - yield Requirement(line) + +class RequirementParseError(packaging.requirements.InvalidRequirement): + "Compatibility wrapper for InvalidRequirement" class Requirement(packaging.requirements.Requirement): def __init__(self, requirement_string): """DO NOT CALL THIS UNDOCUMENTED METHOD; use Requirement.parse()!""" - try: - super(Requirement, self).__init__(requirement_string) - except packaging.requirements.InvalidRequirement as e: - raise RequirementParseError(str(e)) + super(Requirement, self).__init__(requirement_string) self.unsafe_name = self.name project_name = safe_name(self.name) self.project_name, self.key = project_name, project_name.lower() - self.specs = [ - (spec.operator, spec.version) for spec in self.specifier] + self.specs = [(spec.operator, spec.version) for spec in self.specifier] self.extras = tuple(map(safe_extra, self.extras)) self.hashCmp = ( self.key, @@ -3117,10 +3187,7 @@ class Requirement(packaging.requirements.Requirement): self.__hash = hash(self.hashCmp) def __eq__(self, other): - return ( - isinstance(other, Requirement) and - self.hashCmp == other.hashCmp - ) + return isinstance(other, Requirement) and self.hashCmp == other.hashCmp def __ne__(self, other): return not self == other @@ -3145,7 +3212,7 @@ class Requirement(packaging.requirements.Requirement): @staticmethod def parse(s): - req, = parse_requirements(s) + (req,) = parse_requirements(s) return req @@ -3170,7 +3237,7 @@ def _find_adapter(registry, ob): def ensure_directory(path): """Ensure that the parent directory of `path` exists""" dirname = os.path.dirname(path) - py31compat.makedirs(dirname, exist_ok=True) + os.makedirs(dirname, exist_ok=True) def _bypass_ensure_directory(path): @@ -3248,6 +3315,15 @@ def _initialize(g=globals()): ) +class PkgResourcesDeprecationWarning(Warning): + """ + Base class for warning about deprecations in ``pkg_resources`` + + This class is not derived from ``DeprecationWarning``, and as such is + visible by default. + """ + + @_call_aside def _initialize_master_working_set(): """ @@ -3274,10 +3350,7 @@ def _initialize_master_working_set(): # ensure that all distributions added to the working set in the future # (e.g. by calling ``require()``) will get activated as well, # with higher priority (replace=True). - tuple( - dist.activate(replace=False) - for dist in working_set - ) + tuple(dist.activate(replace=False) for dist in working_set) add_activation_listener( lambda dist: dist.activate(replace=True), existing=False, @@ -3286,11 +3359,3 @@ def _initialize_master_working_set(): # match order list(map(working_set.add_entry, sys.path)) globals().update(locals()) - -class PkgResourcesDeprecationWarning(Warning): - """ - Base class for warning about deprecations in ``pkg_resources`` - - This class is not derived from ``DeprecationWarning``, and as such is - visible by default. - """ diff --git a/env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 7d423192b74f12758665e9019748f490836d70d5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 100359 zcmYe~<>g{vU|^UdaWM7kGDe2SAPzF-U|?WyU|?V<X5wIANMVR#NMTH2%3;i9ieh2} zv6*w2qnJ||Q<!sDqFBH*YZNP(W{YA2)9g{~V45R}159&9ae`^CC@wI~9mNf%d7^m0 zG;b6ynC6S(1JnFb{9sxjN&rj?MhSvxp(r6REgU5RrbVMf!L(SE7?>815(m=~Q4(NU zGD;FmOGQb6Y3V5G6vh;m9KKwcC>chEDv0f}QL^C-c`_^vsd5t-D_IyBKoG26K1w!{ zA&<#`p^76_fsrAcAy0yZAysh#W2G8M4I@LUQj`KjMG9jIYmRcRN|XvXjM#EibJe2M za@C{Mb2Xwgz+&t<EV-Idnv4upGAWEH962nxT2WfL+ELoMI#D`|3@MyZx=<TH?&yHn zkir$E3%7wghb31pN*`<*PmV#ZVU%I6QIruQLlwmT#<?a@ri=`!rdeii*MiKt0yT>{ z$`ooAZwg<Id9Fp21=uY99OYcgC`&L~AV)dZD$0tHA=NrXu$d7|3qfgNC@lh}ZK7;b zL{piw>{u9>8L}BBFcn#(h=FOBJQhZVJdRZR6!B)pCdO2iEQbk9MIkB7QI09hQBEn$ zQO+sMQ7$RWQLZV>QEn;BQSK?sQ64GGQJyKxQC=y`QQj%cQ9dcmQNAh6QGO}RQT{2+ zQ2{B;QGqGUQ9&upQNivEDH17?Eet7=sUgkGQK2bPDbg(rQDK=3QQ;{vDY7jLQ4uL} zDe^50QIRPMDT*x&QBf&MDatJjQPC+XDXJ|DQ86iMDe5f@QL!l+DVi+|QE@3+DcUUz zEDTZcQ3)wJDY`8TQHkjcDSC?-qmtYiQuI>{S{PCcQj?pRqf*=%QVdg!S{PD{Qd63l zqf*@&QjAkfS{PDHQd66mqte_NQcP3KS{PEy!1C$t3@PR*7A*`Z7GQoxCPP$aie*+7 zDE#^uqOw!0qH<EKqjFPtqw-Q1qw-U1q6$)MQ|ww8q6$;&Qyf|tqKeWP(il@5Q=D2D zql#0UQ(RgYqDoR+Q`}k@qDoWQ7nG&AFJz1=2eUjDGDcOTmPS>kc&2!@Fho_Qc>Z zFho_SR!7yO_@?-^Fhtd+_@@N4Fhtd*yiN&B32I@Cs!s_{329-7YH(*r2~7!WVMqyU zW{PTbXGjT8iD+R+iAZg1W{zrdXGn=miE3d;iE3twYIbKxiB5@WVMvKdZE0qXYISEw ziA{-XVMvK<W{PS{ZHsDmXGn=pNoZk6Nl3MCW{&D`XGlp*Norw8Nor<_>P$&aNoiq- z>PksXNo!$<>P|^d$!KAS>Pg8=$!cMU>P^W`$!TGT>PyK@$!lSV>Q8x-lAlu0!WcEd zogt+#rKp7=rKp)HYGP_(>ZH_(%}k68?hGl#DJ3loDJ7{Bo0+2~yECMerj)fXq?Dyj zZf1^}k~(F<)P)RSb>%4)Eet6YV0F_{r!_M~O?PKVsZ6PAVMwV0`)7tbLrQf@O$$Rx zP3nwh=BSzO3@NoKbuA1jbzswGr52`gWz9~V1+}?8rJ;o(r6F}%Gjr4&cZQV4l%^Jj zl%~`v&CF4A-5FAvQ(9UWQd&}HH8V%eON~fr&16Vv>jjmp?I|5C3{mq_-llY>bhR)> zEl7En(w)-N!WgwMbw1dRg&;dp-lz1Y^tCWXElQoAIw^G#Sgb!~LJLFG;*<|56H_L& zFh(s&nVd4Eg&}IGJ44FUlxZytDbt#nqL!shPnpre5VbsIX3DG<hNu-Ovs31@Fhs3P znVT}Ng&}HH>ikr`tktPYKxU?{Ni|KG-^?_Dtw<<!eyVBKTBtb0%?m(ohPr<th@G-1 zWpN8b)Vh=<DN9=zqSmJ@OIhB+5Vav?Mas$+hNz7xA5&JPtZre9+LW>;Wo-*X)aKN6 zVB0o>ZCeNSA%u;vxhHiU*k-VJ%DR;GEeugxQrD$UO5Fm|m9imaV+%vn)|5>tn_C#7 zwq=5H$d;6?EsRmyQ?{jSZ()eqk+LIYXA48r&Xip#yIUBdcBSk|+1tVpwHusI_AO-0 z+7q=G%-)~Mp0zKPJ!`)c!$PL4Jy8eT8Bz|U9Bg4oIoQk;bui^n%HbA<s6#17QjWGT zL>+c#NI8~ryoDj<cr#Pf5qE}^6DcQK7*bBA9%*KdI_l1law_F?3q#6jF#lNUk<_E9 z$5PJBVU9YUayI2$3q#ZicZQVnDHmE8QZA&PY-Wx+m2xrVQVT=WX?KQ{%PCh{7*ejJ zT4kNdI@`<~bvET{%C#1TsB<aTQ*N{{M4eB$nR2UzA?iZP?UXw$3{e+T?xx&pVTihv zazEuk3q#c9RPL-RDGyUaQ#ex|^)fRuq&!Y}(!vmRHT7!hwPsK#JxzJm!r06hbv^ZJ z%JY;LEey?!Q8(NfQeLLKYGFuum3p(8IqFslb1;MEr^F~G1_rKx#N_P6^i+kS)Z+Zo zqU2Ns#{f?*T`Yi$%Mqa{vsfWfAtygQGdVFwAuTf}RUtV)uOu-uFEvG>JhLPtGfyE= zp#WmEjzWGBLN!-$X;MmNQEGBYeo>`DNk(c>YJQrYf<j0}Dog{y8pi-nh180I)Z~(4 zgkWA`ZfY@CNxnixVp%H4gv=s^g2a*xg@VMQl46D8)PlsK#1g1O6cQ5j6B2Y3wDR&x zv=quS5=&CcQj0*k6ms&D6LYx0I-z><ixe`8^%N9b@)h#(OB70rQx)=y^}s6f3sQ>` zOEUBGiWN%o6><~vG7Cy`5=#)_#szkkLQ-mGUb;d-VsUY5ib7^yNj}&r#{f?~E-sv2 z%q&(&NiEJy2ZdfqzCw9^Q8qXf74q_na-jiSTv=R_nhOh}VjV8M)bw<4&=>0{B<7_k zl;(lLJ2gcCA)%+B;8~)OoS3JOm{SZj7aTJ=nYo$Z5K62BTg0VTm018W3~UxC3Kfz| zi%arz6#`rX6pRgw6ms$tQ&NkH6-qJ^OB9Mr3kvd!O2D2=NJvjDiBCx^Nz~9xNZ`s% zEy>7F(c^jvYJ6%k-r`S8D$dU-ElG{f%mwN3(`3BG1JVKErWR>3-eNA!tk7h>#a3FB zlarZri#a#3;1*k2W=;uMmbJ7bGdER}`4($#c1mW^Ew-XmP+;F;E6vNv%*zgO(`3BG zl3$RTr^$4SHM1C`gtfRJC$r=wBLf42CgUxxf=Xk<<ow)%#1c)$TkMGi1u2<D#hQ$_ zI6*;{n4X!JUL{+QS)dnRmYSE6U!(^Y)+<XbD$dN$t5U!&U0jfwoSBxHT2x%6gk42Z zYGG++QEF~#UP&=7OL7y7vQvwSHJM&AGcYg|fnCj1B+S6T@RF5*fuTx1pt2+*KTp9} z&lHrGK<N&YQWc<PrzC@d8X1F30Jrr87#J8*8KM|d7^0X`7^9d|n1UHJnQ!q1xCWS* z7=$Ml<$?U3$fcm5pb!d5vgH}6d7xM=N>u>m@jQjh;^NX&a3WDiRDgyC$PsX#gR=@K zaC0g_NgtGSz{Y{njfshY9+=~|lI0dhd^{-H;^S{|#mDF7r<CTT#>d~{iH|QVP0WGH zu*b)z<R{0+uVg5a1_cF(_|@iY6%$&VT2vg9nv;@Q6yu+l>Qa<hma3qu5bEa{<{A|2 z8R8hM;OXb$@8=rq=@=92>gyUD;u@r2784NQ6O(A73o5FLOER-#QuE4Ud@_?_iZe@6 zbs^E5S{zf5S)dP%d;Nm!^mtfdSgao(pP83g5+AQuP+26(z`#%e?m;myFmNz}`N^Q5 zh6O!{4eDk&gA|#8VvetbA&YSVQw_sH#&CvU1{MYoKa0820Mc{^@fNUvWZ4)Z8G;!M z7*ZI58CEj-X|fgxF)%RPVuyzKE%q=-LcGQ2nOByWlbHhJ^ZKNwCni@yxtff(7|Rer zS0n>6gts8Es5mtqYE(VQaUfSRFfuXnF$ypiDKjuIp!kD{fq{XIfq}srq*RH4fuV$< znPCBA4dX&aMurlm1&k%k3s`CxYZw+XfkZ%VE|LXhHP&0~={fmHi8;l$*h&jh5=&BV zamN>zB$lMcmn9Yz-(pG0OfI>_kyezSo1I!&tjTnXy)3b)q_QCO7E^XPy1V(}Q&N+2 z5{ptHMs$K)!vYFxMjpl@ZIGiu92f@4fG{}lEf^RWG8t;Y4zFb_VO+qpkimr^Rw0I| zmZ_GxhB1Y)hFP3JlA(sNhDnm4nX!hUhRKGZP^g9>m_d`t?-pBpF{p^rWG+$xB||k( zFtTQrq~;c{WVyu(_R%fI^jnPCMWEn8cQ{Xce0pjLSXF#{AIRC@t~nzMBO9XtqZDJ2 z5y<hN)Pn4IP*#UK9u(rWj5Q1k7{Lx#K{&jG3FKt3<C!4NuVHRxW@ISjLvnm^YDqlI z@wzY{6zPFjpezM(FgS7W#K#xI-8v2AR!G_axm1p^$OPS`AXkIZ2iT<`r8Nu-7#1=F zGeA-R<1Lot{DR7rjJKG}5_2H-fNca@#svvhP%4-UvI=An17i^=wvs_bA1pXPY!C)p zBF4bLP{Rnagb_qD)}SRirdzDZIjM<7MXC%83@e#$F=wY%-eSs6D$>W|U9R|IP}qQ6 zun^<|P>Nw-<X|kaCDo(gNGt;7a&%wvKzx~>l$DxXvJ7Mk)Sq@BJ3#)z>Q6qXKhgaM ziG(66EWY7^_y%IrDkPiiK{ml`0nwmn17UZNB9N!ynHKE&m5jGo5{uG{!5jzyjxY|J zoW$IultjCA3=9mPK?W5$p&JeI94H}xBP#(~TGTRtG99R7t7Qabw^GKUm=fkJmK3IJ zrlOcCwG`$QmIbUOY|WsdC)QRbNrr`tHH-_`Q`i<VrZI^z)Pja(gjg6#I4YwcWhG>Y z1DwX$!A;ko)RNL7P-T@_tWc1XSdx}sl&fB>kegVMnOmBx0IHG_OEQykQeoAW9v8SS zO35rPDJ{v&Db@p#dZ2s`)2^WjZF1#QDio!HS}UOTPO3s~W**o~Xb}oFCO=KVH!)ek zKUg6G(k3d;FU?6&NCGtp!Bu_=sHLb?TAZq-kXliang?n}6e|=I<)@S;r=}<*Rf3H{ zxJE(2sk8*#L{%tHRVYu)194LG6p}Mile0lpE6hikIhiGupz66KUm-g$zZ_IwgUy0E zPXW_usS1fjsR~*}rFozVUklXU&R0mx$;mHQC@lsx|MSz}O-rzEz~-e^6y#(kXO@6N z1MDY-M1{Q6^3)<&kRn^919En5X>kdpwTa@g<kF&|)Vva8Z6z703jV>+IPpwVD9Oky z2K6FRGC|F3h5Y2?(xPI8G*I6muTmi&)Kh>*GkSX@GfyG2q!{dGSX3$$mlS2@r5Ec! z3{ES}O9q=;oB@j_aHOQ9rYIyPC+8QXWag#kR6<)Tx7bn=i^?<es(5k}lk<x!bXALW zRf}&i>b(Rdc5ur~lk=7kDCs1XX6B^C!)(1J1l9npjf25XxW$^ASdyG^i@CV6_!b9T zB}-O*X5KBHc(8^FaP54HHN7amwBQz3SYl3Ts%ueEevu~AEf$cLTa3AoY>6mL#X#0W z8{(-5Cu{`ea8SFCftQVui&2P?iBXM_hl!1`C<s(VyWe7mHXCno6_w`27bh2G7L-6* z<ON0fWtl0dMYjY%MuSpjQD#ypDA;ZZfSUjDsd*(umGK4nnRz9*ctL6)0-)wPAA*~i zmzIA^Fta4J2w6k%Eq++DDjpIyr~;{pxwi!2DnNZoP@C|U09+_1v$zD*wnrF~T9H{? zQhbXKt_0Hf7lbt%Kn4^SBqpcc;s*7pGV{_wb=@uT#FUiy#N?99GH{PB9%OK8UTV=T zp|s4rlz3!+7vB;FRTrrhB}E_&`FZi6-ry}kP=%9MS`ZJjx%ieK$p0y+X^EvdCGp9L z$r-7)xLxzgGK=!_KyCk9T;cgepj;fBT5^j&2-?~9P0UM7Pc6E|<B|yq5@=X+2O;_l zx42wEVIBYua<IM}aD;#p$1Q$nLUYc~OUnT@twfLw^2;xA%P-AKxy2Kj2g;3kt{`vR z;s;aU+yFKO+>X5^1ZgBf(+0@N#o&hFEzaV^v{Z1*{T2_H2`y!yNd{W*-V%Y8PC2RY z+)#XryD~F1CnY{7GcUFH79Y4%7GInSw!8Qi7uYy(*xuqU$&ZJ}IbSBEjT;Z?7~SGe zElbQP1+^lf0s^Ud#id25@$i9!TYQkNa%NR3B!)O#-QD9|JcC1SaXWeXIR-^SIl=y+ zLC&ra4zII^tFyO%Xb6PM<Ki0T>f;{(;R$;Brj{gvdbI(tTp{QQi#NCsk6UI=Doo)m zo`A%X3^<S5H9Z~9;dRX|D5-?&<4Xl`<KY>O$FDRe2QCZJ3Fq*;KoS*PfIBL)0M6kr zN=?r!24yu++D$FGB?T9Nr~dei#JrT8)S_D=a5+$JPA!TDx4b3NGAl|8z%dNYEb*{z zQ4y%Aa!W2CJ00flVwco{qSRz?wt;pYZ*hQ1k=(@0yjx<9Wr>+NiAg!B$f>Xxqjw4_ zL&3dM35?!p3UdoX6iW(AFoPy*Q68uVrRSJb49<KCNr}a&;QAmXwIDSwB{eS@R7r!! z7Bchm6jDLOWid)W2GrmI`2pNA0rjV97_u0$7)zLH7_yj~8O7nPR+d|w@$tzyiN(e7 z@kQdG#y(3?YC%zvBdA5mc#EYtH75<d_~nR?2dRmV{|72?L4IOjtdanQ6jBb=gDC>_ z=s*S+f&5$~32Mtpfr!~40$ipe2vExl?D^jylR=F&4n`Ixun0z2g1iR~OB;-^jABV; z1vRt4V}NX_tSPK1Y+yEf3VRAi3quq~3TFye3qurV3U@GrCQng5D7;sJYf(qgkWo=; zVoIfMW?pegVopwK3cT`8hL$$PkZKrIk%Nkj)MC((60~%H*6YFW+7{G}&P>e7tbz^9 zfwUpaMoux{At;bE+*GiekV-{JHC<&~4T=~&P=Q?wY7ZfdODZi<fJhdl7J}tKW@Q$o zreGuxP|Sf72&j(+N+2nWlAumFlOK2>rU(?eMKe*O2^2%1&TMfB4<l$s71S_hsuDpf zjlm8h#Xf$JEjaCCE=nyFK(bC4-MXUGLJZqLsR!&k5m4^}ocz-mG8sykni-Zb_Ax@c zZ7Z2?amJUV=7L%pskhibE$PIPTWsJF(qgQhXM;44Md0pXtP;a?52yv53<_XS0D&+l zxq|p$CxJq-hOw9f)TRdod<|n7qc}q?Qwd`YQy-`!&RA6fj(O1NlxG@zxGO#h-1^PS z&(j4LqdE#jkgfpI09Bd-C~1J3vY?a!8Q}t%<D8#Yl3GzxnwW#`T)0)5OyG=vOA@DA zP3EFmpi+Vxma5{DD#3ct3ke?3a9BKOY&^B1L>v@Ypq>%~D+?nFBM)Ph47wYTmHTOO zfy*NFA_LTKy~R;b1R9bqsVo9@q>JW*QqB?(u^dDo$`UXO6wu(@%>;4*sBOr>$imLT z#Kg$O48k1DU|HOS3uycUc^EO3C5ttMNt_{yHI)rs#IUEZ1~X`~6)go7Bdy@jbW}j| zAS6N(lao^mN<dQxB^jATDWHM-#N5=9)FM!0JyoGNwFK0!D9K0#8v+euaFYb0A1aap z>i8%iGCgt`0xcoL6p|_t1wkpO0Ekbjti{MC@HB~92xv0-6}f=|6j!D!0(I}TK%ojU zfq|(?6=#~!gSk3BsnSoA18dZRO5h?;{1&YM*$OfoDMcaT5){NrAX`DHiGz`am5Ygq z5ghQi<IsbI3L=#iQbjZ~B3BYAJS_}STq(T444QmJ1)x|~15F7PmO@H?P%#YaFDR5J z7J~<d(?AW-s$kI6hdQD_R#(8S7+m^ig64a`J<b%27%VCV^&g0i!=gE$pu`!0pqyh0 z3QA}MN+72qSPL2ycf_WdqIvl2yTu7j21Uh|NVdx1vK5qMi}18+z=LB9Sq#NoDU87k zDNG9(K_%%zM$j<7Ull*77ELSw_2R*8wkjqa1x==+l^_@TfCy~$8ZX?1pm4SYxe_!O z%)rFP$ii5qgx{qgEf^t1TqRVr0Edf;Kn0sK$Q|G~Vyu$J;RbMZ18Vevsu~amu|ayk z)eR`Gpbb`nO~zWkvB!ga5+Cn|WUUNVYoQALG`X>6X+&-Yr8G#;gGTBgR<8zm8Jw>X z1h}*YWiNe@-Jp6K)cj)sm(-xrnu(E%m4g|a0Woqr$itwdUJNSakxOjI#7|KnDA(E{ z`$HimKeaedy#z9wnwY1c1n!V2q@^a7loq8bK}%wV^vtr<JOxmn!mkLF=&+VcAmhD2 zt_B4<2P4Ef*6Lcl>RRxi3AiwQ`Tzg_|0t~jkZMrN031y`poR)#2}2Eo4Ff1mYceJB zGcqs)LHjuh39wF6d|D!S5;*}h&X${)oeCOT1CL)ohK&-CIyniDp+6KMP`dz>KR}%z z(2N$i{SWePB7Dv>At4t$Po)<h4>c@4AwdURD}kn5u{Z@ZX{G=lYy!=d>cD1$6BV=| zrfDfa25cb)LE0|G3W<3N2?-cI%!CARmj`5!0z@~YW&_Ql3d8%4(4fdn1x=}NL!Aop z*DV3`&_aqga6+5Jz`zgzi!uiGA`l-X1A`(4ly$(7Qv@E~tzjr(Y-TD_DPdZ`3>xAs zP%2?5VXa|kW^87Jw4ST@O4zd4YZxRMY8k^B@>IYBxnYoj+!9WZN=62R3dqoI30Dnc z3R4PmGjlCd33mxk4O25y4P!H?C}XLzhmQ6p<|$x=5j2ES!KpI^8cd)Vg%)I>mIJsg z51M#{22Q-6Chsk-%wllsAul<#C<l}ilR%9+7En*RC>X?KE-oo5@&d8gA%S0fi^Ds$ z5<F}IG7K_>9Up&-Jw3G~v81Hv7H>RAcYI<>VnIo2QPEn^kQ?(YZisIGqM+2mTWk;x zsCf;VQAdxEPzDBuBv6EaI;;##T#QoSc{(0O4n_gc#1}{&C4xYuD}3%K1(bUjiepL` zKr=_6$N-POgGSwbQa}OAlm(i*V_L{q<Ws_0!j{6)%v9u4!nS}NH0@B!oWfeeT*gr3 zQ^TCX3W~fMh6Nloj0-qH<MN=nz8VIQnZXR2?2zu!Eru!s{b2Cg1bv^(q@u*4N`2@2 zqSWBjqO#27)MBU{v>B*Z02*rp)q#mA0bnLyKoMv>yacMC$Q2Y|Tt%Rn$6M^ViOHaG z(OXRU#kW|%18;1pkRd<zjKpGacyoYF%*jkD+6#&%w!{L^*gz3zE=7~&78_(Fu1F3f z#|l<@ix*5m+T?j9=%Me+z`&3X3Vl!+#{g=jGjV`OMlMD!Mh->}CIQAGkQ$U20F}C+ zSO8}cP_(5mf)>}#VOqdY!vLBk1=q&6m<tM$K~tUq`Q@oa0nWGh!Hjs{#AMJyk>U){ zLWuNK@DhdG#N>?3yi_#TAx4W6i;^?yLCypfoeYdc=g=o*K+b{Z+8PE1&@>BE4nr<u zEdwJ%4MQ_SEn^8&7IO-7Hd9eW4dViq6qbdI#T8X{C9KV$E*RSa_Js_fB(Q)Zg)N1B zAyX}L3P%ZN4HGE(n;F3@PSDJ030DnsGh-UF7z1>Io4c|MlFuQzx(1YgxvGvp^KS`g zlpoa11obi1i=m_R;2aDS)rBrCNJeQS7DGz#h=>RUXUJqi4ruvMW-+W7FHX!&RY)vW zNJs#+EkRQ|SSNTui-AC+1DTMnWnOA(O0hz5er~ElMq+X{q~`F+%qy(`w?knwJdi>c zT!?5g7L|d@3KvjS3QD4&`GJ?9@czZ9aEmd%iXSqfudAA(r<$UxT3iI`)@$<I;w-K# zPR`Fu%S?wD04i4?37xCB1hjMs)cFG^uA&3r^jZq4Z9&8J1v#KGZ05|o5^zKp`GYbE z3&fNFkXu0MyXY*4h1QG!P4_i}(g|p=iGd9?4IskE#K^`7B1IV4{&BGIFtafhfz(w= zKpn0TlcKE|qX(vRHT1MJtK=cmA-Z58s0@?>D?q8u*%=rZ;N{T^aCwx%Sjtc=0iFj0 z(F`?=*-S+;pf(ApoC2*YsAZ~QDtZFuF)U=PWv*c^o&s8F0IFVUS!!5{CX_JOuq<Fn zVP44C%vj5s!cxNo;elyZ=&T`I4QmQpHd9ee4O<F(HfwQD4QmQVHdE1r8nzV9Y}TR) zAUjjIf*ER<k#sXJWXxtR-UAlnUdRYGksBmdbO5Bbgc&Tu3bMI`87vECXR{PN0LjD5 z)a0qU?VOmWker_a8K?xcE?{khlmx`=RZ(f4LOy8bGF2e~T1O#C+e1=1B*PRdloXYw zDrBZ9q-LT{fn|b{x?g@?Dkw$gLzc9`vQRO2x-S*9um(C12g)~o;Is}Kr-#fUf+rWz zQ$1v|tu!yQqEf*>IJFp(`u#${DY=SOwOCKJ7}Asj#dQ^np@E+9OHgS8W}3Kx+j^R; zMW8NcktZlE3qukRw3LU;ixpi1C0IXDT4o22XMoynDYrOaAp%<GRp^_Te2X2_h5<3S zKnxe~%-k)G6zE9fEyx@ll!sPg7L_wFFf0UR0ML>P26hQ17G^F+7Dg^+78VfA$0)%l zz{vKW351zgm{^!a7=`{bF|jbqFoJks{V1s$l+i<-JjIT|sF!g>fNc78589r!Yw} z)Pm9oGiWJt4RZ}s3X=^(2@9ynlfo>?uz(e`W@8~}VK8`*yUM{QKN+-+5L9Tvd(Yq^ zEFM%2CV-0}P=d)UDON~;%+`U&>Jt<o9B`ySx*ni<$ZsVZq{YGsT7!~Sl$e`(i!&`A zx-6&25)|g3woOq8DBxM5I6)SJt-8exF%WF}EvCHUTP&ag2t7nW`p$zw6f{)AzyxZS zaDWz2fW$FsMNs1r98#c838+n9!kER>%v2->UO@!P=?q{|=4PfM4M-Cbv}mV>p@glO zso183J%zD`p_!?P5i~}q$yDV4$rTET3a}Yvkn`c;mJeQX0j^CF6_Cb@L5)Gs1Y2Hu zm98szJ!xtRwCd48RtH|HirhQW<R}8orxt-?{1y+y2=J^)F}T5aixoU;Rs?F36=j1G zI%h~_0c7TOB_m{L4y{BEV_;yo0}4J+69p7}kcI__ECR`4tb+kr4Guz3mktzI&5WR> zST#%wL2LOKt6ZQ#k^qXV1O@PntO9t77SxwX0M95xIuYPhl>iEhqQuPNR0U7)dQ5O* zR+9;Ac~LlM!h;#&a8S-HdIm}_XkGv*dJggexbeXR)`XHrK;rP22l*4>Z1Bhg<1bsN zqd_GkvWs&Q3&61lbv8IYKx)!Tb8?_w%S|kRxi$ingqe_Bi{?;}{2L^Pg7~C`?@Goh z8ziS9=3=2;IAq6aLt+5z=7a=D$qaL8Bq$hPg9tPyf+Rj7IT6Ii=+%S56O@69LFEmi zSD(Vv!Vtv_8GnspflTj2K}YVQ*r1a;>?z#faXSv^xLqr#r3fl0K;t7I3}S;YIE{f4 z8>G`+W$lum3R(REoexwmMrn|N)@p!Oe1ivJL1`~VAs0GhYVQXwG*&WVOFp-FG7^j9 zVM@Ql{mxh=hcV@<hpZH%aKYwk^^gpBKM?8~#LDqR(2z4E6GL2B^bRvhAoJQV_x-}} zKG38;Oes<ByA%nU5Qp_tvAGb`Edu3S(DX)9PGVlR0*IBIp9|{7Du8FwAq@lt1qGkf zM9{hwa2-)nl$e<VS|(JUky(-op2-C@jX~ZmC`e6F04=&yNKH)60Gk0>GY&BgG%cc_ z0GZ57NKj5l05zk*xh}J)xCCrH#39KUiJ)Z=sYT%CMSgB(Nl9vo9-g2CuaJR-4`da< zU!(w4!HjU^0EK8EDp>72AxRZA9V#R$z*h*^D=28>WM-!-BqTuB^y`6Fi-6XwYvS<& zAKdw1<;+a5`98)f1x)9oDkjS5_CA@#;Q0=iUU1?lR>*`j5aAv`c0MSLq+}Kma=QS` zNbnMul*}SFB-bn9aXr+0j6xk-j<a>GNKGy+0q?{BJ3R&3FoF31v_vT<Gc^S)2}zfr z<(HZHd5J}pkdW78DtZF0JwfpYRst?SAOv`r3e>vbL~^|hrt3lL5FjlWKTS?Zg9tI% z{vMRkKY)mjAmS5<0Ig>PH-jMdpq0$63=9n4K#3JJAj!eV!OX$T!3H9WKr*<?Xi!0o zD5F73?qQ1>QdnCUqF6!Q=@y14wiJ#O&K8C!_7tuZ?iSEwJWmQQcru<Zm_d`js14M; zG<M8`RW#rcKv4TPGbObcv}7%{7`zn)S~$ZCxniOsEd^SsB|^Fvpp`f94JIWSkXjA4 zwh7!GgbtvBii(6>$f~6T1@L0Oq*Sz_OX#Aegak<3u4DoY<UrOr@uHZC6zrflz9kCE z{BRW@H-VCa08*^0V~qWQmv3U|Au0?q;b8z;=m1)_0^R|m3oa#)T9OHH<3Y|LKOl;} zf)X8SD!V0&;^*R$qSVA(Q6wL$67VrZ2T}gbh5Hv&C*-BWDsWJp0V?gmv($Md#h}WE zzJAWkOP3<e&zX7YL=~<&=#3bdr;%DMu;@j!TE1h6C~&I<rc@ruwQ`s-1ZuUwloI7k z)anbSmDK7Bv|I=+PZfdIV=E!K7IXAm4`y9FxPl|fz3@5<rWaDS!%BQ&>nv;zj$>e8 zP(^aE5@ztiEQQr-xE4zM07c_Z5b+B{`~eZ5@F)V=ffP{SED0)sz=bX^$Z}Ap1vKl% z!3u`V9L!)jj8Y%eUIrET#cR-K*VV!8az^kXEZD*;&>}4G(yM01D0XQ3oCDfE=S<;E z;RDaFYozd}2(&Opai<8T2(>Uo@uUc+h_o<7@up~|h^I)jFh=pEXr)M|NVPCV@uz5~ zNT<lOFh&Wa$fn4(FhmKa=%mP}D6}v}38g5eD77#|38yHhsI)LdiKM8esI@ReiGs$f zG<AzIK{bqvqe60iP7Y*ACMf5FmbsRtqO|mjL4#GrmC&7#8lV-~3dNbZnK_9?3ZRyP zrXNcA1M2yK!Uf!+0Bw0lXQ*L_XUGJRj9`)pECSw!Q_4`JR>G3S3Yw*GVTk3cWvXFV zzy_L&U}PxNf_6phor_XIV<gZ;yx;{Q;N~pIc95e%a|7V+VP<Nvf(CRIt}V>Tntqz> zx7b15%*@o{TU;PUWjtvA(Ji(lFyj_ya$-(S5@`GvJa$ra5Zo96EfWSShA#Ih`U?_f z1q&f1A5h8xZEgdtaEp)E0VN+$R~<B8&c?{b$i~D0##O?I6~KD1ZDlCA4HR&oQ8aMC zfzl{soW2TlS_Wk7o(X*ZgBS}#2~(vGWR$&z5w>-#im!%o0W&1%ASYjxuvA7sRe=Vc zm=?m-f=A_<s|>+YnV?ENpa`^W7Sf2zO$03{1#d$I)eXg|C6EC?kUHoPIB44*beyg@ zK3<az<bTi_(D?Ww7Dfh!Tii%v3*f0V@B*V-67i7b@}S6zhw2A)Yl=0QZ!st56yIVh zF9sWc9=yCzjS#0<g2EUyG0wos#>fPk7GnY}Wa4AwVH9Ahl0Xh;h<y-kD5(@QatTkR zY2Z=nbcSZeTBZ^P(4-@H43Dvf8MIJtAroi>8k{;=Yd}+;te}~&LM2eTbzz8=sAa2R zt6|DwD`PCOs9{>bUc&~Kw*ZNO)PQD#TA6GZYCr=vOjUvKKz9P|9Z*O_4rxd?EfKcX z4HP&Epm9Jwg`m{(B2dRp0hX*0kpfyyR18X+?4Y7Cr!2K71H@xaOi4kcXK?B*Vq|1s z&}1*-07VjLq!m2!SHub8vJ|Bj7T;n84X71E##BJd#n57+h@Fvv!51F>?4Y4PK1L2k z9%j%877w!kW0f*y_+!L3N>qT-J!pjqINgJWI6zBSKx16#44{G18ip)TphGqvvVbNL znweY}Vuip(1#1lxXx4ZkXak%|3TR(DOX6Kd1_sBJ6z~r8k_-jVwmr}ifrJD-P}a>% zEe4I4gQjUgsXH;R60@+&EP;2i6%rCaN>O(OXn+i=)KLg2Doxc)NC5S-OF_G5OY#*! zict-OM|X05QBi7fL4F>%&ko%h4llYYAzkv4jMPeS_c}2pB{fA)K_LNb7sw8{L5Vr# ziIv3)kh#uO@IE6{&!vLaYGkG<WR`%OmY4%-;8rRW6r~oY<{@QfjS$dmTxPLCQfhJ{ zXt#Sp0xWSQB!KsggW80N(4HuGf(^6~KUE<&zX()RB<8`Ll%JQJ3ip5lvTH!)GpKoq zVm2a)C_p#lK>P$Z4?K6FfUHMP6D}Fz=BLS41X_1}i>o-b1X|uh68KS2Ef1OnF9I#i zg_Ydklnh=e39jtH1gP8w=Lb+?ECv<43|ychgpaXG1mQkCcr5@@1{yE}W6+QsDBXh7 zENIFXmS(e<KpWYzL0O%#$`X`76f)BkphK^jkWmUObu75c1sdWnD9Q(I8`NYj`VaES z84zI&8kJ=NFFA!|OtAaG1jrMh!WbG+p!MsZ%n5QH15=eal0V|XQ{IW0dBySZC|&`1 z1BAg|(E*o)S>WBiAg_SuG#E=6i!?wPt&Fiq12h9x!w4Re2YHey@d6_QgIi`ED8GTq z4)|a^c-Ipsiy;;C;Q213E);m*S1Nq7Ij(>Kr5}(fkcEcOAObBG&4g_F0@qC7HNeH7 zG@n?kkdvR64jRVFEK$f!O)Y_hJ9Lf+qi_Z7;0LWUgeNf2tXzT~ctf5JDEdG%Z?FyV z_}mC}8F)MnI>8Kb8fb|X^aKi!W59h6uocKI(NRc9fX<J>w(~$r7Vuzw3Zk?}4zs*` z1$^$o5@xWGX}Dj(OD#b=DN~W`@Y7^LOMl=B9G0EHOWCkxr%enD3}v7M2+K|aOk9jr z{7A_VR6b&i!Gn??2p5AY^>&7K#xy3-0*V%n8U_~z@CqR2L}5k-2FTzkxIlzWae!xh ziXqh|bk;xtp7J0g@`$qBGfe>^1S%FmBlJ27;0;Q}puLdb24p3~T=4K4%s5c(1yTSH zGUQ|qRtZX<NR3k+$ackY&?HNKUQVS#eqJhQV`>R#QAax5n56uY3<a1aiFqk7w}G~5 zf}NF`qM(tPhf<p;<QJu+7HJ|<14auH)Tl8AZ5#pZs;*&(H2^iO7cg`%EMx>N336eG zm8oUwU`$~sWhmC_V60)v0xb>_sbLCZU}Pv1DP)504Ax{W0?nA*VgncY#o)nwP3Bun zdIpeE2vn%9WGX_NCjys9oHpsHd8rizMRvWg)Bsv;F2pGGw@M!=HDGKK)U$zXI<V7& zn*eTstc0w%N4HFrk%0kx$U#vQ0|P@F$SzPzf`OffiRoXJ3_hDs5+P{40x00XWgw`} zf;6kkT*C~W)n%z+UI3ZZWdVuUFw`)BPC;162%Xnus$m8-S0J00s_e1N>w<Q(f-*j6 zRc|q3YL}R4-J*w}$u3rKB><lzF9r{r7Ci-364++yK%=HpK!JifS6d~D6flTkQ<S6x z3Jp-GfV#ZJptZu8450G}vOvcu*nnz<8ip*!GR7jQLM{*sbS44lfCbRXjT(@+N(y5Q zV+}JXl(Lv=m?as&$xEe>3*7r;uG#^~%cxli6h5HYj+9c!l4bCcPEd7-Etes(HE7NU zoM9lj1C+TzITD;zKw}c+8JWo$;8GXV7A#hW92W#CMnL_=^3)>8Mgve$4Q_RTT8kh9 zkg_x)!-419{WO^&%?(f^1YA;TvOuDSr8qS;?-mQlq9Rbe4Nkof0-Q5A;^V=IK7I}; zUceniHWtw8GA1S_P(zx75xt`b+T0f(;+71G4RG6ofq?<kdjavm=@qoVy@t6+tcEd* z0TLHAEGdkj<Do#S4@wz|RB9N(s}mR?YyUva>RMLN9yn0?&0+%c*=ksd!)h3_K;mp= z3`Jp}cmkdAk;MiQwP65}HLPWfMHMxy3)n$CP%j5W*MNFHeKnvpgp66>z7b^AAV?l$ ziY9ZSI1{8v4s8cP4><xg4vJGtbQBVci}RB+kq&JF#Z4t@I|0!SRw&H_b&0^WwhpMi zhc*Dg<KduqOGwZIl_H>x%Lxgf_9w(zL>&6(DWq0pmOyF^@RGEm{L+%lyi^^e=C%S# zT1d@H0ht6c9-1uR<#=&wi8^R84x)RZpaE%omnRm3mR6%Rz%`+3azN<~;xbT*1y>X( zRzmFo4|jmgQ->_nNdzr)2IUIyZWy>TK&=d9+rY<Tfo8x!!@ZEL#h}ap@&P!|OY?F- za|j7Vso?cxwxG6Z0wRn&LEQ)SVn`@}n)a0n@KF*4*hW(1&3p+7#idE037Di*(8LsI zHaH_c1@64^%$yw1=?EZ0keeDS8H=tmFfjOOa^B+1%qvbUDv8g}181&V9I#jfxAlua zo8KUL3fwdXwe)Xs#e;(^J}<RglO3D`5p~loHi&s(^KY?$M|@a8q!A=P!W+=wuEJVS zegtJv1|AkhA<&==_;efrCKe_hMlMDOuHr)~ITKS-lEJkNG*^PU0U$m&Q&up7j?DoL zC4jpBDNL=*pyjlg47F^T47Kd(47D63jLi(SoS-$-B`gaWYq@F|ComS3)G#h!1ub%` z<*wnb0cAvwLcJQ!1#C6kHLMGnio*)^YS<UB*KlWXEM%<Zso?=Ft((AD1lrQdi7sB; zSHn}oUB+1SqlTsEM-4+QFKGQ{DMQgdh`yqAC7{Ba8#L^ZCs4u#9RT40)4VlIS-dse zHM}*<H7qGCy(}yYwLCRon{61N`hV1Lf$U6ST*y?*SHf4rUBd_N7;r4$ui*h@e~A4P z7>iVDxN5j18EW}U1VCcVObY~S_!lxZG1l-b5USzM5?%;eGRp`JCxIHq1tK*9U=swu z)rw#ZSB;<~!vfJ7?kq8|ICqwC4QGv@4Z{S+LXQ;I8nzm48-_x?8V=AVw8V2P3=H6j z)x?|}lm=9>0%*x6q|>ZXlnOdzBC{+tr&1H#PXPB%K(#Yy;H4O;0D{%p5OKuJmqKxB zVQFe!aw@2BNJv0ha|9}RAdOQ<C%z22aR8L-Gt<B)sDWlhbzmJ}*gP82p#h-wKWO)D zUUDkvD7Q3tUILv?2b)&KC;>5joCw>O4W8o%odA~yIeY}<7I0AuS`>s_6~hV&q#_99 z3-D_BoSf961aP+q?gY5QV3|BKuPi?sRycqc9e}zb&~wnh#TICI0pyLOR8T<y+T?{a zngA^@k@g-VJI)$Z=0k@KAiF0N5)~2>kk@U20>23EDp;QfsoV`kE&M=zWAF(InR)4u zf>1{R-0uRd7(wfmDWq0_wl8MpBSt?m5m5sgPeSr5WF;ne7aV959aQ*&M|{B3x!@8S zBm^EAN-hD<q9`PlLY5|jA_pW{UIgmPLi?_I3JU(9-YBSV0geOEwh=_MfGQGLtbjrZ z8XxeGfW=EmzCwNyeDw~@dZ-<sqztkc$s6DvEx4zdSb}IQWtJd?XaacOP%&tr3Ut~d zbWsDy9Eb#{QI(VmI#dyIL?oy^R-B651BR|M1^F8`Fa_CQ0Xhl?HbezB3`LhhZepcE zPJVv20(j;&A-57Vv}_IcGen22f>Lf}JeaMNprZh35<-sb0WWt21t_R`%FHWCEh;EV z1?^=AuNNvPElSNnWS9H`P_rU22iXar%$ZkQlA4$TJ_84QbWce>$TaY*a!Ed@fs+b8 zE-?{&W@0fS43PpEl2%HJN)hMnAa}`&Kyys6@poZpt&N;;Lo~&2v4EyTZgIs2r51vZ z`6#}{jhNplzQqk~DuEVY++r?HExE;9kY4~=LJK~DFdlSpWf6SL3EZ#+k0pcaWAKd8 zEv}^0;*xl97rO|wORWf04}(Vsioko1B|u}zY~X+{z6GLF^HRVS>@6PX@CbN8fu<0+ zw!X!K900eNQ}fEe&43cnkpo3V%Ao$84#-5#f};H7)Z*gQlv^wy7u*7!7y?U?x44Q@ z3n7tP4BnCp*$@pLp#Y6-gSXw?;)NX?Q36UJw*>N1%Rvlyaes>+O$5D}z|F|Oa2nK1 z04=&_kQM?h7-nQ)Vq@WAVq@ZB<X~cA;$Z|~E+#%k5k?l!h7m>{R?rwZ=;$}5e*!EV z;D!VjBNr0~qX4rQBNsDhTMr)-7ju;mQquxDj*rsj2W=w&twjMhFF+gbp)(b%HLReH zJtOGAJ8<IyTFINh&bg@NsNtw#G-s&g$m0Nw;)yfVa)A1->7ezuoFxn;tTmijY@l_v zpaZ~bSX~%m7l4{0HC&RQ-rgioQv|dfB%QIAr%I@Xa{)&UPYp*6^FroY-f)II9~OoZ z&dN)S47GfW3{@sIe2}WRhNWmjI71{u3S%u_9baKu9v_0o$WR!C;1#Ap)EF=rFu+~I z+sp)Z4f_JF67B^&HM|SK696Ecg=vLRB@8v}&5X6|HS7?-*Ra>Hr9s9ci`ih~kvTb# z(Xqr5a6Uw?L%<!%go2#X^vt~Y)VwmJs@}CCF}ENGR8l3Tr&?Jdx|yJY3B?Q@=%FJD zwy-H2(D_1oX`oYtAVwE!z>6V}ZV*PQ-!&kLK*!jCvMpkO8>9}ErwnR`D?rp2Yv*Jp zfjc{}(Rvh1auW+Qp!GJ`If*GLI;c$`bfZ%;iwklRE1|wYF|42{Gp|HL-5Gpn7O1`k z?VnSJd0Z0_IG{c_a(EKgtbsNKAZG_7#&W@ZA(WtoC<Kj+L1!bNWr=#Rf)XTD5KH}( z6!H;uKWr^RW@@n>_>kcQ&{|?}l!NO}SZ#^F9R?2**f=|AJP@`9J*QF^(ZWJ;HK<}p zQ$W}Vs-E-m5!E}w^87sT_;NCMqB}()v9u&VH?ahCymC$@teXm2yND<w5)!~Co55WM zId>Oi1Ehzgke>&y=0IJqlF9<8ak;69ptXgGB?_RkkU`U5u;ZAKnl#8$FAC6RghFw0 zVjk#_V$e7Zsz(tCApx~DlBiHzl9-p0SOhu_8FG?L5xgS_8leYIoF#$wav>_k1n~N! zoHFE&BrNuzGxZ4yX*r4M3YmE+nV|g>#R}yasi1}t=ny(c+YlZyi6x+;O-euw5NNro zke`!+IK&RT;wcfDxuC=S;A8HJ;Rn{i%>o5LehH{*hZ>cF)C2;zTA=Yz1f7mZR4~#l zDJ{rJwNlUkclKfPBgF}z!3NNwMe(2m(-Jg6v4uPog{B%5vx(sK7O?giN(?AK+L)Pn z3dp$-?rv~<6ExBVKF1kU9O@_}f+tBpyUr9qtyXX|2(_R<<T^;F31M75c)?)~`~YrP z)tU^>X9@}6)0iM0gE$=2;(#pqRLD&%D9Fr1jDwfvfeICnn_zK(>N8OL2{d2>ZFNIV z`~Y>iQc}Ug4WMBp*kK`{k`rt<#OdHu1dBlPsG-HBi8-(>gRu0B-fe)L_kiAgK<fb@ z_sifx;-|@5qylQGuoUMPl_0g6rh`UjLE{3DRuEreF><S;2-K(mpX~%bzqCjlq*?<s z*2@oRAaOy8H&BUnivw166&ZqT;z)yLhFknlMbJ_aw8{mZvTpIB1ZR-}NGn%yMq)~S zIjDjt(gQWJz-=Yaybfr0ZgGB2S!!xA_QP$Ft2cFK28LqL8L<p1984TcEQ~Bn9N@uB z4kj)p0VWP69wyMyBtlGlpl!5Fe9S7$0*nI8984UH9H`Ti$fjZpM1uySL0c4yK?l)* z&TuGU1dXgLWCRUFgBNBn*Dx#q4Zt%pG877d7g{hT?qg(Na0MR}2T2Sl!GJVLgxms6 zfXux^4hKw4K`PczRl%3OLbnltI?#y<8U^{q#hFPtmAZN0sY*@w@BloSfXb-U{4^c# zs*cPw@R`}5P7<o)K(j&6-WcK}6ws-i&@*vB$sAI`D1awtAbAXVECSO^a1j8>$DpDx z2~pg_n$h5u1Zkx?Y2f-IBNe%iQ)~^c@`_S(Qp-U7F*Nrg4WVb|CFhi;q^9VAs+T-y zd0MFeE_|RJdswp!d`3RF8iO^UK!cr#F-T2jNcI3NZUN^W=qP&;=xB^vY!J^t2K>N- zd0+xGh6i4AR1Hd;;E701Q1atpLTh4!&zC`&1_Grs&^#o#i4C4VV+76XmoXIaftI3y z*r0VO;PEG>VkL-}3qvdq=uBzQK4?aULN$=6CR0_jCwL4*Apuk!gVvToHeq3m&LEN) zXm%33za2gZ0bk3e2{|hQ6zw46Ktl;2gJ7z`6O5o?bcOQNoE${>`Drp0F@SP6sE-B> zyIUL}6F?5S#R1cgEeLOM!iRIaK>-O`63M^@+BC_-2s*xs19h1MTruvo1)$aVpdbVX z7!#-`0&3wGvLPlM8NsfF%`$_FBv+90!SM<vz>zD@$iOfY<R(yjF)(s5qD*KZMubty z5zyWRP$>+KTi7y(6owQA(BZ?NX%o;H;owOTriGws6c(6V8VmH4G)-1WHyAwUV+ty# z!Q;^20LF5V4)}oRxgckPtYu)5VdVLTwju*@N;pcWfz*S%26ifFd1(z}3=8Ps@>-T! z)*2?5!$7MlYnVa(pBjdErWzI~i@AmsNd*fcbfL}%yBzEXxbrpHAaxCUYJ7HlQhYMR zpNgQMhpR#F41-Gj#US5-=N1`x82La2KO>qC5oe2QGWvlKvtNjtCX1h+o1Z4LpI?Y3 zV~D00`eqH#X7wUwP&LI3K9mL0q$=V9xd*iV47_TmNC?CQEjR$r{X#c#fW$xxe<0-s z=+Gc=QBdR#k^rR}aI6%89FOE7MA8B+iq!;l@j+*$gH`}@@iH-T2{SQriE{9Buy6=) z@o{i)2y)3WFf#n-ie>oE6#^Dx;a~#~kAS92q0<2n3RIkcqOcg`DU^L7ki!`nqgcRm zWNbyMj0_A_cHoM_H?aV+RST)o0hQUHLLD-)0<F<fa})DGM;L=f;y{IiA4YKonk59e zp%}CQx*c>y3}XrtXki6tNk9toLZ%v~0;v=haqvQmTILRhEJhxN0)rAJP;mx2hO=rn z*hwJMT|spXXd!Mc<iZN@qNSqLLWRV1(7K`$h?~I<1iKHeF$LM3a8c-f1h>STV(<=k zkncdIWq`-sAa;NU9@7#ta}b?F=wYy#`FVQCW1&Uh1~+&~9-;t5DFHx>qCmj`UL65C zGNFbcR;-q>g8{VMDTSeiF_Up2BY2vc2~vjNVg>ufZza<$Hi&a>aX@WP)nqCHjlmRw zjyqb(2pMleBqK3K28JD=%mK>AEKE%QtF#b9a(WQ6iov68xE4G>j?-s`4959@@&a>W zUL~{)hgb(57vlyyF&^ZsVn~Yi10{8EISD$LZUe{_;7X8#i%IAo8%vcq4wry(Co9&h z2r>s^HrR(?0&D>&$*u-j0P-dWBMS>S5#!DSpxZN0@&HpROEW_%YZ_!1D`ONJbQde) zh*Bx=I(fz@PUt#$F6cUW?iA@1ffT_O#weZ?nG~TE;TFay-V~7((H4d%z7(+(@fL<C ze#m8VQ3Bu`CJSzpSD6N<f=*8XcQ=aj5(|nm^1<8hP#ZM)pbLzO!79P41^kjhUW8<6 z1_lrtl&Qc4v;z3932<S|RKpO@Si=l1ju{p(gATR;-M$C9QzB83nSmh~W*@3$h|vRd zYY~kDM~ro<kPcsdo<ah|o#2Cyq3u`D+EE4Q3e!}?Db$FJfvN}6VFvYT6X7jZP%jf@ z5CF8K0dzZ(XBy~aKX@)ijA5XvE(Q<vBlV6GV5d_+rU>#B;6v%43F^Fb^cFE_w-v|{ zpke{06>clIF$)vLabgU7mJW90MGoX58}O(M+$2Ja319~ez$^pJgB5`9<AM4EZW6kG z@)C2QT~qM&PDMyZ=;o&>K=1U?NYzW%Q%FcqH`X&#Pe{;2%v)rZC_qQ+!DD@(V1T&= z+BHB5+{pY=@H`08k^P`!G?BtwBQY;UKfg#J0qS^7Q2Kz)jDcF|mHDM`uasvNXMp5E z`|-6Bb8@s$#|3miDL^3$bk=`KMt(8q_Ak)oO5n>Dz~c$X-Erup0}8MJ1a+05o`?Gb zRJ(w%pC;&@AW-heO)P*Mj>86V?=2S4;1jg`yTy%^<iW~{f<UDnxMTto;Nl6?gg68$ zp1|dwFnBixW0eTf2rObF2B>m?Wp7Z{24Qga2GyIORx4<ty+E#pF^dtw0*PmX&;7^; z)tHP~%%BEjGk6@j>ZvE%hI#OSP6BxEW&vbG8Z?ep0$PKOlt-b*zkosmG^Pp)3)qkm zBte6xUO=;Fh!6#J7a_p}JER#NlSnOyVrUKn?Zt)O^ORYvfMhlJ)K2ISB={HuaMcVq z3g=2uP}qYm*#aHb1-j(|d}<0fT9BLaw>S$b;~`lQsWJgY)GhYp#5_>5{T3*)Kyw@n z99)bX|CyM${xY#v2_r`sR3%D#85DQ$_yQf=1&S9?Oi6+U1;FzLkP5v@DJV5JzbqBD z9vi%}6O^%#0s*wND-e{JK&!VvXV8E&6bXVvz$pt%fLvV!IyUbG$i*Q08JMbsklk4X zwg|<Upjrde{s1Q{Pzw~am!XuQ2z*IYEn^KMWNjwsf}ds(o39o$s=-{t4C-$d$`uMh zJdv2f$iNT`y44M}5C<hD<kSKxfWfsKc*GnvrU}<8prLl~(i%`PfEGjpP>m=k_=6VG zqWTYXnpS=hq>#;rCsUAPVP%azYOVkksNg#a6H638+qJ+4k|%;DbRok&plTE0InW|# z@F88G?O;WSJq3`JenlamBq0SNz#Ua^x&Ra4#1YKM!0-l?IKbT_4#*xb9>yvG<U|50 z(om8JC>4W}2{?&>Q!@DCBhXeC@I7MSwR*t}nv98{jXcl>bRu-HTDK%$7c{V4Tml~^ zMh!1e3IUx*1zI}>o`gl3^$IOcEmlZQEKUV2x&U2PQv$kS4OKPdPMxC6V$jq=VsUXP zIOstG5y<5|bPN*hxDZfk1nn6~1>M#N+2f#I3|a7yoS#>gS_GPK2aWXR<iKMx2Xs&# z$W5Smf|3l7*6h?uq*@PjCm>i+5je+!Caz&64royGmH@K<<FivM(F-1K@J(HymQ8&8 zZ%}N30-u3{gRx2+Ii8SI;f^lQB3aPbB&gL_<WU1&ZC&I6+r5;<0$yebzOt)~vB;x_ z33L<`C})GWiLo!>039L)I{&g4aX6F@Xd4r>+Q>`;O>HD3Knp<d61&V2aQ`S1bb2e~ zyk*z`TT*Ij9%#xi6|n&C7U<B#jO5&ckd;i}WptpU<v=xXD(Jj~a8MV68?<v7B$Sz- z2MJQdnmf=CQW5CP;#(Y`lgATF@{4Y9fzDt|Pb~r6(+FLl4bBUo16$F88a#Z*#=^i* z49*bDLW}~8prPU_e&m2oOi4jq=n5JN0oC5%3<1i5ReUv|V-*<}GS;#}cR4avYC(57 zvJ@*dfhL?;p=S@WrhvAtSk$lvgAQV3%whshXp7Xc*09zvmN67L)vz)#Ffs%)6gt&_ z+v}hu+~C&w4kqX%GI9!104+Q~9XN(8;w~))7qp<ZIMU23QtkrJ41vboARAF2d&)G5 zQVT)5#~{NSu%>PTvI(HVw>TBtJ4PH~UtF3AX+EI14RrD>bfXt|JQuWN46?xsv_1yB zm<gV-u<kTT1D)egng=%>nhs#@f@W**NHfG9xN#8sU~9(UYjYJ)yrQS6px~LNkf;E+ z0NMF)voedpYgj=8@Trg;KA`ns8Tl#DL;fKF2)cx-xCEt93bh_?5K@&69*h95?}O+@ zU#AC}G%HFi1nu|%cW&TLgd2wJR8R<j`(B_$u_+2@^PPz9Pzm%ZP0&nPX%4852{#Uu z5@1~eBzJ;W5kuBxfzpN!WTp$W-VQ05K<BRDW<kb1kXO`#>MiiNSUzZs64H!;m<k=| zgA5;l4!Z@<BSBW#fHN+*{sI%=N=%!Pfq@^CXF)@^41A#bB0+<{OyILnSr|d<)w!6e z#E^3^D2qT=2cZl_fhsmoGYOoJLA!jwi&Pkk1R%q}!LXyA?=dnk_(N8vp)FkoH+w;W zhP)IrK>^Z#D$7h%NXah;Pb4BON<cLUbQf=82_*lf!lzY0D>|{60_r7#rpXc0B;X5Z z5)zPn3)&?Kx-|xxP@#*+Asr(~ydZ|H5)cUm6uGcfN1C9`sIaBjs8i>V4N94L(8X$? ziVz;_AURM%gxCU}M*%ND1J4m<7Q^xks8CSI0IiJ!cbLI9z7;DJmnMP7RZ|hJ1J%6H zX>!OsFnEV)ej0R{ASm3?;v*?F4YUgsGzAHg1x+ZxT?ZX`K=>FmERkLc3To(aQP67o z7VHKMkQ5{_f>R%u04G7vQOMe$BnYmVIXM_no7s?bjWNszN^YQGsAACdoS@zSXlxw3 zX_&Ewp@vbCp@^#nGSmk?H(!&f$`-O81=M&f&C4t-g>O9pw^6`L1VD0#p&H~Op%^sL z0&aqU#>`hjw`ziN9(pY(&B(xD4)PADVq*aB_`v9pf;W7iv@<|{hxZ&nrv!qQewBdE z;1&bVdxE<-c{X5C&{2vmu)YN7ut{*82kA?|W=IVRRr2^sSU_8J(ip`UnnCNZK^Lwt zRT+8a>4LWdfEo|boA^M5HnML)9eAWtt4i8A5nN`cq$sEsfod!yNljMB0gBn6q6j=N z589eu1iBm=)|Y1mCphpapP+_m5tf1obi6<&Xd`aCEhy~3yJnamYw|%0>I9fTdv=lX zC8%2uR*pLqwV)ea(?KUAGo~>0GJ_h~HH>MXz2%_!Jf<3EbB0=`LJ9C}GINy)s4bS5 zhtglpFG8(?K)DD-1t?vB&aws%Ppo7t0<8sr`nxC<)Z${!ODzY_$fG5cTkP?m4sm?E zC&<H~77zmy==g6gM%3;wR269KmdVczL<wRY!Uf&^cZ(w+GTztG%RdM_xl#mb@_{?C zMWD_~Q8cJ41CAn4v0ntrctxP(T9giw$N~}IY>6Pi859(s`$0`-(1<z*BMUPdBhx=F z2@XCE7A}4cZVoPn|6DR$JREEsJm3LXP_~2(w18>Q#2k2r1Qe~Pqr;$cvx|xt7#I>k zoh?V`C0~%cAwk1w;IZ%I5>WXAIx+!rgFU2g3mQ8~%Lm<X36?D>0S}^pj?OAdRY2ro z@CX37*v(5$h30ZlR~fd%8@l`tdgK+nfCHHhS^!j9l$;8>4IXrhAEcE5ZfJpSra?9Z z;w12`fZ$PD6m!7U3T&BLC3H>&;uX-vp`a7@Kx@sxdh&}h(=+oDbK=2kT);xGfg<>- zbV#cKv_1x0=7V?kry!XG%Auec6|inRmpOpKJrtDsK=n2UBRC!~A`ev1f+Md5{Qw-M zC>HP$IG`iXzz5(&u|Y1C!E^Kt=-?X$q=Rqd!2|k?QM{?pA^m31kv9@4k}V8T0x41{ z(%=Jc6u?K{fDXI?4ZJB9Wq}U1QHLBu25NlegJTJnRzO4Sd7wLolCu-jQ;Ypj>JCs^ z1bG+SOaXONz~|L~Z{>ze$S~gG0Y_s>Jm`EftaoF9Ggl@o;9!@+f!qLbQW2<h$^%_0 zj?qE_g(lc)KFB=_jNr3gnIMOzR>{E+vjPo`gBrx}RFYX-Vz0>rIfoW>&JlFG>@6|q z@o@3^MJS7ou$*vJ6wkoGkOOx%Q<XgEE<0pr!xDTvc-cTPiLTc{Iie9}7O2kwHV%|a z;h6yL7w~aSxu``CxYPkj6o4EHsYf{&nf_PF;dC(MWGhhUf=e6*1_lrtRI7qR8&vRs z>P~QIGr&*QHGz+>fY0CtM>zPV1MrLxIHMx^Ixr8xVgY>k6gHQ~g0{#byPV~Jl_E}; zgDeHbHb!6*a=azn@u0&$z}-`jSs16=;r0Re<ScAHhyhidXg<K5SfD4=fdZVAz*mL3 zAJcuH!64A8Qqc9ju+aVmYF=P-YcvA`LlY@(1)VI1?p6>VoKUc4OGEHJGf?9Yv^Y2w zdV(H^4~jUXYzj}_Fjs@lcq+o?YLG++va6Z?S1I63BcQe8DVaqm1sSNd2*O}zLt2cW zCNSvs2Jkj+rUJ1NX7Ei9EDKmum=-cFU|Yyg%Ur@<!<@wdz9Epa8GJ)vGh;1F4MPn} zJXZ}<4NE+C4Py;UJWmZv6C>obohnmz&_E%mVFX%nsF0gl48BkrG}c&9l%JH7np+I7 zeDc!4M=WX-Yl3%CCxXr+1y@6$N(_V{ElFrm4O0uMuu{|06~F~Aq$&le1z}J<jHu<o zl_H{bP@a*Qld4cs1X*L34|4^~SQLw)Jr?M^6x=pw^$)TNf~)g$QsPr9l4~*Dfvy*^ zARW|EgHGM$RDxExDU{@6nhf?HxOsqPctC1VMq)v+LS=qw5oq=(zcjA|d~FkW77o0L z416>cNDj247wnfz(Bu<zUAH}oS3y&SpxJ}ujKsWj@Q^GdWRcvP1a>93T?I<V0g)jd z{(kYGD|MY6ojqJpj6-VdE0iS`WrB;El6=TH8lb34%!4`%JUs}{1c-5VP{@K-&w|F< zL2J^I!Rv-^@k5hACiK?jqIA%qRve()8_SCl3vRKcq^6|ifv%|p%^w$l+b2bfKn1~K z5b+J9nhO!AxA;&SPnyuP6xg9LT2umRkF%8I7UbMwPAw`zZ;%ThIR~83`al^JRCO>g z^Dy!-@d=25PJ3fyW5mp==vu*MqZH|&yb5aNgYzroII=8;0xs|#VP?=xEm<rz-~;o- z8Pb_*m=-YxG4wIivQ+Vuu-34EmeGYX<VmqGl(1F$K*vHEKwEYg8K5Jfplf`<^GGS+ zox(LNHVieO3kaAK*D--E*8&{?qmY;czD+k(0k-cNG^Pd)L2zZ409rSZSq8Zb8Zz*i z04m~;_sN1XWI-bMu6KA$E98T2cTWX1#Y%I)i3+?05;~Bj0G)6IO+kaEyz`MpB|sZa zU?bY#Rsv}99n}?xr3;{x3T{h->N$|Rp!UL3YieF{PJS_{p#jR@8jvl3putg)HA#@1 zfTT|Wp}s1!0A#2l(lSiQDp!zUpi`Ta^itE)l|Us7XzB#CG6`~+3uuvlW*TU}KKODA zluagZcOfs^1&0jS5e1+tVHA`~^HNfal)%%ysp;wJh_W<44<1cOGa}%DX6S%2G-$w^ zX_8VEK!c8{pkt0e5dmovL(dZ~0u75MmVkFgE0iE+(jbE?kR}@V4rb6j%doTo8T|ws z4l3(GZUz~XTB!iqLYW6zOAPlRH2s5DsAiTZfXvDUD^>s<6H^2}_yJ-7$SCL{>Qn{j zE$a$7i6yB;i1MO}MYklk09=D;aupSTT8E&b0eou?_~^zW&{PcQu)#{ue#Ur=%fdNb zVcol;N>HYki7!tq%8M_}LtID>zM>pl7#HP$j?9A=7Cgv_?-ncA&9``<-UBPY#a)tE z1Ul3g6qDe54k19T)?0ia32=r2t6c>uK|rSlF!1t#uleEuEu&=O0-c$J(U?Wmic;Bw z+9&Y#Af&Pfty0KlDv|>Y50x-vflshm$XF}~s<cZ$=hiSRWQ3f$S;CUV=D<*FSHoDs zlEv=8P!yEHQo|qyx&(@20cQ<U2^aWO8_>~utcjqtW$;+_gk)>zA{9{LhxSz=?c>a1 zh5WMAqN2={6wq8$UJA741EnX>!3@czNQ=f1sj9d%IRn(h(=W*_0Pk(jFG$TRRwyk1 z>B}zw-SJqOmstYoD1+*jl9I&a>{QUe6WnFc&9NXI(6|8|fDdX7fLEs^<|&lsC6<<C z<QIYOqb^9S1nof4Qvls*4$f+&#i@ubWSO7=u<X42@;p%28gyg;atR5Z*hJn16r7r> z0N;zAs-SFaZVE0w!H4Fhq?UjdGa?f6EhbPERu0<7RODB6S`~bs6{tD~*P}_53g8Po z^uc3fpi2T%6v|3-@=}Yy(k1x{iD2)8c0c8T7hHk2_$z=C3#>;1?x})Os-A*#eqM1V zXy;QR<OsiFG|y;&)(nAzNUu1x1hSzPkrP1UexO1Yy*Yp~BnE2&XzFQlLvkeeV4};Q z+L#^MR=CAdT#{IFiygF&I6o!z7JG2KXSjce2ZZ4s6mW|Jlp!<o(u;4gfLOP<LyJ?3 zK(UjVm#)bS&g8dPazT2TbBog<ISf251<GbcHH-`lhv9jPONs?_*|G=|6ARNHrvFUr zRXXTRX?*z~rJ4riG7tt=)1W27B@ED<rd0x6YXZt^P7Eo`4xr{VD5o)kCKVYOAm>6Q znlLdi1f&*$u0I3sx`M4#K&)Xa$S*E|ZgvJ$FZpQ-384LJpcq7-QOpEydn-y+0NqoT zkqWv_P@xEZPAL5D^_2X)RBOnYWbidZ#R@6;dFqI*h~Q>qVqRrQ2FOxyuPZSJlou*t zJ2_MGk?I*(2*RqiqGFgbP&K1a0$S7rt%m&ld?FPR(@Ii{6pBleL3_ACyO=8BnH8Et zLDnXMR~Qt5w|T>BDe#m=Y9(axlb?SGxFQ1`Zjhe`SA#T>k&##eS<C^Mqy#l#K#3Mq ze?yMANAd+CU_niEkTPg9T|omB<oQL3MU|T12>@tY0^E0i)O-mb6CsfTYQTap^ms>* zAjo~N22N2bNCZ?Nf{wWW+XCL*4h<A=SV5<b;DJ&EUd@bjBEl`!g8bslicC;<G4nq^ z=)fFSr2N$iss-CXl^JVtMs9uzbddQL2gn~F>u+(u+*{NGQVY&4U;>n7ZgC@}y1SsP z10Gl5=VB6JtdfRBHf;O~NiE6%J80w#gu%H3G-U{yc`4#6VN78JPcblp7RG|t;xZ>* z0xgG41)qkX0B*H`>Pt{DR+Nf}RrtnJXc_?@+XCLU3)%XE6qTN7p#G6UN<O$#gh+(Y zfK`A_SAjM<LJiBz&ns3a0pA-7x?c}8hliN!1G@%Vv%!~N7J(xLy5kCzFB3rJEL0Wb zs!7nY3_S$}jd0MBWANAn9kH4SIv^Hy>stbP8JYmPxv4C(C_fK069(@{=|GBeP@$S% zib&*`g$8IE4m1S^TA&N6fWSk)P``s#;^ZfTXWtURYn?!iEKqF(cOR@)LYg{-#X00q z3TTjl!yhz#2y5Ge&QAlk?lX%al|CpcQxr-IkaiM-cDELRHZ$kvL2nU;?DoZe-L0O2 z0;q!uYL<g4BXH&bRdaB+f)X@1V<P&iI-oOCKxI`PI1PaJ=7Cc{LISi284s%ri$M{D z+{R5w%}Iq`UV`u>D64>r);v%t30g@Jk^w!XG%sHvy)>~XF|Q;Q)MH3Ql%TjQgB1g? z8XK}Q5WJfX%|@i;tl^hml4=F<PGTh_O(Xj2P<^20I5?q#A~X>ixG<l>0}MKMp#VCf z7b$Cj3w-c0A*gAf9edD;=*s+3g*5QxKcHZQn}oxMNGJ1FnL<WzpkoVAlVR@E0T-X3 z!!|)<l9jL)V`>U$%_XRr4ZhhD+@gogp@Ns*fr}|H0V=DCQW+Q+K7z_9&;UJyFz5(y zrvEG~Rm!k53oECvv|-#Z3M|l&Ke)gG)$7m|mQG9z3~*n&KvD>3nH$tUsYru*kfZ`y zfQytTbfAk>AaxpOd=73JIJcyN0|LBu3#O|QT+M(wMTsQ}$?)SAl2TDBO$A8eK{^%& z+~I>?I1M@j4xCuPu?s5flJoN*by{*IsID%7ob<1wP@E5{q99#FxZ@zbG0-+?aK8@G zX@o8pPK8AoEJi`qW}*T-OTrC8_$sv`Ij6K3G(-r>#R{PAcMf=N9n=s2SM4aP6_8Iy zKs^KjloC@@tRYzfwDKGz0P+LUlK1=~_{nr28PGl=#34-y35g}3Q~y9$YM17Lo3)@Z z2T)pvEq90X6yg2Od{Dz5pXb157l1M!G+}_M6hzbB58N)*gscX*#hR91l#G6(ZxLvy zhnp2~rxeCa07e0($p|r)(M?kr>r^keLkwE_4xZ5g-vCksnsg`vjoTN22E-v3V1T;5 zMU9{)0}rS<o|z13uYp_7MUy~n1W-l;yAW(65&_PJplP;LP&Nc@fB{{S%)-RM%)!FJ z28S|Sl1z+Tk{lu&Qs7BBth0yUya#G5fSS?^m_Vx_L1WWdEa0_}pxc94s(Qc)3pyhJ zYCt6rTY-W#f^V#V*O~Aw%%DylV(1gxM+5aI3ktxRK#isp1trL+uC8l(da)8DYHtak zSKd|JNUAg$Z?Pv96o9mALR)AppuhwzPAw7yb%Xdo7DJi~prc=q!WB`*fd(`rLFoeA z4rAwG<oX95|3vBcgNiQDz#%vYA#)Q8K*#7Y)i5js_1BrJ`kf(bYe7BX#G<6k5>Sg4 zwq+fXAz`O;pser!xgIjY?U+}oP*j=+o*D-o&6=1~kdc^InwwgbnXIp;0KXCr(oTSO zyi*{}mPA-~SJzdCgxxQ`=r~8+s6^c=16@nKSnXeox|&S4n2J(wF&CF6VY`m6s04H& z3@9W(ElUPgFdrin;6taND`%^ON*F-*j6yD_Z)SvEOwE|Zl*Ll%1Row{1syTHkg1jd zbo)7Isu~n(u*)=3SV6}KRyl!_0`Y+eTQdn7k%pddQFH+`8tn=qW`feeEJje<oug<o zNCY(a1HPTSNFKxm<s|TFl|{2bO6Pz^o){tW;G_X2z?rX<fq_966e{34kcEi}w4RoS zu?QrN5jyZR0<sQrvN32Fcp)=r%QI+=Mb$>)y{HZ@>(s&372za8Yyyc_hwN|%RivN{ zUX)r4S~Ce+zXrMN0KCi_v;+=X_f_#DrzG82?V^jILo=8WAy*U$2|mycO{6>q4!$Y| z1_nz|@G*hrB-x5Ue2icNH3-023$!Bzw6YtLV88)Z0}n7ztqNMV1R5QIML#I}fTlh` zL&Km30*J4hTAZ8+zKAiuC>IfM>bmOaVFanKOTeeVf!AU|vy*x}G#3?t(h%6cMKYjt zg5?&=qG|>P1}C@=S;2f1AA)=iN<3g6x`CEV@IbC<1>Z4a!opC(Sn0sXP|L{3P$dIe zDHhKJCYfs(!x=!?B!#h-v5qkqwBDMrjuCWt7o=-f1sOmNOU%hk0c{orP1t}2^b!>U zTmuwL4J=T`iy(Vpt)UGjP&ox($O6uLpo4Go%0Om;0vNm@2{MuaI<OB?sQ9^QvJ};V zN>=XR%Dj@q3h<S-MH4|)8yo0~%e;I|rduo^cidvcsDW!37#O@j0mTPO3am_^Az1K4 zjuc}NNDigJ2uc$0Km(03SBXKYE$}_%Of^iP6T+e84MP@V7E7fYBSS4SBSV!)2`gwv zbrU1>+%x7n<~*(x##-h&W^mAfDmtdBn_xe~_gUi$GKk-ybz-7IQht68=v*hzKw@$t zc$Ni}k08MdYW9P(6KFvzXkilime3&Zg}_Lm2WlBX^=5+3N(09Lw0{C_a%O_gNCWj% z6Tw}|QqcAhkcH|6m7qJ3GxO5b6>{@aN^?>n4h7xV0V;k#mjQy$8ob5k3*JRu<O_-? zUQb9QL&fHTvMx)}d{F8J=U>nc=%NK6F1QQ?6EdJ86BO?epy&fd3j+rz`nVW{7{TcQ zYkLE{TIm3`)k;iJtSL-UY@n(Dd@&<r)e;AE)e<LoBQir27jz>sH*_O15BRz+(Dhu9 z>$>=$*LCryh^B~v*C~N6?E+oQ1-i0}Axa2*VHfCHF35#lBH-(~K-Y39g0JfmgI?Dq zo&ve9OCnV=MLk8Mg`t@-N-9M&MXQA&N*bKgw2OK`+153rs1jV*z+wax+u->f$apdA z5>QA32i^z(WkzEIBk*}psYS)8cX)vc2T;ocTsVMEBLXdtNnuQ3Xa;R=W&}-0E?@zR zF{Lm!GcN><?687Pn$TqNE7}0ciX8Faap(B>qCKE;nXPC$D7JQk2vFcdhH%+aGK)ZE z<1KDTQUTA3z`B0BKx)Ae4JN>`4Qkfrfnpn!5g8cy7^_76N^^1oit<78Yj{>xfz*RN z1Ip!~vK(~c2V|uWWMLQ6E#~;NyrN}{3=Gi4Q$?T|<RWY<rNC=@K&}7<69Z$F5{er@ zV?wY_I5-SIK13Ns2F=&NLl=}OKy@-`rUtZJcOiJW7sOG_x0o{XZ?QX7mZTPY`WJy$ zxva#J2|!DAN|79-fZIVhmgB&k174fYumE(q0qE=-CQulG)}O%~!~(ijzGwx=5umUt z!sZ;1J1dBG4rs*<I3PjgF9QPuh>hDhjHuzm5}%P+jBpMt?O=;F(7L#4Bv(nI1QKZH z6D-zHihPiBu%{kI&<*U6aA5*F;TA_~dOCRV0?ZxYxesvi1rwk&d`l=EltN&+5}f4g zkenrt;w((HD2@ZABoGECZBXkGG~!y!10sVVQ3%>71-erY6p@UugKU_K)`KE&BZydw zl;Xk8#Wv&ux<0oN<Va9Mn*mfkg61eOLlEXG6i0%ZpP<qi?8q|E;xUFShGH(zSW6A~ zq9O1(UZCj{riF~P%q7fOEJYeM%)ty*JT=Ua)k)AQm94UXk)f7_k)cYZhJ}S8i#>&T z0S6@0m@_aj#IrXsfU8%AT9!JNJgyWl4X$26tJ_)pz-7@d*3yzRU5hGl(9}S6Ep#ZR z1U!CerBGd~$%zy?Yd}E+ivC;70g*<aH7CiSStp^;yi5?oB^5-1+Z&**!imNCdEg}| z(8VR-D^nmv9cx))PHE~b=G2O0^u{RYTH+2+;DR=Mf&v$O9|R*CBMT#_I^$y&W2{0A zYUBij64V%p71X4I99adrMhBc&S27iW&fzEmSzELL<UerQ1QVbHS_HZwc{<2FAk!Ea zt58!Uvfa=dy20wm$-QilJ4eBp2VC?Pt;6CT&|1$~NbZqF$sw>z3o!~KG~gu(==>c} zzQ~sVCpu7aW5{BtK`l=pF~1w+2yhXHEqFk8N6*FS99Rw@<Q$B07S$oQIAFJ%5(pg7 zQo#jCu93waIG`~|&>BIUQ3YDP4+@?lDQv-$&VW{Q?7<sEpqsT9gB%44eNc)PVXQ)R z7(AF@4g-~9&?LkFDl9;S2Drcgb)P{U4{-+Yc6bKRcKBkA62=s!EGF<mMP}GS#U@73 zsm36A&=m?PERcH}7qF(VLfN33MH#Z#LG!WTEuc&(Y&Hxf99f(TxN2AzG8XlfaM!Rl zGcMp+$WY5x!dt^u!<xe0%v{S}!dJsy!&Jl6%*@D;X9v2uJBL44pq7J?p+pe0{3?Z` zhGl_J3d=&q8rC$H8jc!P8-^0z8WyO2&Jw;FPMCghD~ZdmiUV|ZWkE@?ew9sda#3bM zi9$6*M6swAJcJA0V+bmvU}2?@2vU=plcoo&W)zERtC)DXZZUHGV&pAa0%}OJq*kOR z!%hij1+O*H6fOdl-;hHl5ewwN`Tr`Ykp)ib;2HtmG%Gp;k^pslZ?S*|>u<3q=jRq= z=A;(w2id|2>Q;dbFFF9?Gv}n{6@i*onq1(M#31()eE~HD*&x2U#SNk3!QC)^C<oR# zzQtAyZn55C0hOl^GhrIQBH+>qOn{3h(8We8KnV=gHe~>BBxYjdU}X8v@}Gr82;7AO zZ482}r{Q4|`p?14!&oJbnm0=G;vvq!C^SI11f2Ll0Z_sKnZ5)?+)5_DDoe-|M*(ya zA3Q?^*%1vI6$gz5m*yeej{;g*0$QC?S&+Jt@s_Y(eu*cnp`Mxot~rV(gEAA?b6^7O zLr}H6ALK(w7GeS|a2G^zKd9wHyvvJDgDg1%BCuHpD)Nq?StpEY9b^$bC}?2$6vPH$ ztU*P<LQny663s%iwmi0?0aQ%Diw4LkehWY=_8A!&YM6>NK*N4n%r%VZj5SOPSU_XR zkd>0b4B#7Ynf!h+>T9yz5|0P>XA?_O;S+=4b{J$r9ozr{b?zZ48nUtd77J)<6Ki(> zlzq;DyaH()fsRO&VyqHC4ZXBHl+hOye}InB2Mr@+ff{Pepeth+GL|tEsFkoRU;_;- z6sVQ3Ls+0wLW&JQEvFQwS|*riQ2<P3aX<-24HIaxy@WH13$({Jg&B0dVG4^lLkTzN za4pcaP$2!9?1}!YNV8ms;TrI{pOEYbZW9%Qmha{lAzxaWlAnyUG$Es;q@dVJU%xoD zq_m(UKR>5f4^(87WTb-CW#;Rr=IMjh@D-Qn7i6cygS=QTqa-&+IVrI?Gg%i_jq4_Y zmxw?H$UuuK?Ck6mKx=?fQxt3!(o;*)GAl|-i&8bzi&B$8;_8Ug%wbAF3y1WI!6OuD znK>n?MH=dm>qXJjmK7B!*rN88a3l=yunf#KWkm%V>S_7;`bmjJdL<PlXr_WjVl+T5 zOHDyI4Lop#X^NhnK8Xf_ZfQa>2V#>RXr8D@17RU3EWi$>*aEOAAXn<?>Feo{;%SoI z3bG}QG&>*x3lEX-%)FHRa_C}&V$hw|po1zPlM}@yMTwc|86~=<1)y!4;LXs;`{rRm zR-_&SatLPZh7=_xr-D{lC}`y77ndj$r6#B5l|a@b<s=rDXj;MDp{EBK_5!7uFi^`M zT+&-9gcgHu3ewX9jb_5vTZ1R@LHF{&hi<?*4>Y?9TAK`aDcpF3Q=P2_y<?qn67#Yl zt7ae(0rd}R9tS5g;<FMwDE#vCbRp9%$X4X#Bi~H}3og*Ec|;Z=Gddk%dr6^DiX7E` zRkjqxF!+v_Dt++E0PwmI@ODzfjYFWJScOD|v{FzJr~sPDOe{{-D>@IlAeiwMS21WQ zY))!fYK|rkqAt6|R*+bfl34_<&Tesn*O7rz9Owd=f?KSa#feG9x7hMZKw^*;7@eSI zLKmoEC*+b^P?QQ9P|nXoTYt%(2^q32>IJC=w_LykxcPFPk%8d~s7?g+D;Uf~z^8d} z{AFSV9TCpLEW*ga0y;l}iIM4Vl?rN2iM?vZXz74zP;kRT1+rHXyb!aQsYn7evbTT< zbP7)}LkV*VxHbf}-87l~ZgGHmuPKQoiB+})TXB$vTQPVlGrzP%K^>-7LsMOorRXrI zfeaqcyan?ASrCD(Wd#~RkY|IPd&3B7l45JjrKgr?%3zz%hYTu##t@;MQ;@x&anK_0 zFeGT`4>B+a8s91c59xqg`{3q1s4EXy0RZZ?LgxKJoioU3xu7;?5vb)?1Zs^zI+{~K z{s6^Z5y;_4Llua)1&unVgW}eRfq?;ZMlR?$Xci_877k`OWar?AvspRBIatAvjfs)V z3p{F#F*FZqM}mjuL8DlxyTDVJTNt8PQdm-0TR@wM*@8hg*!O~lzSUp@zu+Z=Dd1zV z70NP;N=g%Rz~efQ6`vSs2Q;7qPCJlw2MfT5LV%XJg9c$2GB6@-_+<t=7rdwU7BA?y z{L+H>f}+&4%!;Drpr8T=3zz_>dr-vaf?^wF1p^}w=(xf3beJ;{JAXk__poL(NGS+| zT@(c!AFE|dVW<V47M0Ch6b3o(zQ_SG@D57bH4O2rU>+Oj6uE_<lSkQWK*R7Hg<&;} zwM<|+PLRqNrdq~Y=0YxT9$@nO#o_AiuIuUN=C8>G9&@?H6Q5Ze59(5a3jlZ*@D>NC z#S2b&w?RGyw}?T#L`aG(%FizWmnhJsrjTJS=KP$LBG8TCNGS&#Fn1Uk7z{xH0~+{X zU<M6tf$l}(V-#QnE#P8dtdev^4k&PA5*pH=xg&8<vIj+1ktB!(8qEPmN)gClB+C#{ z0ZJiSAR9qFC{QxxU?~ELVI)0JNdiuKE*P^y=t(byy@er)4Kx4%o+08&;cj7w;z;F8 z;Yr~I&(LtC@C7qy@)z}ilBXFo-oY(s=*~RohHQ964=&L`6K9~VFplI3av(TyK)R#g zli(PU2IUb&J*3-?tr!C3b!Sj$fHE2bW0i<YYFc7xP6^bBMS57flO)*83yKzOHiHTn zHzb?IFl@%&vxM6X8V&-_kRbV)3GC-v?9e_U)-E)tQ1e8xSOUXhsBVnO8F&v9lvtrd zs0>-4A#|n`M$qw|E1CRmF%>0gG8ciO1X6P1oDTWPz`)>x<PK$YcYrDuSpO#;Iza=D zCTIx(3JFl(5}XFiAk`gcO*K=$1n2?`(8k_y1}26S1{MYu2GAH)FoPjOv4#NyWUWgi ztU!AVnpI_jIQbxm4e8oKaxNRhVx+7D&bOdiz#rszPzePo(9oR^nxjDJ+=7&XG9B2x zpiVkysQ~y$8o62~(Au0DrV^$UhGxcQX3%gy=)mM=CPs!r4rmdj$#hE~7(5>2mYI|4 zlMmY0a7zRt0=lynA*#s&o>#mj47n&UCo?HNHxYEpdTLSSEtZnXg4Ci(py@}JA`Vb% zh6hrogU>#M+-H7^3o4YHQ;g>ITb%K*VVq!40DxkEfeCb}n*d{#Bt{^>)cR?1W2?rC zKp7CJvIQjyNEPb|DqP=y2yoejAi&`dDo7ka)`NDMf=e-2CCkFZ2rgzY$}>>X0hebM z808u4Ob!-?C{`?oZF8n@wJ=0+f@hbxi@HE%m>#TvfF5rGUIGt3YY@Cq1T@?QS{VyE zW;V6B1j{rssHOua1W>8~jXbPm@^ga(HMY{iiGhIubgOO=NKciRYi>bFCCmwWHaUs8 zNhyhT7!^7;OTd#oxGe%D>{L*|f`W^Iu}TQlDsZ9(OF=Ush>c<md`uj-9iS2@1IZ3F z@4$xmQ8Ew64iE<UzZe{5u(5ZDJ=kuV0JS=@@z@g&I_xw)UXu%J$^;i&pi&x=MnM4s zX%K>pg;<J~C_yPB4rCvw^aCYI7A79h;!kF9n!!krpz;fxAko`)so+JP;EIzq6_g-B zTasCC@kC`7_$KCMrh!sal^nRMSCv@+I%o$hrjS&c3A(@wEP;|1KsJH$DToH&S`Vu? z`t>>)+Tph!bTEKczPT`fE<P?{1`U{j%TH#M^3x8b`~<D1WJv^t2-sFozupPt3I))y zXyC=fiA9wP#hJO8If<aXh@kBV3RRf}kb()ZR{^dYJbGTN1MS;^b{2vz5C!iu0$mqY ztfNp|0y<zVDzm^dFAa2GD`=HjF?0<M$bL{y6Lf7^VhLzB8PW!_#F7jJ_}GVnMt-qg zacY4kc>M>cr2%T@DS+<5hPwrni$UZ2i6xmynK_`%mEcW)1(gMrpf)vhPz5offs$ZB z83R;dg0EG8T+kFN2O6kcz>vZK8jxMc)B!$Rb0K3I6Y}*6Md!dvAz2_R9>ML-tDsVv zJw3Gqv}t4|^oj-0tn^C8TdY-}CK4n)f{RAbB@2z9R0xW37FMReJd7Ows#K8^j~+Os zV7X%fbkI0EbX)f=_NdGPP@Qs%1Jv3DH44DjaA`7wYYlMqSfmST-hi{gCs0uha=<NC zu<7L>CxF^044gcST&!%r+1RUuFdgBi$&NMmfs6m|Ab+!fsv?O0z!rfCkVQrBK~{pS z0r?bk&jJ%8mk?MKBd>u<3~*ipb&HYvQK{gAK0r5qM6p5pQtT<<zSJ!d-_+cE&`wxn zS68WmlLt%+l$Jr^56^_q0btPGv5=e^pPQdj#g_}sw+gu>nYpPbnG@tR5C)fQpaaQ3 zW8RRSdM#rKG>K%ffO|a*WsJpokfZvtSZkQFnL#J%E?@)oXTZ~d>^01wl_?+<HsG^e zB^k0nH-9r$g@c_9${(PHgF+(Q!Jz3gaMB0w5`Y|d06*yyNmUML@EUZZaAFGb=%6Mi zxXB4l4YxS*@{2$x-e(knHs0Oh0PSQ2`S%tp*xN;*_$>Mbic}6*fFO61ivEHk^dE=- zM>3cI$Mg?I28PL?m<E-s3@o67CBzuH7zLQBBw;au97%ehB;%*afi-2Rf$Zl3CFvCK z4TN9^6@hHPn#g`KGBEUltOhmRKnJ<;FcpEsFp?Oka0Mr^Sy<W^sjSVQ9ujj33%G}b zwuUa13$lu?nK6nRx{i(~l^3#-u9-2454x6)KLxUuP5`==P7u15PACPkmQFYYvX)K+ zx|U89d;%Cllo)g^ojAA!qgd1rYQZSMwgrLjT+c5m0T+Z-nFWyLajEI)SXwRcbPB4n zz?BGisQ@GBW+<jC@EnaeLk&Yb(&bg`;NB&qQwkavy2TDXEC7;jAVphMCV2P&=h(q= zPy~Q1hcvaLG7I31pLl33j*_Q9g)c}sI8TADC9Yvy04a1CK}9g=I)W^gY^EX^P|K@^ zaRF-$Ll)aY#v-d4#u9cAyO|Mk16D9Y2}cTOyn!K$EsY6sCM38y&g=(nNd1z8Y)uD` zM}xKiLb6htf@-lQ=PkA(&=70^!ly-`5GVqz<thSg{Vrl;Vqhpb0!om4j>W~PMW98a z;PF%FN~v3HX~iHDky0ioKiuMt2i2i@Y5Cwb`)W|=fEvQ!BUczf+q#87Yh?acNuq=l zvL2M+0wrD4-~z7!5eE&mFoA}FvY0^2kHi_kLBv!73NEH*#uP?z=tW@**g*22zIO?G z3g`|qhAbxZ-~wILT*So0z@W(i@i#aG9)NN?ypjWl1$g+Rhy|n)(i6MI0Zt!@B^gDa zqmj@9gDoC>D9CnDD1gfcX3$bsIY<bAsvJaG0V_nQra^5=koUnU1r&y$)gBNpXEB33 z1YR7Z$#RPi6y))+VyhTZU?8FsOZ)Q{s3rx~*atx_10_iYrYd3N7=cCzN=F-1%&;>s zFn}Ed+M5J&P%&b+FldDictIHGXzqm!wJa%23s`Cx7O;X=cr0YBVJTxM3aDXm0bSz6 zS_4|!0b2jT4qC|p8p<oQfQm7Lmg#9S`&F63``Dn03{);^Xexj=x`7UD&Ig}B4{8a4 zmRCS-IMJ)hEC9DsG&zdEV_=|B-dh6j8O->Sd{AKB5&`uV;!{DVK*HsU!KaWEaWXM5 z+!BljZ<<I3T|5q%S-r&zRSq!$b}%zy$ted&9~;<6NKX|lF@Q&ZkAlJ*G)4hhV*?sh zW?|uC<X{v5<0?hu7(f|gfcYOKfq?P_Jb}Q@%>^G822TH=A;krtN|&*g8FUm8<hE_l z&P`Ct0<Sm$&t7P<+~Ne8A77kVm3oU4v;`m@Ts5+QNw(Z<5DmKL1(eo{K?gywfRq*q zfqcvfk}NJs%q>9kFLc=?*to>J6tL-+K;8#6i5QsJpr@uFdl?)lC>l`GAE?O&(hN?2 zpu?YPK-2FG3mM87iX1>ogcmZ@Kn{$T0yjArYoP0%Ye2{7GJ#eX6-t1ISy^jXKp6;} z-azY%m?Rk%GR82~vevSda1<w$a6%T4RDGynT)<Vski}iYuz;tAX(8i6rdswIh6TK! z)kO=LiaKi8K?@yA_);Llx2!en3mH?GdzoUGYB_2-OPCh$*KpJ@WC<(~gy?2uC}CP4 zRKo$fMxaEvhO>sXhBb`|G?r4sxIm<avxXg%6RP-1L_utjcsN5|8Vf@SQ<m5SM%YnN zU_Xe1?3%z><c4t11jZt{8g|fD53sA4vLsSivY9|?N+dzIuQM_r%tfecf*v^)&X6Yu zw<!-Y5>>;vKngUx4n35L9dy5(UzMFwK4`@NC_^fNXTCuE(!89^ylf@#Q4XLw2a!d= zd+0&?&2u0fpDIp06=?R-WW2=;n&@f*4Q@%_VvEnrOG&LL;saGa;G!3?v|}l#IF<lO zaD&nvZ+MVrh--XsXh48}P{=KIPk(Uj1l}JB$@<`o%nceUhwjh0#Sx#IT@2bDdW#iw zU`r~b&I8Q`-C_luG?iKeN?wqyl%T|Rixqrs*e$lqVo(NwEDq%c^(#PIF<~pGz(oKk z_k-ncv4AF)i^M?=6$3exvnVw&2fSG27E69<N!l&8l3dVcL$vGy_VaB}{s5h-#=ykG zD8R_V$oHR(g@;K5G>FB-#KgkL^Ph!<hmnnmiIIts>mL`32qPCGA0rPF6C)p!03#nG zA2Syd4|sJI7b6do023cml`KjQgN8f2&_l^!oS^9;SOE{3Gy-KR(Ci#2TY)nOb1e%v z@v(r~^~EYFjKQD;%?jdy7U*TM)v#nU7dzFkf)?#%GZ(pmRMaqJaexjcTF6+-R>D=o zn8MTy8VF^tVPC+#kfD|%oFN6?k<Sw_WGJpe?#S1$)o^5k&WUBI@`m>mpu1>5>lHv7 zUqGE?Pz-^C88itGjd5_p5xm|DRCIxwD{vFsik^TwvphxcGzDo4fm56kDEh!X1<;u{ z;L`37DE)zJRZxOK8k6M&FQ9{#p&&boz=;8#0w6sO9*_%Q=S|*XOuNMkb}&o?JvGQO zF)#?RGcXi`D+?A8M$j?-T#O=&EKHyYNj1hQag=z?ERKiz8KsH<RS%$Q8(d`CL1(H` z7)lw6EYcZj8B;*F7RiCm(O$p^DxivlY8V%Q3RQ5m0V<>lg}`%EpjI?!MK+V4CQ}uE zULxqOnfRQ{q+-x=nkr#%tp`t2U_nimA^}h!f~PihL171)+SG(Jn;=r4VFGl2^D;3o zD1rP9TAK*EDHb$*3u-ihPU%DOF{pk-vlqqdpb-vGf(CmXl$fhPB{2i2WMlztm1~2P zaG4C?8WVJgco=wW9^6#`Eo-k~E>Zw3?OMQA!<@p9!U$THwGec;CQA)t8ADMT=wMAr zh6U_3%%DR$!GWbvXi&qvfMX#;IwMHdhM~})Pyrf%jG%Hkn85%%RjJA32dR5GZ*hXQ z6oZSsTYRW16^cLw9i+(#E(<{&5=a{be6@=vsLX^ObH<#Rmr?{uxwlxs4N33{g4Dbc z^x&0ZVqnk)1+NTfkdzU$1QU|5KqROYBE-nTB*e(Z2p$j#fbY@)yAPvb4oY3%;05)$ zz-0ww^8)C^LeP3RIdBEd1gfABtC873sRHaXkYiv80^E8A=NoX>8ccxP2p-|I0l65| z+5shqDgl&akdau7;x15Q7Va+4RvnnTK&zyYUBXlZb_vK4MXVq<f$annV2eTHs}3NG zK_-HRn^COAJ_82NYM|N967YVGg`ie3bf_eSaUm0ERsTvRKXAlovJ`<Xpf3Wu0leKD z>?CZi0S!z$Be_Nd#WkQ2FuaS!L8S;dAVAwUKoeuAi`OARu>zD!!Mz@Ai~9MQ7#Q4; zT!7kvgXBa=+ZZE0;K4$?Gr&XK*qp(`#K7Q*<O~^<fPi-xATH6Az&g$XE|@?gB}H7I zhzE@kLqY)5WGGqzs^Gy16ue#oyuJclM}S);pn|ywR7yc&4Q-ML6i7uNCxYV_i2x@l z(CEfOP!$ha1PvaAXJiAd!r<ZHVq)ZC<^bJX%)w#KA;7`OAqZQY0Ui^<7}5bHO7M^l zh(I1S1RcVFy7~h96gXr8Jc<)K{oM{avmbPAtZ!;bB51vhLPla<N=|AKxC$)>pE;0| zpO>l-;0;-e09ma8SrHZrIzZS8>404L0(e^m&@e5`ObsP{Q2nT1lCKXlMhSX?5qOI# z>~u?oqEztEIrzvOuwy{G%;AQ@rmkQk@t`gs%sj}ZbjV4epwqpIQo(0cCW4OP%q#}& zvV|N5241TLJwg;#2ZM+5Ghj!(K+XvQwJe~{N<lil6Es?hk<3AH0xk|gZAVC{4;qjG zchgrgf{SOY)83%;7lV|fMUle{u>u8TJgC$LVGtYCivwE+%3h$ZIJAr{G6E%PY#U)V zGBPm4BUvPmY7wYLg#|LWC57Qbc)<$V_yk(UlFgJa0v!})$O6yyYl0T6z+yv_8NE$~ z%~_x(LK2d*BvG6N+UEyz6^esE6#}Te4i19|P}_zvg)y7CNT7rPvW5&al>r)01MLq^ zVeMsxPQJ5%&dm--ntTVhIUP{ioX|lFMh4KXHcd9aB4Z{7hAIuee9%2Tko*DJ^^V97 zppy^E5;Jo^r$!ZR1{I~Cts0t4w>VPslJh}}v2U?~yA#ElY(-l^Wy~s&BG9l9Bx!&q z_-~0oPBzTXi-(@f0ot(*8;J%tn6yBh3JzF^pcgTqMP#X<umqV4+GoMRB*Li1$i-NN z8mh=~jS{M$W)mo6!J!ITx{$)SfB|&gIH++1Zul6bFoOmZvKZ4CG8sykn!%@z*Rqr_ zFJJ+6t08N#G+F$LL8;~a{=MM9s4}W925p1^<^NjL<B|%BK$|ggDiu<|d-GC2J7_{f z+;lB8S&O!Uf(Wq#2ENP@wq4I06c_?XK@|@=-=wG<qz&6DM>8e{hCER4fU+n96KL#( zg;9vHN)aW=VT%KlKmuhycp!mVs*t)K)C~gF@8BF?v<u`2Z0Q};5H15b0%QzmyB><= z$T0)iuIGni8W>b=psybUc@VrG5Gi3G+BBe2J^*Ah$juy#EZoo~f1Df~MIbrc)eLAM z7xrofG$c^e0jfTVnHU&gMLp<{4e$<caQy)~z8QAHRAy>1j#@)m!3DGuHopLr<`qE0 z{76*_Xt^6`#8Sal0jU;A1m6kbmzbLh8Uxe?DNurU@j$ELK#gk!TZQ~$Jy6QigKl5f zfSHC^TMWxk3bqOXi6t2@e`vrA(E&LKyj2*X2Xq1tc$gc>hT?*pOwf)g&?GL{N{|70 ziMgo=J2j&XV&RSinW12dIDa-XKM!nYN@kG`C=fvvA=nOEkV-I12VMx-!dwllMM2e) zvO;JcXw6z`3dqIqdF;&8Vzkf%xeixo>XxMz=@wLi$kdW#P}m}Z6=o-TNP)r>WTp;0 zw6pRv^T6H)3#-GHF{*2#1|gdF^*~qr#DjXr@L&V$$L4F0hf#(wKxGanTY-x&@Sr(p zi6sN5BNERDuZ=aCzzZqC>vLf}kb|Hi8MImwDd&J&ZJ=z{2g)>{91j||trA5}A@B;? zZzU_%)+R_ll9`Cy2+A~7FoQW5S%ksai0nMr37R`ofF)c|+CgMMPz*v^Y`DuY7jPAt z1)huoPn9u)+b}FOj9IKj1|^JHYzx?H7(qL5vsl5)S2^-Hz<h>yjv9sqoS<<+&~T3? zQ<bhWxZMSs%Y`*3p^c~_1yJlNB!XtAAuBCXi$LWYc;X4s%LUIqfd*S{u|e1Ff};n# zq7~dV04*Yg9n{7FGYBb^;W0N26u{uhkeLs(4W3bqi37667Zy^82rRM$wVc2agdo5s zfx>n&$Rto20JYqUKqBBp2P+wGiN=HSCiuQ8(A@`Vpx$y3o^C0~IW>%+I>QEbjba5O z=urRk%wo`~yWk6C(Tqy~ofrZ#8MG4yayJ&}@H$XsSzHMz-4rrQQgfk&YXU4x;z4Wb zz!%?xnzA4cXd?^wHbGE(7jj??=vWaY&s@+^-JrAUHBd|h7gf;SfF`8%jNO5t77%!E z4X6nOUVWyc06Nb-HANv2ygdeN63CI@L1U16V6FtOrb*08PSsJU%uLNmDON~GfFH@7 znV*-C09R400NG~?J+KsfZYrpJ0Q+7~K>>7_YC=K*%C<F7xWz+nr2w5K2s&RbPa(A; z5wx*W&#%Y^G^59Kix=h`aG>21#uBUONo)cG1H)2K!T=RI4D3Z9K1vn?B^VF}7f7JJ z6`*JbFJoc^-y6;ZYD<BNry9m)(2^y_Dm}=>hRBw~)+2*2<N#frnE>)}JSZp=G?|M) zg<jDPQ2AvG@(9Z<PPp_f7SMcIku|8D#0Cn6RP=i?!1rXY2YCV1k6>T|-SG<+Ln&85 zBWWOcQ0Y{B3{+AuWHErwu3N}hBmkPcFJY<yt<GYuVP3$T!n}~N$OtrcR>N4soWjxz zUPV;HRAdEGS;M@5EroR<Xy~z~mZgLpv>&^u0lKT3u?DmYoVA3zgl7S74J&AWb~95g zTMe5FLo8P<dks5yJyKDjOAX5czJ(wcfF{RX&~!7wbT>2Ba@4TaaK!VMuq+S&jmgz; zEMx|o;R14tCVQ0wI90l3=7H-=@ak^R(lt>1Q*5nJkY8M!nUn)M%sQtevmhr`AuqKU zbn`W+c>-BqRmGxLo{<CTBCKRA0yRk?6YyMmpg06KN;Cz*Q|q9<KuR%asTQRC0QG!| zvO$}!c|pY@ywZd0`v6_7iqwAs6@Iq_Kye6K`(GTNnFpTA<OEICg0t=|Za6cw2z;0t zxPrR{F&lPZza}R*H5563$~s370dnyz_TthcP<jG0K*^^Fd?z&MZbz^XsMbeM{O(K) z4BJ2{2efpFfrW<|GFU6X$if8LE5yMF+AIJ{Pkf-M2}U-?B9IQ0bOlPf@Qy4fpMYwR zB14d~Kt-@7GrD6zq7Zk03g%lp;PA-H2cLp|1>_cRMr17VV`5-H84m`DgE}|hj0oz# zf)0mkVE`>;0xe1cbrO3)8IU#62X>e&=%S=Ng+v9=@EWMF1f>a3o1_?aTr6nKU@oW# zPDw3JPR#>#@)YumQc@vT5hPVAz|WT}%}oN`hyhM(pv`SyV-#!^)RPj6)O8d<yHi0F z^jJzGJ##%n15l-nCTIi}gPRhcR2dJoA|Bxc4Y1*mHdeGcaYiDX0CEtdd5YrBVEA5P zT|+%1J>w)puv2st)X`<Y;v_i{s|i?4hT2J)>p*9rL)=c88xiIZaw$qO1SNP-G7M&5 zU??^MZw&x%4}nZTgOVetAI-3U6|@%~v@d=kQ!Nu@P_Kpwv;a1kL6fD*4D5DL>o*{= zs5n(2H8D8@d=!6v9%zFr(wW7ev;bEOK8Fy+Ij~#-b`GeMm(Ebb5Gw%66<}vEE@Yg@ zRLBy{0M2uo%tfFfb;tpiFF@<`AuB#_v4CbBz)BzlIB#;<fHDqfnX26fb_NE>0&#on zX%?~K6G<K+h%iZ$4N)ZC;(+zGZgFOoq!xj<vfpA&&PdFJ9&W)5nUiG(O?&FY3Kb+L zawFOH3RHT4>No}#0Y(wVDs3b=q}+vY6q0;MQ7mXSh7oiu254D|CR0%zsQVv^#ZECK zeMsis23Zd(0U7u?IEunS#TO{8fJXa37&Kr38tqaBrJE_>bko7u%-G3T!U&>^OhEIp z9gHO`9gHQcpr(2UBY3)jDTN7A{emx&;Q*<vWo~C^XG~)PFDm7zVFsnDT9y({P(=)y z#dTqbHL7KUnNq_BTJ%uD)xlW9*1^!sT+30z0a{D|u8=uvIKh=^Q(+9qd`-40GXkv_ z&~2Uy@b)EaP@uBtE-1L1nHU&Q@ArhIPw-l0Q1ht<w0elKgrS46h7shPA|~j)&`gNl z9pfz?P|X{kmY7_UUsS0HNu)(gpo6oRiokUqxb_3rC7`5Q1X`KQ#=*c)42pjiCMHIn ze^v6}ss-9=M8vuc=*;bkf+9Oj?puQKpk<|rIhj?dkmG?<ZV7-E9F#(P;Gl{cT)!8& zff53!!-q({;HkV@Jm4#gKp6$J4gwVIMG>Gz92a`U_ZQSm0Nn{ul3J9Sa!U|YM}u2{ z@t}FW%+zAA|88-B?&<)^-C~D&AL)MPNRTT)9){MNP|tk@B|UH*&cwk4J{X#j??2Oj z4ptT>4ptr}rhjbgkgb29spq0Z^rQ(Y&OiwlT(g4C^93zw1P!v5fSS0>S<Ij<Sk2&> zQ_zfRFhdPfu|WxI4P!H7kwFO?nC}E`H!>|`EOIJg2Q6)E22D3JS6PC~F6eYWXytx! z2`pN{BTJBu1vnhQoeEG`KyE70WctMks*1qvuOb)F_$`DFTBf4O327hsgHjzR&Wl_@ zEo5m>vVnEHisQj;GEl<@GzU=xZjPmZVnF~j&6HD?3W{FP5MA~ycE5a3ccoa971FK( zB{fJw1D$Dmi#@YA9%K%r<Uu4mP)v)0k{u{c7+5$M1(=!svoSOMXJTZ7(j5QUm{@*- z(*&sP4Jr!Y7?e3c^FPH}80&f=`yf+Uv)GE{Qdy$d!Fin_iUYEMyeJhE9KqnQ1=aFN z`T02-P%mgeM`w`EX#gn!rBH+t4RzSfGqAy&Xh^M$Qn`Q{b|4H+7@!maZrr^Eg*iA3 zu&qqwh>r)kCO%#d6fPhiGJuX|fdsD}OcJGw1yTgUU~52SB;){~U<PnIQj_r(3#f8{ zjusTfgYp2_dN2VBdC+a;pu_3o<BhRf3X$~F<it9_lMXTw<h`OTp!Krc@$q^2c~z-J z`SI~ZnIJi^MF;|9B{&AuK(>Jkc19L<4kk867ACMbN+5zN0gxK7??8v~Rq;TUH!p;p zlg(7ZoW@kC1X<4z$&eSo!cf8jK6npw6tD$o{03B*m#}8Bm#}7Wq%oH<6oiy;g63~h zn3|bWn6sHcgZsrX(8KtcK*t2<aixH1@L_!5T|QNw;Pm2H0$M>;0ve70r3nS(*)veN z1G(D+wE7ElEs#QSelF+|g5=Z!&<bMM9t4i^%slX9h+if*EIDX$LCVHQpg`mgNG;0E zEH2K>&jYXPx+Ub7U*hPJ3B4c_BF63?3}JxQY31eLVt4iP4{`Afy2a+|=<Mtoe2dN1 z&)?NA1ia-CdJ7f!OxjzVndy1?;48V%vt$et1A{pzUO-(01{TnHe&B^zEMiQ2;L{K! z7>ht^P~r#_`Jhq+ltYU_Hw3`u#1=9_TT;xRV}XjSN?1xjQ%ejB89{55vzdzYK($s0 z8)&4hnW>g3j{~&G8$3L~kj1!w1Ei~#8GJMlBWMFf33m!pFAJ#31?kgd_5&~D)MUKH zRRB8MBqcR3ITiUNi6Zc-Iq*(j&|2;yP}qV;8NtK-MfX8r59)swd4bX?=t^)+7VvD; zEf(;0aZuL~T(6)96DR}vfPx7$r4L&A&ci4KTA#)QI>n2Hk>h_6NCiqDff6z(cY*^6 zR82reLi%+;>)yeOf<ebIGcE)#?JnZ00S_7!@`W>`Fv7NZfoJNhkZ0;ZC5k3fl_5B3 zLYf|+L+?{TyATyXXPy;91{^_MH`sm>uv$M&$iCWJtl)+4u+#ybU1I@hMDy`2{=EFW zc(A#kB0se_8svLW#$*65;RRKjMHQf`5me&AifB;60Qnn)iy_yKb%2IR7~A1n+d$iF z!4VFsESZ{_ARBB`m_fUiHCd_>!LEh%L_rx0l=Bkv6u@;Gs4fF_MvL=v%2H8B2EqCY zic*U~9fHg}P*+u<C^ap$2$V)Z*Qu9eK*ldnA_-KEf>JWLy#;C#)G)-#K+`Z2I8`%u zFf3#Qox%u8g@s71E*41kMGVw}(jK(!b&I(uH4QQ`4K4@4MIflrl>-VzP$;o5G5xPn zMz2`0G`qm@qR9dd>mra-!Gl$|Sn^UUN??gs0O3*aM0W8lKB&nlP(C-PrjG|-)mIEQ z5#l(oyHc1K7}7xQ0*%u$uyQbRfto-pT#Q8^nOj_-={nGOQECzBd^qrwOmRVCa%wzu zkhEBn@s==>FlaUgbaOo@N5B#WXuKPIr#ZM-2U&zRAUul+c|aJ{i$k#kJRF>onw*nZ zlnOrCA1tc?vkEf9M&m(XERI4Q0?x_I23@(7S&Y0kBqcQs;b2&hX~0HaK_kW`8Q>;u zr4IBwa?tc1jE!_+6R7vA3_pe*JirXm2g)F&#i`)-VRA-h4k)pM=Lw->;~?`O!3B#j z@S<hVKq+|mIyD8hrWEEXh5RJYJe)!X=z<!^b~AAHN=z?G1zoWPy236Kbgon$blD6v zx8<akCFVg6ss#^ELq^X_GE(7p^nok|8wI_pED^p_Co>If2;`h?g?MnfjgLoMBMrM| z7gYZyf{vnsT%40ySejXum;=i6#idE0@<LBR!3|}=8xj0a*B0q06sJP2Qo|fM&q<BX zD~82WLIR}B@GGhZbyAp$>_E+CL5!3D$x?`{K9PZep%#>-K;;Vqe-Vg}k{v)50|<k& z1L)`*&{^f6Vi9yCUMWM72&kYhVFc|0?pI-CC}CW{3|f=`Iz$k(#{{%q6QiPVL#`-5 zt29d)iekX#fIG<Gx|OAdC55q+p=e48Xo)hzLPi#bS{6`isfNLZA)Ntqjd}?;Xk?p_ zAy1@)r-lVoFc+^V;RW5f+RW6%Si)DrUjr((S!-Bpz}vBESejWtBi1R5rHn=IYFM(s z<JJoVYS=()L~EEA2!d>8WGE4;VFz8*4m$s#2DGn}waV2sueh`blxGr4z_A2Rx(bl% zi&Kjg5Gf=-4U*_V!?p?<nQ7qbfKyX6{cf>=n>VSTb}c9c#K-^Q^UE&*&%%H+f|aH) zWYPe%pyC!^a$-qx26)i}=pepZJjf^U-Qos!gCWVV2(&i6XbWhj0kmB47At5zsrVL` zFZkYo5YXujEuaL!2Re5LwD&1BuOvRN7;^N|OOQ73EJXvTu>o4cdW##h9TKz;wKOO7 zmSB8QDtLn~NC2GPH92l^LyI&}riJvaKyw+8mHVIr=Wnq?GjS1U*cRM&K}&qMxS**w zKCieRlm<cdFatBFN6W&@#mL2|0q*mHmd%SWvN3{0K$wq_1IpuJESdnS*g=&zto(-c zc|l^upo^6tqsgEe5;UCB$<)r2#t0fyZsF);gbufWwpMb~GJ|GHYM4{ldzorkQaDnW zS{OikqCov)(9ZTOmJ-%xrlN!zmKvrkmK4qu&Q>NHhCDV9Kb|FpGnhe>tEv!OWCTG% z3tCF*!HWp+rC6Yw%)oPFpu-+Oy<*VKf1t_&JU*S80yZHzzo;m+xF8=gat*$QJ~gul zF+2lS3sH&OssUwUP@N4PGz2vO!Gnf8pk@N7Q;#%YxRS9biiv>%x-t9~Bl;$xq5via zhRqzX!9i7w6oAwK0QEM&gNY~&7LdC@1&1(bTnuz{Nfl2A_%wWY_lU7l4bn9#0i6Yd zScVPSQ@~uM5B46YE(y;s%1$iGFU?B<*Br{GMh4&^1!Yr1V@Rn7Qgw?tGcV0gllc}a zXqLAEeEixi*0h}b#1c(La8p^6@fJsMWidDbLy{t>RdGugJkSG^fNXTx3QCS3*F!oQ zJd9O(ctQY+0VqKMiV{$|1P6r;c#aOSwG_0YA2g(#!UWzs$(X`i!^F)1TGL+33>r2B zEtZ4q)N5u0tzpt+sS1Jz4RrhkG-C@sS2QsPG#vusf{GW!Sze&)b3munfx3F2X%W~s zAKaiKS5P4U+HVOuA_}w$3DRf;Ep5NWnw(#nR{~Bj;IT1SYmN(K38*wFDZa%6DTpAv zBG8boCetk*Xc+-+a}~`1l`inA=avY}L7)k<VrabVLj*hzcy6jnA5XwzGeMKF$QpF= z2`K%+3I*cxMbSi%BPW3fuuH)ND4BpW#0gl200k1b$OSj5!$8V6f&vg!$by%SYqH+r z%rDAJha|Q+AO)a8v1l%+6z0fFEr&>ejMro?0?UJgXF5nF*uGvS28MN@&;Tu#VPF+t z;^E}u<YD9kZ9rlw0?DGJF;MyfC0KAh4La!?G!_9``BAl_hM|P1jG;&&oB?z+07wj6 z*Rp_bEoWH32CA=Pm}{A8LCXi3iW*ATLFagYYVZ=KGRC5y67WH|j0{x*B`jH-pe;vP zT(ykh40$pv3?<x^b<j-A14_A|nisMst%PX-Zw*sHR|;b~!$PJ7e9*cTB+391VPpVx zuwwaYSxWf9wJj4PL*X)n8}qnet~G$H#bBwjbb+?3!R043Z7HZj8K8<t9kj<N5nMw< z8j>(MNcwICwT%RBvBYQQ7Tn@VOfD?VEJ}^f$xqHMY6L|L5A+;Jh!8x2Z*diYrcp9M zxu+-*6wlj01h~2d$G9#i*1*-M0I1^*szJdulO}6XA4m$EN(?|O(A8Ry+7cA?h*Ah_ z>;+JCgN6)2l^|#f2$Lkoa~38xMgh=1Ge%Iw$iyhX$ipbWBE|?hCWen0tPiEZ1}bde z3BeCM9|1bnijkqptb}O+GiY#WA!t*LOf6FhOATmo0C=TCkr?P&B~XKjk)cow91U!s zqymlxFw1}eJTcE)<$~N8Dkw@V%giq=&Z*Re_Igq<gC8_`pPW;gl8R^-fxQko$zuU1 zSQdf^P!tq_nlIq6E1C=n<3*qtV}XPiC;)G<Lt_-usz3`wkd{xNKm-+FpcNCK-~yc@ z&Bp{bE*TU!utEW}V;a;=1?L#h8Y@s60d$B4=<X><i7d$g+M8O!0-b<i&SG_8h!v@2 zD`BZ&Yi6ur&1Nc6V`M0FC{(Lq31$FKw6Ih;Ip^mVl$NA|Zs5u*)`hwk-hBWqicf?r z`Kko%c~r<R0<F0MkAuLvHIUT0h5>ZH9n!QKxbQ6k`3+JQw}1kN9cexSoY=tS45-a@ ziwiypl2RlEN|>m@b&DTlDN-lmA1LTRU0w!e3GiM;9!56iqGg~a7IMIW*r3uC9B?2G zXvhn)v=(H6CJR;<fuz8ZUIZ%MZt>@p=HwvREyM}Gy0d6G$VQM2u&4sD;b|JQrwI~O zV3HY3vVaa4Xl7gphQSP)j8%qy`9-<l86eOxubDZi`YD-3;G_v|MSvPCiA9;k`FRQj zr9}n##i^j>-{6IApxg>MmjrZ6-YpK$K2cCjSM(b+0LmMmT$x^;nFlJslQUK_f^SEI zcns`Cknf7>85kHO;XYyl^HGXxkdHu3RB#wVHYH_&R>?CJiGk(|AzdfX#WTSSnoNnH zBiF!HwR3(R<l@Pae1!o2V9y8zBLf2q9fkZn1!u6UbU+7tCzq!vXc%jPM}QME^NPV* ziz{<MgHnje=wdyEP|zi^U|HBY+{7gC;Sm~|3g!7l*`Py)!R;>aR?VEu+{}_hP$8(N z;HZ$6SpjNE<QMCur<Np_r$A54E(c$@TTqmrln7d#layLgl3Jt#QVDUOLTXuRo&xC3 zY=z={*qKdWCx8oeutmkGskz{*!jn=#_q?a17H6jC!43z$#Rds~O;$*!#~V~kAmWW3 z>Vu-ypdtkvBVYm?EvuLq806s5!chd`qZFQ?D1j$5&?5UPF3<?DBy4vgL!|+<wqpeK zJy{q)vNqs>QRH2O;LM=O1ldghN(-9IkYoZ{par_#26QDOdYS>X$2CEY1CL#T_7Q_h zdPqARciI7!2A~aO;3ZekjUH9z-~e?=Edh<y=cR&1P0}+#;SNg13W)^;sfk6f08Y#U zEk}m5qkpl01}`<4Aaih_nK#Jj8#n~P1UMK$6K;kemx9_=3@qRYI1CqpidS&zhU8aJ zaOKN^8?(${lBI?L)HPcOJ~2a+8M@qyXg9-VauJS)%v6K+gJ`mXodjvYf^u^ac-t^& zofcOAL^ClkSb+Qkst!QoiemqYKw>C<0u^+iMi$slutq$nngETGgKAjNX-h>GDWHA2 zpxu_tCEyLKHO!I>HB8_ocMOu?BPBtlC1{(eD`=Sp8>Bb~Z5aiZ?zh;BQ%e#{N{S$f z8`Q+mWPvmyKy7O9s)-^{MTnkyx|tXloIrknq#noy3NFSXkT{AzKuH|r7w~95=!{&@ zXg?@Mnwg3$AP0oFFvKc=eFfT)!&t*uBmz3`2ISXb5$L48NS<5`g9}5fL@iSZ8>qPm zUUk3-mGvmJfwmPa(T4u@L6ZQ<`MKbo1fbD;@O8L}u#0r_ixi4e3rj&G;lCJ_LCphj zvl`^yqUWF)UM}#$60pXiGEfc&p9llGg-Mh77E5tSQSmLt;#*9`(6M7gnguEG0)-E_ zIn4x`Fy~<6W8?zQi-50js^W<$*Vc&9iz(OE)KaOM2F^no_5n7aK{UJQINexnO$80G zD5$@w3z8~JEy9!m%NA6E<iRWTv8w>90;|bMEV0wmhAayMiGr}EJ=`KF6H0-i4OT6J zX;9dJ=bGEl=bEL!bIXiTEGcZ@t%j`7({|ZXq`@afF-EaN&WnoTNRa`b7sVLGnaZ_* zJ4J9IV-)B#DcKaE6yX*|(0Nj+yeT3nqAj4i6ZunlQ{+;_QpCYB0;#+y@+lH2l3<=7 zxDljKlnYw(ZtM>koh<^Ld=8rK0F8ZsE{0Ai1D#t`3>wb`FOUSUONI>Pg44Ah=-f)M z??417SAtS4Jm-}#fKptsPzhrSBdEpN#0V;e<H3gr#WR<%fUXAxpXv;5xPi`=s$s2R zh-Zi9yeeT&$a(9~0UB_lK$GJZo3Fo1sE;dn<N%z};Fl?aQot=%@X=qlSV6h7xJU=o zo&qhxgdI2o-UGHBlq7e82)I1hLl6R7c!G8vWPuVQsN@E11mgm)eg}<gRSCQ1l@wJ5 z<Y(rUz!$%xWL{8#3onE~Q*|kzs|7)a05F2iPJ-;1FVX@X<&eS*y0tlrX(6LHgE?d` zJxh^G4I?N~fMr+~GKxWDKsTnc`Bky27Ax2)s22ZXv;sFkt5_AHRf}VPG3sctg2ST- z;XQC!3i2at_I?Y<)8Om|Ccs`@4I26Zc@^BI1fNe08psm?9TAG`(c+S#_;?h5qBM^{ zx>FcI#Z)t+7z3z5<X0tv6jGpDQd2cli!@g<LhgdbvV5UvHUk4gHOMWXAY@=f3u;gb zjgJpOX$ycd7AUO!LB0ST09(UY#8bmm%u~Z$Bm-)6rZAR(7XX4Tf~jFFG5~F9tYOMz zs9|2h*ax~shhYKBLXdk|syyJiIS4clPz34-fd_m+i{^_Iz^xvHk90s240+&#twFPg znI(|g8B{J*c?BdECFX)^c5np_8m0wLlB9t0SaM=XYKoqMf-`7rQ4cz^1|BQZ1MSVt zEJ}r)W|^8(saFKLtGMVQXnh=O5oo}<2y{_F5oirt5oiRl2($tKw#5-F;0P*$*|N(M zi_$R)SkP&Bb)WzSEkp#Jx5vWB1Ue4o4;vc`qX1(SKf-_Dv-VKp8<f346&E;*!zv|E zgE*ZLw8XNPxt6g?2-JNoVX0xr0v&6@3_UM`tulm>p_Yk}p-Q5J9Wqh@y0iy;c_B+J zQyo(tR|=R$S});(6dRBUTF{6YXe_o;p#YTmAXC$zK{Lpx7B~pO`5qAykQFDOgbLb9 z3R;l_8V9|_ngiM@2U?K=9wPwdm|L7_rFqFEpzC}<ZNHS#<kTYY9j@Sl0z7uW1}aTJ z_n5;rJ%KxMJ3*r0>;xvjc?uLKy`W$Q1s4Mg=+HJH(Cw{4NWlw@c$D?rpp*<MNWmct z%DteC$wgwILu87@Km)Kf44|<a5FcDRFo0%mz|9uWZX?ja5e%Re4z(;LY$fa^ELj{i zEX_>KjL=P`%zjmBkZT~I=?v6?$SlbK-Sz-k90pswrO5~`IyE`LR1v5IEh+>x;Uz$x zO#-n%UIY)KL1vM8APE$7L}HNvNRc6k-~$neqeKw_1WKsW;Q_?R!^p+X2U<0X8bIKY zpQ_lHVl7Y=3@YF4^tA0YV~VwGp<<Ajw~LM`*NfE#NoZI>Wk3l5Ca!4@6$CA0O)R#H ziPqDKi3N+QpoBlDR{;-y&`K0g_(SfK1Z^}amP=s-9pO{MQo{(22WHUy*R`P2*g$vR zfzQFJWvgLLVU}bl@`BI{K)3NR<}szPg3i9GVNGF^WB}chC&^I5UIS{Bu?90}awLi{ zGB7|EBPS|=`g=L43K&TpwA3OmT_K^kC^-Q#MGY!!z)1?4BZ|TIfh(lt=j4EH1p;Ll z&{?_26UZPfppaCsRRAq6(u0Jc6_^bQGlghyAQ^&seI-SSMzIK+LNZ{E0viB6RRBD7 z1+JUH1spVCr9hT3f$UF6umTxdoR9#@pYS}LkN~l#I5r_c0W@w0>cyri<b&5aCFa1@ zRat`l2d-@ua!ZR#6p~Uw{Zw_36KtW52U`GjcyX*cXy_m}u>_oUZ?S+R!8IkMdIz@v zKp9t)4Kz#z>iFgrd4f_js0z8o30~BYl9^m`ix)IZUYrU!%dWTx)DqC-C<68JZ!s4a zB|~yWAV_B~Xvl%NC>7e^0GAlxv<@b~B?4%<_gYYb2e)jwK?lZwt~~{9@{nSz5<qxT z4_r~A)N!D47gW!IO9jy37d4E<9N^Jm&<-A^8b)zYIlxrIl*Lq}RKncM(8LIu{R(CP zt#AT4;TB_sCTmd+$f+QA++r;*NKGz=G@-!F1IWq0x46MkUmOpTE}9Qg4$=(?H?S{` zGBGe51o;9~+k*~=2W?bgV`O8jl0fnSO1NQ+=7GvMuusCk!=9iiFK8nXoToBDGsvL3 zCqX-$jKFz|xdwCwB6uHD77O?sL^sfVm^F+wY*{SL%uS3np!q$vEEXGvLOIYFpC)sa z6f`sCp=2X)<W>oJLR*$#E;#X4iMo^)<Ya=XW@HVTtVP>EO(sy%0Czu%K;Z{&W@)m6 zlR^<_@b(rfq^|=iCvUNU+6hJFppj~(RP-4;(1dJJaVli#%qdVvf-7QX&^8~?@t!=4 zT%Z%l7^}pP!V{b#AX-pLD^N)V!r;&>fre%YV>1)DE6B8vp_Va^ql6h0!nKT<p!-BY zVd@pbRLfG!3Z1!ks$ng*DpV<9fgJi!!?J)CboOKoOAT`wLs3i#OA0fn4rv0NH3<r3 z)*7aTpz{zxVXXo_-hrh`5gOJCxrqg!nJwgk3mnA7epRYq|3HeVVt7UdRmPzHMV<mg zU6lwT8o(mp$kAjk+6YRF>L3DKn^b~W;79>?FVBI7SlPhwaf=1K+87cOxrqhE;0P)@ z4T?q7#0=Wz2a1Z^#DeRfhyW#U2GEQ)d_Eg=A2Db+9~3zvpk1$s<}f5mauW+QnIYK& zWVW9sV~8e`pPwcp3<*KnAE2Ef==ZpQn%&^`F66*baCHi*6^mwr>dZqR;xNe3;PbM< zsScF+ia=g1x(Jd0*@&<kJYEa#(4~Vs16q3q+Gxwg$-%+F%*D^a#l_3Q$n>9ulZlZ> zn2C{#gNc!chlvra1ErA%YI(!6DCEpDSYZR+(gG@K7(rbZNe1XvMJrG<djU%gV+unG z6KF~lbo=5$M(DUGs~>nfANahkDwf<7Q(H|&u!tsW5y&2Jj=IHBT9gA0Q}FS*x424+ zazJB8Ma8L_Ohs~_;uUnMS8-|znvZXZ#22OJ=9i_$=cbs(rxhipgT^dggMt8DL@|Qy zY68tsN-!2(MIW#R<sDGj3eG>E-Z^Nf3%aKbG;#>KauTwvkP)<Q1=Ipqzzn+eHio&D z1(b(MSZY{7`K6h$z%B(;kF!;^fNL)3g2Oz}vL*03Sx~kBml2RgYa(K!IcRhrv<4A$ zKsQ(~sL}*qo(<9i;)JCZffn*Aq=B~f>VSp`q3aTLK(i8{JKhxXOEOZ6$}@{oAuV5& z2n98MLB0efu3}InR>QD>0eK+OuZjb@3(g8Qs0bRb(PRV{V(0<RpIHpwGzaq0Pf%Ec z5)A`r&kxif$l8C9*AOcZ(DZ@RK+!JHmK9C5BG5QwQ57gzXMhS$PEd;gGLu&d%Ict8 zuE_?;#n(UzcwrWSoKOsLD0tRx2PoqpvIZzq-x7j57}Nm(Zxj6jay7Vd&dR|ADslxF zi*AC_2WTh*8G{@K;up_iWMDu&!UKG{2y+T^3UexJ3Uex38f2RQV-$NTM@lewI0rN+ z!wDVG;Y#IB0biih%oxQ3JwJ*!g)fD_g&~SBMIc46g&~R`Je0!_B>)-5i4p`4;4nl9 zfroAwqJ&eqQ>0R)!2>)ZsoW_tDY9U;Xo_5ld<#RASSojlLW&|-Ogxo4MJYuY%$7)% zOi@Wu1+%46)Kb)27^0+8LQ*tSv|1RWWKy(KbXpjqWK(og^ja9A<Wlrg3|bhX<WoXZ zj8cqS7^4(YOj1l+7@`zY%u>u-7^0L?EK)367^0L@tWvC77@}0#K?`ziQfyl|qEu7W zQq@!Jnwcgr7Mnz?rgEf&rP!x9fCrv5QXEs9S{R}<Q=C&=S{S0VQo>VQQ`}k@qqI}p zQ#@K2qI6OsQan?<S{S2rQ@m4rS{S1AQhZbVS{S1AQ~Xl`S{R}XQn^zCQ-Z*LF>GgG zVTdvcX3&fTZxpIB4KGS80L|$oCW9|U%P&$W$S+CFE6GgEK`hLHR8ZympiL#<>H;(# z?UxK{{e$8fgh6ajss@)0pe}d`Lk)8QM+##z=tK<08kQ7>QpO^M5+=~BV+}(*sExu9 z&r-t%8qxv}bg_Zfr^U0^FcsL9aMUowb3zBUZn1~vW#{FW=V@{kfhz4HJy4PbCG%Sx zu!LF^3K9cPnt%$wq7qQf=mz!cIpbkRL1=P-PtF9Fj*xBBV1q!rypXhmb)x16@R9AT zTnr4w;I=3WXsH%tcnjQ;69sL>fpr8C16-g6C@5e+7<7m$C}V&eSX{@zz>va_&X~d| z!Vtp(Is~|uy_Tbd0bE-!fzLf<s^zTV1a*~4K!;ezm9Ri~k_@#BC9I%P!dk8xuA;aa zF3>Uu(6X--)`ctxvp^e+YnaoRYFKMPfy$A>HixB#1vGrKfE_$^!|n&Z5)#}lyTx3V zT6BvQJf>R&Iw4+@1roxj0i(%*H1QA!3SRJ5BSDn2C_pz?-vZqq7w_lj>k4j3+~SWf zN(GJQz@kc%8{F=IL<4w70C?3uXn_DWdy7Iqc7gjFXt4s?Lm&i-70_AK3`|1cH3U51 z#t3Lf01q=0Bg=m#P=)r7g^B53l@v-mflD^nCUuPRA5;f`Q!*$PYY1Pk^N@*wK^f#0 zP!?cdtdc>o3oQgNYy;J+VB5fb70`+E3|XKNP^J>*8ip(uP!7ssEsz0^in0}`q%fwj z1v3=A1C1cC-{J!|15#kY3rYH*wL;+f8xqWj+<|QnF@}+WK@H@1P-Vx!3~B*@cGhz+ za{Q_iLGegNVsS=tZUKe|K)wch08~SOhBULli@Kl_hPPNi`iel-6k)L+v}_clAU@s@ z<Oq;i42)IixeB5JrJDy*3Bq8TL9G|i-~;H0m~2>ttz-n-3cW+1C>2ylpr)c*Z1M3q zCGqhlNLCA@_!%Nkq{WP|L-C%1QtdMkfyKVm_;_=C_NB(h6KNl4r?f1n!pCP{dP#h| z6(0LQ@<iIlN{s)~Q{&@p@!5yXf1nl@I3htU5YTFD(3o8_Q?UT3-(CYgLo|yin<<!~ z2(+P3lNr*(nGW(hIAP%k>(s*dcn6SMKzWRTk%x(eu?jtYL27XOAC#m)1!^`E4=h<h zns_*D%u9`rcLUi7N}8Y{d9>67l1IrvAa$VH6YP5v&<qpm$-#P%xp`0+fT{!*(6u6< znGeL$Qkc6mS#Gh!XQx&cfk$7#wHv6AE=s{n_u$opz946U{KvoqT9*Yn1H4KA#ktw3 zl_+inm5b;x#Q@rGTP#)rF0nvmRXnKF0-bHa<adi7GPVIPo;0Bs<AU~;L-zH*17#8{ z#X`{|CI*I3kPE?4#{@cIyh<9yb*LpDibFx=HmJr02P)|D2vGf+#Z=1(DN;ehk>E{; zGN48VD5({zfmkK13)nz2!k~I`0S9Q1ej#Xw6z2l28s;o+@Ck%GpgDg~U0T8mIy@hw zOOwSf(T<UU0o)w{jTeHjdUZijK4=>Uc$sLef<`s830|uSUeA}53Ys^BctHWQ(L*68 zH9ax85^|&{$OI71%g<8?a1Br}F)=`ufEuQ!5Sd@9kegVk09rS%ke`yGkd&H{Se6Oi zf{~(747$$-ysjG3(*c<Y!k&5HLB!1DQqXl|nI#Ia6G}lEKqn{_D}ZiN1RblCr(mFG zpr_yoIiVD!8H6*7LD!pur@T`@ds6Zhax>G55=&A++hL$C2CvEi-5Hhx+3f++2f|Rd zLw9F_L_oM`FDRLU7I|v&A)Wi62+HE%;S6v}DFi73Z9{}il!FevM4IIRo!xkgr7W?i zxJVSV5P=2U<h#Y>6LyO;vp60S!jSVC(aL4$Nth57u*x(Bl>9&|&OtMp;2}s3(5_iN zc9x$koK=b_i4nY^0crzGKSq*-=X1~jqG%_C2f^|=Xx9m7p#u2ebT8221yCzsA!995 z3gm(w7SPpJwag`Kkee|<6UE5ubTpa#s!V)AyIJ$n71W`<VJmfoj8xD?nV?Z+{rn<@ z>RRw}J=iWqD~0M>P4=SOpxg*5K5p@Vug8E!)h#(N57zz%trE+KPs=X?wf+in5-V?U z1bDm0gDwp&0!0CMq!c#C25v`!*Q<breIaEhIPgIwJ-7@g0|hf^%m-Eufd-Lyn3(=E zF|qw)Vdi2&Ylc7_g%Y};k_jHVpo31(LRSkBx}XqU2-;Q15D&eJ0@QE_1}(3vgJ)q! z_~2YcNl_vwQG+JVK;v(qVFnGzNfMe0(D8fFAPQtb8Ym@$7DIvtHBoj*f>w)xR*Qmi zJ!q5yv{Fz3JbsMGnVKxO#Nv@tReXF(YC(K%Vga~Fzr_dYi<hJpL5J9H@x?<nu)q{y zDMoK`z>H`Gg)+FbXM>dXVi>I~s5vMB3o1oH<4)j`v<N(C3SObW0GcRsVTg?bCDmHc zDgI2L14(O{YoME@z>BXz1E;L{E}(&*X2t@S64n~lW=0+c(1xWVzjOw0B4%o4EQm;9 z1e?KL!vtDJy?_IBi4P+~As?vmt;t-q1RgQap(0T96oA4qKMfL!;ECgu)PmGJ(6;2v zRPY6fMVX)h)-<^0)V#9HqWnBibSdN}7G<XvK`!}9%gh0tga@A3%L5$^i!cVR7j(-= zE@<l#$W~AcLJdGfpC5R5Mw1gV%?Ap&BJdKZ>!3_k11iUAK|~dZ5CD~9po<DL*>5qW z<Q92>#_TvjOX$IAq6j<_2p*yF0m<;BC1&On$3v_{&qLpt7#JpkVi&aJl7U@_5j0Z* z+D6X7$nlSf1=OJDVG?0Pt36TE5=xwd;u}=!g5w-C&<DD<0DOCc5$J+m(AoB&`x}}; z!{c%>pe6P!HJ}w@%;2~KtyN(Gty*PdD3mJXr~xg+0N>=m1I;bq8yl*)A&~{<XtEZ8 zhNy4xq7*Yl@IWdm29@TJ+Xsq%fr1k}Ed>fRNJxPT6fglURemrrFf0d!2sphng1R$e zj8YgOfSP+i+ELnppkM%<L<bHA&`}(qa-x<Alx%C5L04ETU;>SRE@T4lv;zf(T`fzM z7(}iFG!MWCy6K0JA)KL50enhA45Sn)VNGEM?G6B~ZUN2fM=}&D7%&tnK<5V>d@_qm zK*bDnSp_J$7DKn&f#&KUD=R=-ii`3=!<z}<BvYIKo>43<PEGLxr;sXn)nf1-(!6|y z;?m>{NIp?WOHC{(ElO2TEz)Ew`Uwh4P%?xpQ3oeY@M+PY*=yLb$Dk=MaH!v6Nl7gz zhIGk6p#`=EGLjCO=w1g3aqvL~pu;5?g%~*)nHa?wc|fZ^|MM`T_32=V0VT*mjZ1hj z4jL1v5{bV`{ioFPvHbZJnf3M3#S!J8-y7-~SftC%ovYyo9c@aj;=W-|rIdQn(4 z2Ce|X1H_52qqGs3xk@NH8NBKjl<!kgOHz|dVl|nI?tlVpBPjD$gNRKa0xc-MFflOf z0R;s(@v$(m2(a)laxhhCBbV%YC@CGILd6IaP{4pz$rXcUDnKLBpu)CD0h|>X!KWK? zff}^nUGgHJMk%!OT?9V#?;|MtKrcf9=N!;<8zlC?jt6I&zf24aXF=`;Wqr`y7krFp zgC;0$Mkz5s&I4g^RsmJzU?+kPX|DxM2{1x7*Fw9Gn#@HY%Zk2&0uwZh3|k-qo^}E^ z7{JZ~6JWP}W@2Etgm4=;JS8#16WTIxLz(si^#wo}>^9IODrmPzDMJw-s80Y{Tvo$a z13tM5w0#F8TFOuq1nDV&7K4B;l>;3z2|hJ~xdya0pRJ6c$f|@Lv?h;{q0kD{N!4Vj zvV-m+0cXw3q*BnTa?su#$PNg|dcZsd@M)R}3K}V?X^EvdCAP3_YnpyVGK>rizr;XO z_27*@@z8A+kTQ}3vU(QWl#&IdJJ7}u$N&#GG(pR1!8>PQEibT2Pz(7Mb3t}GT6Evy zNK7utEK4j&y#WeW@X#g`Xb&nMcuy*bM9Z)+^(YY!>b=4P7qp%XvZf6*00bTgVgmID zvzQB{N?6jE#X$X5hAh@16VQYhXw4IJ6(6XIV6Jk2Zu~0;ZE(kEK&cliKrV(TN&%ln z0nWXkpi(H#0B6*s)G993VqMi@-GWNhV({T}nrubYpxPGP7Y3&*@K9JbDD*&sv9NW1 z6F~yt)CMNNNe*<O-(yhFfQQAHK$~tj{;{#Lfz~CVj!uD&q6RqxC15}eQh1I4triEB zW1x-YHK2u!44|Svm;uyj25o-?Wmr(N9kf_cL$z2FI*EsW;om!u;~;sJjggNDEw<u8 zNBS3`tw03D7QA=`O;%P3fMO|yF@>R-8NB;Vj0JRC5p)Y{3PUX;WZzp2V}Ty%gdR}6 zmBmy8UY7|v8qg2ifUgpaE`^NI!;YYgtzuOz2HpM1Tm)Ve2A+Ec#R4qE!I1$DY%n1M ziY3q#?-!7#ctC^ZjGzz)&F_N_P)5z_@sPEZAm4ygf-r~;4{ng*pi{v>UHKxR5=PLB zeiNt|V#or`?n5dIN0(GkZx6JkDJMsvG_NQ%IX^uQbj`6sL1|J>X0ifkB@8GRr-Iv- zdhlukHlt7kYM*JcfTv)=4RnZKK~)6In}<Lp9N33o0_4qG-0`4t6l8dO{2!2a!Ep$_ z9iU1A&7<j%b@OP^2ufQZO&||L&v^kIeg-PBnwdb$Gn*MfZFKNvZ-y*ZkO*j-cr&9D z11Pm=GGm^42g<{sMpiM%i8Y}8V2t1pWLU^pj5za-F&MPD8su$1O-8W4p(m~sVex1Y z=)@IPZrCw*;8sADI+_PlGK=El5tE*X<L=lXt!NEU>zB2-v>>$zJY#i>Jw6_+2T~J* zdpsHN+zWDi5i2tT0~5$vaK;5EBMwH6|7`!6{-bpyVMc*;U{o2P)*q;hC<e_hfHE&6 z9YHrTF)n1RVM=4pgszK)Rcx$~qm4kjUXbQXK+_zWERcB*a8ZMp@&G3bFadTu=-@tn zklVp+2PPIqq5rrhFF>=!7^MzMHURDC0A=qi@Wqr_EX_<sO5jNZ(6zPTEL_W&Cy)YK z28kq60zP;hv>ri|xyl||Bqu5)Bp|g$6B0lpLnR8}{tzg8WMmej^maj~T_>01R93O6 z7TemY7K4^y+kzOH9FUP)(C8l0D33fS|AWd0#HuT37P`d(UR?zaA}|3CCo4t<1~E`L zfl4z5CILnvCIKe24o+fmJhY7oYCvPeFDS)>n*^W(8o<pJ(4}<XZKL2bI@F+RrkK*0 z(ikBZ9@j8~#%4h4#Hwte0Rw7bCV-+L0eKx1sPUcvUXYUjT60j8m|2{v06Fm-e1w=E zbp01(eUE}_kpifd2|j6Dles7o6d2&ev!Lb2u-Y87a0)zQS9BJ$P$>#$U|^6(1PJJO z2_eQRS(Mxco`wU@<;H^-1Y<NZL4gSl5|CY0psPq3YC&yoEf!FvU;=4#gBC2;Ff3pJ z6|OZ53z=9z8^sVqDU2yhrHn;hHB1XwYZx;bK$q)+Tj$J0Z$M+)0!a3Qn>Bu*b%pUr zqa5HRHjpJd;ARbI?<}l+2y)jgHmG87Y5)^5pa266si}cN0K7tsiHVU5a*N@A0cOxC zVQ5WR(7h)Rr{pFUprj2@p$fv_fB-d%AZcSEBdEs*$`(a$L9J<~B9MiUZj(5?075ti z6p2P4=YX;#1A5v-SP!~H1ZB-1DCff?!ibT9p@yjdJR<;V-xmvknwlk`4I<!`wOOF! zds!AT*0O>It6RXk&znIPU$TPs^13j@*2FM@rk86tYCzX~$JH<wg)uS|zA4<n2<|!+ z+SG7>cl_FbF8eNF&t@vJsbMbessYW+vqNqnEMovIp$FMp!&t(R#azlzGzWGA1Ng>T zcF=evBSQ__0<Ic%(244xgi`pX&<3vl3|u{P(LIo!6z~`(BSRin4dViC&|m_@Jyjw# zYzug5SZdf)Sj9p6lsUs0@}yW8N_ZzQR!V`)Wn_qCn7~-57s*ig#(<%Qt%lPUv|kZK za@MjJz5%&YlP&QH69WUZH4eTB2sYIVYL0_;$0n9!AQtL+rYS%#^|1w?LkVx2qn-bx ztKgXizm^MR66{o@Owe$8NrpmVUS)YkYEi0=LQ1{@^q6o&ml8BKsH@<bQ=DoAA5{X0 zDJXyq&MZ*}jYfg?{(%N*6+i=y1&KwVvz1a{ClP`yg*qQ~J^*A+W?pe>QHeqpXw`2b zXtWnp41o$Lh$*NJ0a*%mib7&a3TS*2q%buv1*8YmWk#q*3LVf5sHkoSyBs-iVL<|Q zB|JzJG(bfh=p1|0Jz)x<0x}~rJtMV9p`a);zbLb$5>&Z>)`As-CMiJv2VLt@jIM7G z1~F!wfLGgrMhp}4Diw0_%Rv|2z<dcRe=<|ira@5SB@=w|B`9jrit_VHFe3+hOAfqt z4OA+EkIE4N4bc{ffM!*j84JW}kk8o0e>6w{H|(q&EtHxBlG5Vy^N?C@ps{h#{&PFf z><mK@=+qTWK1lZztvLibsqYqNYF=q>Drm+CvSgtFREC2Nr?@4SoRONG4Vy!WPtMOv z%gIbGDN+EHvPVJ6rh+O!P?rLBDKe<1dy6?IKe^~CXweT#UQT}UEtaH|%%WSYd7#u> zG#R7?bX>qKrabgT#zmmsv>B+Z290$xh=9&kU;%HT1YL6sI%<)Pg@aLu8MMs{v;`Hk z&5{k=UT0zCW8z|DVPRqv0WCvj;$dQAsuIH<R4BbeP~#HRf(KVJperCj4a^kAY^EYU zP+t&q^cZNG0(6K8_)t&q1|jem3Un2z3qx!HXn|!3TNZm6W3dtF%Jnh^5M9Di#!wVg zXau?n1GFT$(5QqHqzbfWH-#14(POD$De8k90I`4zRQMJf)v$oC9%o(1SkzZ&RKlGC znp^_g3hK6lMnMXVKrYi{_q)Ya3_qQ}=s)OaU*3}Zf_U&2A<zZAn#{L&Q7%L&5@2Rv zxW!ToIu~~dBLhQ~C*%Y#1=V7Oa?sQ#<cvE7$S_H23S`ZvYB6L}glaLU(1T2uCZ<3q z8{uOnJm8sZ@YOg)pye}=fhExHbV$+zr6|Y|V&H=~z@1UhYRy}`nZ?DWso+_=%)E5y zQ0Fb?yyAi)Zjf`?bMsR`?Ydh`X?bWvCq-P$3=CDE^a2{8WMJfCVqp>hFGLq&Wcv@= z9|juu6k-%&<O1`+*Jp!zAIc~xBN=NlM@c52jvl-%0A3paZj^yWl=D<rK#el!>HyGQ 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 diff --git a/env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-39.pyc deleted file mode 100644 index ab37be8e77928bd336e09a63cdc0f0c8da407f7e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 678 zcmYe~<>g{vU|^UdaWK`0iGkrUh=Yuo85kHG7#J9e6Brm6QW#Pga~Pr^G-DJan9mf& zl){k0l*63M62-#EkiwC|lET`;7{!{(lEqfwlfstDl*P`%z|4@%nD3Fop3RWQ!o<MH z5XF(oQ52TSn#YpLki{9rnZg*%pvn0XWVfFt<1Oam%nG+;CJ+~jK`sHg)fwa(F9rsN zD!vki1&lQe3mF+1!Wr_+SQtu}DqR>EYMB@rs^n@Ii}Y%kvY1Plvskj3iwv3=!WkkN zQW$EP>X`DlAhZF40YeHyFoPzepC;=qru^bt9Jz_vsVSL7#kbh~gI$Y?@{4Y<rWO_D z<=<j+b&c>04$)-3#Zr)1l5vY8wIZ{)BtAd;7ISJv@=AsxZUzR1Umea?F`>n&Ma40x zIVqV%G5&d}E=8GTsS3IZp?;oWu0g?`A&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QS zF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylBsk#M;$=QkNsl_n`nFadsWvO{7`9=B#+3E2` zsm1xFMaikf`URE7hRON41&Jkk1(mmW;$dEiH#Xz|g&8RD7#Nut`55^a1sIEX85kHe znO=f|^(704&0NICz`#(%&%nU&k`W}p=%&e41d=aeV_;yo#avuje2cpvvp^4Oe-S8p zz~<ay4u~|m#Z#7ARGgWg7oVAzmVb*cFEur#819N9kR9MaLLzuT=5pBN=BJeAq}qWj aEf!#4VBlcnVB}!pVdmmtW0d&E!~y_b$D>XF diff --git a/env/Lib/site-packages/pip/_vendor/pkg_resources/py31compat.py b/env/Lib/site-packages/pip/_vendor/pkg_resources/py31compat.py deleted file mode 100644 index a2d3007c..00000000 --- a/env/Lib/site-packages/pip/_vendor/pkg_resources/py31compat.py +++ /dev/null @@ -1,23 +0,0 @@ -import os -import errno -import sys - -from pip._vendor import six - - -def _makedirs_31(path, exist_ok=False): - try: - os.makedirs(path) - except OSError as exc: - if not exist_ok or exc.errno != errno.EEXIST: - raise - - -# rely on compatibility behavior until mode considerations -# and exists_ok considerations are disentangled. -# See https://github.com/pypa/setuptools/pull/1083#issuecomment-315168663 -needs_makedirs = ( - six.PY2 or - (3, 4) <= sys.version_info < (3, 4, 1) -) -makedirs = _makedirs_31 if needs_makedirs else os.makedirs diff --git a/env/Lib/site-packages/pip/_vendor/progress/__init__.py b/env/Lib/site-packages/pip/_vendor/progress/__init__.py deleted file mode 100644 index e434c257..00000000 --- a/env/Lib/site-packages/pip/_vendor/progress/__init__.py +++ /dev/null @@ -1,177 +0,0 @@ -# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com> -# -# Permission to use, copy, modify, and distribute this software for any -# purpose with or without fee is hereby granted, provided that the above -# copyright notice and this permission notice appear in all copies. -# -# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES -# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF -# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR -# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES -# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN -# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF -# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - -from __future__ import division, print_function - -from collections import deque -from datetime import timedelta -from math import ceil -from sys import stderr -try: - from time import monotonic -except ImportError: - from time import time as monotonic - - -__version__ = '1.5' - -HIDE_CURSOR = '\x1b[?25l' -SHOW_CURSOR = '\x1b[?25h' - - -class Infinite(object): - file = stderr - sma_window = 10 # Simple Moving Average window - check_tty = True - hide_cursor = True - - def __init__(self, message='', **kwargs): - self.index = 0 - self.start_ts = monotonic() - self.avg = 0 - self._avg_update_ts = self.start_ts - self._ts = self.start_ts - self._xput = deque(maxlen=self.sma_window) - for key, val in kwargs.items(): - setattr(self, key, val) - - self._width = 0 - self.message = message - - if self.file and self.is_tty(): - if self.hide_cursor: - print(HIDE_CURSOR, end='', file=self.file) - print(self.message, end='', file=self.file) - self.file.flush() - - def __getitem__(self, key): - if key.startswith('_'): - return None - return getattr(self, key, None) - - @property - def elapsed(self): - return int(monotonic() - self.start_ts) - - @property - def elapsed_td(self): - return timedelta(seconds=self.elapsed) - - def update_avg(self, n, dt): - if n > 0: - xput_len = len(self._xput) - self._xput.append(dt / n) - now = monotonic() - # update when we're still filling _xput, then after every second - if (xput_len < self.sma_window or - now - self._avg_update_ts > 1): - self.avg = sum(self._xput) / len(self._xput) - self._avg_update_ts = now - - def update(self): - pass - - def start(self): - pass - - def clearln(self): - if self.file and self.is_tty(): - print('\r\x1b[K', end='', file=self.file) - - def write(self, s): - if self.file and self.is_tty(): - line = self.message + s.ljust(self._width) - print('\r' + line, end='', file=self.file) - self._width = max(self._width, len(s)) - self.file.flush() - - def writeln(self, line): - if self.file and self.is_tty(): - self.clearln() - print(line, end='', file=self.file) - self.file.flush() - - def finish(self): - if self.file and self.is_tty(): - print(file=self.file) - if self.hide_cursor: - print(SHOW_CURSOR, end='', file=self.file) - - def is_tty(self): - return self.file.isatty() if self.check_tty else True - - def next(self, n=1): - now = monotonic() - dt = now - self._ts - self.update_avg(n, dt) - self._ts = now - self.index = self.index + n - self.update() - - def iter(self, it): - with self: - for x in it: - yield x - self.next() - - def __enter__(self): - self.start() - return self - - def __exit__(self, exc_type, exc_val, exc_tb): - self.finish() - - -class Progress(Infinite): - def __init__(self, *args, **kwargs): - super(Progress, self).__init__(*args, **kwargs) - self.max = kwargs.get('max', 100) - - @property - def eta(self): - return int(ceil(self.avg * self.remaining)) - - @property - def eta_td(self): - return timedelta(seconds=self.eta) - - @property - def percent(self): - return self.progress * 100 - - @property - def progress(self): - return min(1, self.index / self.max) - - @property - def remaining(self): - return max(self.max - self.index, 0) - - def start(self): - self.update() - - def goto(self, index): - incr = index - self.index - self.next(incr) - - def iter(self, it): - try: - self.max = len(it) - except TypeError: - pass - - with self: - for x in it: - yield x - self.next() diff --git a/env/Lib/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 59331d34d3f0a9b879d94dabfe954b129ee10bb6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5685 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 OA!ZgP7Dg6kfph@0L1cIU diff --git a/env/Lib/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-39.pyc deleted file mode 100644 index 4444a268fe93d187e8fe4761ddd5b1d14c129255..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2667 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 diff --git a/env/Lib/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-39.pyc deleted file mode 100644 index 801c1561f9475b6ca748f056260878c085e13375..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1501 zcmYe~<>g{vU|^UdaWFN8m4V?gh=Yt-7#J8F7#J9e6Brm6QW#Pga~N_NqZk<(QkYVh zbC`0OqnLA9qF5Li+!<0>QdnCUQdm=&o0+3n-5FBYQrKG<QrJ^jnwg{6+!<0hQaD=} zQaHhUc6Wvpt`zPTh7|5p_GacNjuf6?22I|VAiFggZwZv<WhUpRq{ioDmZTOX<`lnV zWME*>WV*%SnU|KCmsyf}izA>YKfNfmxHuW42N^TL+$_Stz>vxi#hAhn#gxLB!qmbL z#hk(%%%I6~i`_ZDG_NGJC>dlfOf!fL@~|_=!ywHy3=0@a7;6}^n3@?Ef;`O-%&?Nt zPm}o;Yk3jK5zNIUMYmWp^HNePRx;jVDNfBvTggzw%fP_!tHIeSCbT%Us5mAyCnd8e z#y>CBr6{v3RY6xF)Xy`_H7M9K#4%XG)6d1<&o$W7F(%m6*EKlAHAulMCLq8kCecJU zCqF&2xFj<>CN-}t#wRl=rZ}@CRkt89IXf{uwK%3Avp_$-EHy7Bzev9T8W{S?5P#_v zRNi7MEl5c$NfiV61{5X?j8%M4Z|gy%{8qBu;)svWOUzA;kH5tgAD^3_Qknx|^Tfv& zmL}#vWQzD17$Cj^dksSHfyCGt7#Kuh=5sI>f%s&_2PfEJDf#7jq{m1RJ1A{17jb}G z#L2+GaEr4jH8(LcFEcN_h#MpbiV!4MgS;aRb2S5Fl>ppwShy4kplSmf0QNB`SxCY3 zaxfNw__%#6fsz8Fm_fOwg&~S1g(a9lll2yBa7kivwkGE<Muk#l1_p*l(;A_46O?X- z(k)QB6-u{3>2@gHff8&Wvsf7z7{CeHjDdlngrSBZi?Nxpma&AXhB1Xvf}w=Dh9Qfk zhEar}nX#FvmZ^qe0V_yN4U;4TEU9ZU`4xeT(qy~EoRgY&i>)9du{gE(7ISW9-Yw?L zypmfSuyh9wd`;#e9#HVJ=Rp-RW<o+85qzMaR{{keD5WqkaxqFUR`GyC0T%R{tVM#L zz!w4$!XQEtM1V9R8HO+sl)U9ZCW3M<2O|qp5l93hN<euVT#$ic7EvgGq9m9>llc~N zKxV2YD<m|hcSGqZP<kSio(iS={WMvyx)SUx1OZMlAjfHd90<yT9E?REzMm#1D7&SV zmXsEy#>W?dq;4@3fxJ)zia2ma0;esoZ@_x6`TiD%4J6Cjfx@g9RF?BF3NQ<>3a|=r F0suI8FOC2J diff --git a/env/Lib/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-39.pyc deleted file mode 100644 index ba7ea893a261c2e9462a7a6c31be6a1b84b4a289..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1418 zcmYe~<>g{vU|^UdaWFN7m4V?gh=Yt-7#J8F7#J9ea~K#HQW#Pga~N_NqZk<(QkYVh zbC`0OqnH^P+!<0>QdnCUQdm=&o0+3n+!<2XQrKG<QrJ^jnwg_m-5F9iQaD=}QaHhU zHg|>;t`zPTh7@ivpWU4yg(ro#g&~C(%;!kq3ue&de+hDjCgUxE(!9*%{FK!AoXnEc zqQsoymy8Sy44RC$I6U*xGV?M^Qj<X{kuej@)iMkW45<uJj42FJOeu^}%qdJ!EGf(> zEG-OCtSPL)44Q1W*n<l)^YT)QG+BNz>i%Mk`NdfCi%~x$8Dt5}Optk?kZ=ZtgbD)# zLk&X~LkVLILl#prqZmUiV-3RsW)QE2QIcUHD0CQt88jLFG+A!3X6B`&R@`FFNzJ>( zR*;ccoLYQ~wY(^^Bvq5?7E5tzPTDQT%#{p90t^fczZ#saVnT~ki;81Xb5b&kV*K+` zU5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(O zi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F@{9Bfit^KoQj3fAiy<MP zS5SG2t+XH|u_RRz<WZ2185ji^tN5Tnqz94o(`38F5g(tIn420Oe~T+VJ~uz5GzY}y ziH|QVP0WGF6!9=HFx=wK$V^F%PcAJg&MztwVqk#y6zp9HAqWy<Wnf?s1=-2Qz`(%4 z$im3NR0I;k9kU`xF`Lei!ng<=yTJ^a%(u7#GE<>0)?_JVW?*1=G<`di-Ug+&Lg_7j zD_M$!K~4Y}SOjtd*xeAffg%OM0=rV2fq_8|<VsL_;9x8Q@yT)_w{L!a9=a1JLY*`T zN>6~&ll_V$Kn_GW2FwDx2oz6BNG<~L$#aoUW*$7y*dR9d?fME1yuRH~dJj~5ZxJY8 z6-hHNFyL{U6axc;8j{;Ue6rle6OdVvnga_i4u~Tb?}O6Nm|eUc%AXIR7w(79i=g!4 z-4Ooby?C4~%fP^(h2&%q-%pbhl*ZFaOG=AU<Kv4!aes@U2$VU%Nfew4ia-Hh1oB}K kNDm~<fTIaafa2;FhYcj3*nxP(pv=L;$ipnaDZm1P0KC*Jy#N3J diff --git a/env/Lib/site-packages/pip/_vendor/progress/bar.py b/env/Lib/site-packages/pip/_vendor/progress/bar.py deleted file mode 100644 index 8819efda..00000000 --- a/env/Lib/site-packages/pip/_vendor/progress/bar.py +++ /dev/null @@ -1,91 +0,0 @@ -# -*- coding: utf-8 -*- - -# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com> -# -# Permission to use, copy, modify, and distribute this software for any -# purpose with or without fee is hereby granted, provided that the above -# copyright notice and this permission notice appear in all copies. -# -# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES -# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF -# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR -# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES -# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN -# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF -# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - -from __future__ import unicode_literals - -import sys - -from . import Progress - - -class Bar(Progress): - width = 32 - suffix = '%(index)d/%(max)d' - bar_prefix = ' |' - bar_suffix = '| ' - empty_fill = ' ' - fill = '#' - - def update(self): - filled_length = int(self.width * self.progress) - empty_length = self.width - filled_length - - message = self.message % self - bar = self.fill * filled_length - empty = self.empty_fill * empty_length - suffix = self.suffix % self - line = ''.join([message, self.bar_prefix, bar, empty, self.bar_suffix, - suffix]) - self.writeln(line) - - -class ChargingBar(Bar): - suffix = '%(percent)d%%' - bar_prefix = ' ' - bar_suffix = ' ' - empty_fill = '∙' - fill = '█' - - -class FillingSquaresBar(ChargingBar): - empty_fill = '▢' - fill = '▣' - - -class FillingCirclesBar(ChargingBar): - empty_fill = '◯' - fill = '◉' - - -class IncrementalBar(Bar): - if sys.platform.startswith('win'): - phases = (u' ', u'▌', u'█') - else: - phases = (' ', '▏', '▎', '▍', '▌', '▋', '▊', '▉', '█') - - def update(self): - nphases = len(self.phases) - filled_len = self.width * self.progress - nfull = int(filled_len) # Number of full chars - phase = int((filled_len - nfull) * nphases) # Phase of last char - nempty = self.width - nfull # Number of empty chars - - message = self.message % self - bar = self.phases[-1] * nfull - current = self.phases[phase] if phase > 0 else '' - empty = self.empty_fill * max(0, nempty - len(current)) - suffix = self.suffix % self - line = ''.join([message, self.bar_prefix, bar, current, empty, - self.bar_suffix, suffix]) - self.writeln(line) - - -class PixelBar(IncrementalBar): - phases = ('⡀', '⡄', '⡆', '⡇', '⣇', '⣧', '⣷', '⣿') - - -class ShadyBar(IncrementalBar): - phases = (' ', '░', '▒', '▓', '█') diff --git a/env/Lib/site-packages/pip/_vendor/progress/counter.py b/env/Lib/site-packages/pip/_vendor/progress/counter.py deleted file mode 100644 index d955ca47..00000000 --- a/env/Lib/site-packages/pip/_vendor/progress/counter.py +++ /dev/null @@ -1,41 +0,0 @@ -# -*- coding: utf-8 -*- - -# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com> -# -# Permission to use, copy, modify, and distribute this software for any -# purpose with or without fee is hereby granted, provided that the above -# copyright notice and this permission notice appear in all copies. -# -# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES -# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF -# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR -# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES -# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN -# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF -# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - -from __future__ import unicode_literals -from . import Infinite, Progress - - -class Counter(Infinite): - def update(self): - self.write(str(self.index)) - - -class Countdown(Progress): - def update(self): - self.write(str(self.remaining)) - - -class Stack(Progress): - phases = (' ', '▁', '▂', '▃', '▄', '▅', '▆', '▇', '█') - - def update(self): - nphases = len(self.phases) - i = min(nphases - 1, int(self.progress * nphases)) - self.write(self.phases[i]) - - -class Pie(Stack): - phases = ('○', '◔', '◑', '◕', '●') diff --git a/env/Lib/site-packages/pip/_vendor/progress/spinner.py b/env/Lib/site-packages/pip/_vendor/progress/spinner.py deleted file mode 100644 index 4e100cab..00000000 --- a/env/Lib/site-packages/pip/_vendor/progress/spinner.py +++ /dev/null @@ -1,43 +0,0 @@ -# -*- coding: utf-8 -*- - -# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com> -# -# Permission to use, copy, modify, and distribute this software for any -# purpose with or without fee is hereby granted, provided that the above -# copyright notice and this permission notice appear in all copies. -# -# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES -# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF -# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR -# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES -# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN -# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF -# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. - -from __future__ import unicode_literals -from . import Infinite - - -class Spinner(Infinite): - phases = ('-', '\\', '|', '/') - hide_cursor = True - - def update(self): - i = self.index % len(self.phases) - self.write(self.phases[i]) - - -class PieSpinner(Spinner): - phases = ['◷', '◶', '◵', '◴'] - - -class MoonSpinner(Spinner): - phases = ['◑', '◒', '◐', '◓'] - - -class LineSpinner(Spinner): - phases = ['⎺', '⎻', '⎼', '⎽', '⎼', '⎻'] - - -class PixelSpinner(Spinner): - phases = ['⣾', '⣷', '⣯', '⣟', '⡿', '⢿', '⣻', '⣽'] diff --git a/env/Lib/site-packages/pip/_vendor/pyparsing.py b/env/Lib/site-packages/pip/_vendor/pyparsing.py deleted file mode 100644 index 7ebc7eb9..00000000 --- a/env/Lib/site-packages/pip/_vendor/pyparsing.py +++ /dev/null @@ -1,7107 +0,0 @@ -# -*- coding: utf-8 -*- -# module pyparsing.py -# -# Copyright (c) 2003-2019 Paul T. McGuire -# -# Permission is hereby granted, free of charge, to any person obtaining -# a copy of this software and associated documentation files (the -# "Software"), to deal in the Software without restriction, including -# without limitation the rights to use, copy, modify, merge, publish, -# distribute, sublicense, and/or sell copies of the Software, and to -# permit persons to whom the Software is furnished to do so, subject to -# the following conditions: -# -# The above copyright notice and this permission notice shall be -# included in all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, -# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF -# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. -# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY -# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, -# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE -# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -# - -__doc__ = \ -""" -pyparsing module - Classes and methods to define and execute parsing grammars -============================================================================= - -The pyparsing module is an alternative approach to creating and -executing simple grammars, vs. the traditional lex/yacc approach, or the -use of regular expressions. With pyparsing, you don't need to learn -a new syntax for defining grammars or matching expressions - the parsing -module provides a library of classes that you use to construct the -grammar directly in Python. - -Here is a program to parse "Hello, World!" (or any greeting of the form -``"<salutation>, <addressee>!"``), built up using :class:`Word`, -:class:`Literal`, and :class:`And` elements -(the :class:`'+'<ParserElement.__add__>` operators create :class:`And` expressions, -and the strings are auto-converted to :class:`Literal` expressions):: - - from pip._vendor.pyparsing import Word, alphas - - # define grammar of a greeting - greet = Word(alphas) + "," + Word(alphas) + "!" - - hello = "Hello, World!" - print (hello, "->", greet.parseString(hello)) - -The program outputs the following:: - - Hello, World! -> ['Hello', ',', 'World', '!'] - -The Python representation of the grammar is quite readable, owing to the -self-explanatory class names, and the use of '+', '|' and '^' operators. - -The :class:`ParseResults` object returned from -:class:`ParserElement.parseString` can be -accessed as a nested list, a dictionary, or an object with named -attributes. - -The pyparsing module handles some of the problems that are typically -vexing when writing text parsers: - - - extra or missing whitespace (the above program will also handle - "Hello,World!", "Hello , World !", etc.) - - quoted strings - - embedded comments - - -Getting Started - ------------------ -Visit the classes :class:`ParserElement` and :class:`ParseResults` to -see the base classes that most other pyparsing -classes inherit from. Use the docstrings for examples of how to: - - - construct literal match expressions from :class:`Literal` and - :class:`CaselessLiteral` classes - - construct character word-group expressions using the :class:`Word` - class - - see how to create repetitive expressions using :class:`ZeroOrMore` - and :class:`OneOrMore` classes - - use :class:`'+'<And>`, :class:`'|'<MatchFirst>`, :class:`'^'<Or>`, - and :class:`'&'<Each>` operators to combine simple expressions into - more complex ones - - associate names with your parsed results using - :class:`ParserElement.setResultsName` - - access the parsed data, which is returned as a :class:`ParseResults` - object - - find some helpful expression short-cuts like :class:`delimitedList` - and :class:`oneOf` - - find more useful common expressions in the :class:`pyparsing_common` - namespace class -""" - -__version__ = "2.4.7" -__versionTime__ = "30 Mar 2020 00:43 UTC" -__author__ = "Paul McGuire <ptmcg@users.sourceforge.net>" - -import string -from weakref import ref as wkref -import copy -import sys -import warnings -import re -import sre_constants -import collections -import pprint -import traceback -import types -from datetime import datetime -from operator import itemgetter -import itertools -from functools import wraps -from contextlib import contextmanager - -try: - # Python 3 - from itertools import filterfalse -except ImportError: - from itertools import ifilterfalse as filterfalse - -try: - from _thread import RLock -except ImportError: - from threading import RLock - -try: - # Python 3 - from collections.abc import Iterable - from collections.abc import MutableMapping, Mapping -except ImportError: - # Python 2.7 - from collections import Iterable - from collections import MutableMapping, Mapping - -try: - from collections import OrderedDict as _OrderedDict -except ImportError: - try: - from ordereddict import OrderedDict as _OrderedDict - except ImportError: - _OrderedDict = None - -try: - from types import SimpleNamespace -except ImportError: - class SimpleNamespace: pass - -# version compatibility configuration -__compat__ = SimpleNamespace() -__compat__.__doc__ = """ - A cross-version compatibility configuration for pyparsing features that will be - released in a future version. By setting values in this configuration to True, - those features can be enabled in prior versions for compatibility development - and testing. - - - collect_all_And_tokens - flag to enable fix for Issue #63 that fixes erroneous grouping - of results names when an And expression is nested within an Or or MatchFirst; set to - True to enable bugfix released in pyparsing 2.3.0, or False to preserve - pre-2.3.0 handling of named results -""" -__compat__.collect_all_And_tokens = True - -__diag__ = SimpleNamespace() -__diag__.__doc__ = """ -Diagnostic configuration (all default to False) - - warn_multiple_tokens_in_named_alternation - flag to enable warnings when a results - name is defined on a MatchFirst or Or expression with one or more And subexpressions - (only warns if __compat__.collect_all_And_tokens is False) - - warn_ungrouped_named_tokens_in_collection - flag to enable warnings when a results - name is defined on a containing expression with ungrouped subexpressions that also - have results names - - warn_name_set_on_empty_Forward - flag to enable warnings whan a Forward is defined - with a results name, but has no contents defined - - warn_on_multiple_string_args_to_oneof - flag to enable warnings whan oneOf is - incorrectly called with multiple str arguments - - enable_debug_on_named_expressions - flag to auto-enable debug on all subsequent - calls to ParserElement.setName() -""" -__diag__.warn_multiple_tokens_in_named_alternation = False -__diag__.warn_ungrouped_named_tokens_in_collection = False -__diag__.warn_name_set_on_empty_Forward = False -__diag__.warn_on_multiple_string_args_to_oneof = False -__diag__.enable_debug_on_named_expressions = False -__diag__._all_names = [nm for nm in vars(__diag__) if nm.startswith("enable_") or nm.startswith("warn_")] - -def _enable_all_warnings(): - __diag__.warn_multiple_tokens_in_named_alternation = True - __diag__.warn_ungrouped_named_tokens_in_collection = True - __diag__.warn_name_set_on_empty_Forward = True - __diag__.warn_on_multiple_string_args_to_oneof = True -__diag__.enable_all_warnings = _enable_all_warnings - - -__all__ = ['__version__', '__versionTime__', '__author__', '__compat__', '__diag__', - 'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty', - 'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal', - 'PrecededBy', 'MatchFirst', 'NoMatch', 'NotAny', 'OneOrMore', 'OnlyOnce', 'Optional', 'Or', - 'ParseBaseException', 'ParseElementEnhance', 'ParseException', 'ParseExpression', 'ParseFatalException', - 'ParseResults', 'ParseSyntaxException', 'ParserElement', 'QuotedString', 'RecursiveGrammarException', - 'Regex', 'SkipTo', 'StringEnd', 'StringStart', 'Suppress', 'Token', 'TokenConverter', - 'White', 'Word', 'WordEnd', 'WordStart', 'ZeroOrMore', 'Char', - 'alphanums', 'alphas', 'alphas8bit', 'anyCloseTag', 'anyOpenTag', 'cStyleComment', 'col', - 'commaSeparatedList', 'commonHTMLEntity', 'countedArray', 'cppStyleComment', 'dblQuotedString', - 'dblSlashComment', 'delimitedList', 'dictOf', 'downcaseTokens', 'empty', 'hexnums', - 'htmlComment', 'javaStyleComment', 'line', 'lineEnd', 'lineStart', 'lineno', - 'makeHTMLTags', 'makeXMLTags', 'matchOnlyAtCol', 'matchPreviousExpr', 'matchPreviousLiteral', - 'nestedExpr', 'nullDebugAction', 'nums', 'oneOf', 'opAssoc', 'operatorPrecedence', 'printables', - 'punc8bit', 'pythonStyleComment', 'quotedString', 'removeQuotes', 'replaceHTMLEntity', - 'replaceWith', 'restOfLine', 'sglQuotedString', 'srange', 'stringEnd', - 'stringStart', 'traceParseAction', 'unicodeString', 'upcaseTokens', 'withAttribute', - 'indentedBlock', 'originalTextFor', 'ungroup', 'infixNotation', 'locatedExpr', 'withClass', - 'CloseMatch', 'tokenMap', 'pyparsing_common', 'pyparsing_unicode', 'unicode_set', - 'conditionAsParseAction', 're', - ] - -system_version = tuple(sys.version_info)[:3] -PY_3 = system_version[0] == 3 -if PY_3: - _MAX_INT = sys.maxsize - basestring = str - unichr = chr - unicode = str - _ustr = str - - # build list of single arg builtins, that can be used as parse actions - singleArgBuiltins = [sum, len, sorted, reversed, list, tuple, set, any, all, min, max] - -else: - _MAX_INT = sys.maxint - range = xrange - - def _ustr(obj): - """Drop-in replacement for str(obj) that tries to be Unicode - friendly. It first tries str(obj). If that fails with - a UnicodeEncodeError, then it tries unicode(obj). It then - < returns the unicode object | encodes it with the default - encoding | ... >. - """ - if isinstance(obj, unicode): - return obj - - try: - # If this works, then _ustr(obj) has the same behaviour as str(obj), so - # it won't break any existing code. - return str(obj) - - except UnicodeEncodeError: - # Else encode it - ret = unicode(obj).encode(sys.getdefaultencoding(), 'xmlcharrefreplace') - xmlcharref = Regex(r'&#\d+;') - xmlcharref.setParseAction(lambda t: '\\u' + hex(int(t[0][2:-1]))[2:]) - return xmlcharref.transformString(ret) - - # build list of single arg builtins, tolerant of Python version, that can be used as parse actions - singleArgBuiltins = [] - import __builtin__ - - for fname in "sum len sorted reversed list tuple set any all min max".split(): - try: - singleArgBuiltins.append(getattr(__builtin__, fname)) - except AttributeError: - continue - -_generatorType = type((y for y in range(1))) - -def _xml_escape(data): - """Escape &, <, >, ", ', etc. in a string of data.""" - - # ampersand must be replaced first - from_symbols = '&><"\'' - to_symbols = ('&' + s + ';' for s in "amp gt lt quot apos".split()) - for from_, to_ in zip(from_symbols, to_symbols): - data = data.replace(from_, to_) - return data - -alphas = string.ascii_uppercase + string.ascii_lowercase -nums = "0123456789" -hexnums = nums + "ABCDEFabcdef" -alphanums = alphas + nums -_bslash = chr(92) -printables = "".join(c for c in string.printable if c not in string.whitespace) - - -def conditionAsParseAction(fn, message=None, fatal=False): - msg = message if message is not None else "failed user-defined condition" - exc_type = ParseFatalException if fatal else ParseException - fn = _trim_arity(fn) - - @wraps(fn) - def pa(s, l, t): - if not bool(fn(s, l, t)): - raise exc_type(s, l, msg) - - return pa - -class ParseBaseException(Exception): - """base exception class for all parsing runtime exceptions""" - # Performance tuning: we construct a *lot* of these, so keep this - # constructor as small and fast as possible - def __init__(self, pstr, loc=0, msg=None, elem=None): - self.loc = loc - if msg is None: - self.msg = pstr - self.pstr = "" - else: - self.msg = msg - self.pstr = pstr - self.parserElement = elem - self.args = (pstr, loc, msg) - - @classmethod - def _from_exception(cls, pe): - """ - internal factory method to simplify creating one type of ParseException - from another - avoids having __init__ signature conflicts among subclasses - """ - return cls(pe.pstr, pe.loc, pe.msg, pe.parserElement) - - def __getattr__(self, aname): - """supported attributes by name are: - - lineno - returns the line number of the exception text - - col - returns the column number of the exception text - - line - returns the line containing the exception text - """ - if aname == "lineno": - return lineno(self.loc, self.pstr) - elif aname in ("col", "column"): - return col(self.loc, self.pstr) - elif aname == "line": - return line(self.loc, self.pstr) - else: - raise AttributeError(aname) - - def __str__(self): - if self.pstr: - if self.loc >= len(self.pstr): - foundstr = ', found end of text' - else: - foundstr = (', found %r' % self.pstr[self.loc:self.loc + 1]).replace(r'\\', '\\') - else: - foundstr = '' - return ("%s%s (at char %d), (line:%d, col:%d)" % - (self.msg, foundstr, self.loc, self.lineno, self.column)) - def __repr__(self): - return _ustr(self) - def markInputline(self, markerString=">!<"): - """Extracts the exception line from the input string, and marks - the location of the exception with a special symbol. - """ - line_str = self.line - line_column = self.column - 1 - if markerString: - line_str = "".join((line_str[:line_column], - markerString, line_str[line_column:])) - return line_str.strip() - def __dir__(self): - return "lineno col line".split() + dir(type(self)) - -class ParseException(ParseBaseException): - """ - Exception thrown when parse expressions don't match class; - supported attributes by name are: - - lineno - returns the line number of the exception text - - col - returns the column number of the exception text - - line - returns the line containing the exception text - - Example:: - - try: - Word(nums).setName("integer").parseString("ABC") - except ParseException as pe: - print(pe) - print("column: {}".format(pe.col)) - - prints:: - - Expected integer (at char 0), (line:1, col:1) - column: 1 - - """ - - @staticmethod - def explain(exc, depth=16): - """ - Method to take an exception and translate the Python internal traceback into a list - of the pyparsing expressions that caused the exception to be raised. - - Parameters: - - - exc - exception raised during parsing (need not be a ParseException, in support - of Python exceptions that might be raised in a parse action) - - depth (default=16) - number of levels back in the stack trace to list expression - and function names; if None, the full stack trace names will be listed; if 0, only - the failing input line, marker, and exception string will be shown - - Returns a multi-line string listing the ParserElements and/or function names in the - exception's stack trace. - - Note: the diagnostic output will include string representations of the expressions - that failed to parse. These representations will be more helpful if you use `setName` to - give identifiable names to your expressions. Otherwise they will use the default string - forms, which may be cryptic to read. - - explain() is only supported under Python 3. - """ - import inspect - - if depth is None: - depth = sys.getrecursionlimit() - ret = [] - if isinstance(exc, ParseBaseException): - ret.append(exc.line) - ret.append(' ' * (exc.col - 1) + '^') - ret.append("{0}: {1}".format(type(exc).__name__, exc)) - - if depth > 0: - callers = inspect.getinnerframes(exc.__traceback__, context=depth) - seen = set() - for i, ff in enumerate(callers[-depth:]): - frm = ff[0] - - f_self = frm.f_locals.get('self', None) - if isinstance(f_self, ParserElement): - if frm.f_code.co_name not in ('parseImpl', '_parseNoCache'): - continue - if f_self in seen: - continue - seen.add(f_self) - - self_type = type(f_self) - ret.append("{0}.{1} - {2}".format(self_type.__module__, - self_type.__name__, - f_self)) - elif f_self is not None: - self_type = type(f_self) - ret.append("{0}.{1}".format(self_type.__module__, - self_type.__name__)) - else: - code = frm.f_code - if code.co_name in ('wrapper', '<module>'): - continue - - ret.append("{0}".format(code.co_name)) - - depth -= 1 - if not depth: - break - - return '\n'.join(ret) - - -class ParseFatalException(ParseBaseException): - """user-throwable exception thrown when inconsistent parse content - is found; stops all parsing immediately""" - pass - -class ParseSyntaxException(ParseFatalException): - """just like :class:`ParseFatalException`, but thrown internally - when an :class:`ErrorStop<And._ErrorStop>` ('-' operator) indicates - that parsing is to stop immediately because an unbacktrackable - syntax error has been found. - """ - pass - -#~ class ReparseException(ParseBaseException): - #~ """Experimental class - parse actions can raise this exception to cause - #~ pyparsing to reparse the input string: - #~ - with a modified input string, and/or - #~ - with a modified start location - #~ Set the values of the ReparseException in the constructor, and raise the - #~ exception in a parse action to cause pyparsing to use the new string/location. - #~ Setting the values as None causes no change to be made. - #~ """ - #~ def __init_( self, newstring, restartLoc ): - #~ self.newParseText = newstring - #~ self.reparseLoc = restartLoc - -class RecursiveGrammarException(Exception): - """exception thrown by :class:`ParserElement.validate` if the - grammar could be improperly recursive - """ - def __init__(self, parseElementList): - self.parseElementTrace = parseElementList - - def __str__(self): - return "RecursiveGrammarException: %s" % self.parseElementTrace - -class _ParseResultsWithOffset(object): - def __init__(self, p1, p2): - self.tup = (p1, p2) - def __getitem__(self, i): - return self.tup[i] - def __repr__(self): - return repr(self.tup[0]) - def setOffset(self, i): - self.tup = (self.tup[0], i) - -class ParseResults(object): - """Structured parse results, to provide multiple means of access to - the parsed data: - - - as a list (``len(results)``) - - by list index (``results[0], results[1]``, etc.) - - by attribute (``results.<resultsName>`` - see :class:`ParserElement.setResultsName`) - - Example:: - - integer = Word(nums) - date_str = (integer.setResultsName("year") + '/' - + integer.setResultsName("month") + '/' - + integer.setResultsName("day")) - # equivalent form: - # date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - # parseString returns a ParseResults object - result = date_str.parseString("1999/12/31") - - def test(s, fn=repr): - print("%s -> %s" % (s, fn(eval(s)))) - test("list(result)") - test("result[0]") - test("result['month']") - test("result.day") - test("'month' in result") - test("'minutes' in result") - test("result.dump()", str) - - prints:: - - list(result) -> ['1999', '/', '12', '/', '31'] - result[0] -> '1999' - result['month'] -> '12' - result.day -> '31' - 'month' in result -> True - 'minutes' in result -> False - result.dump() -> ['1999', '/', '12', '/', '31'] - - day: 31 - - month: 12 - - year: 1999 - """ - def __new__(cls, toklist=None, name=None, asList=True, modal=True): - if isinstance(toklist, cls): - return toklist - retobj = object.__new__(cls) - retobj.__doinit = True - return retobj - - # Performance tuning: we construct a *lot* of these, so keep this - # constructor as small and fast as possible - def __init__(self, toklist=None, name=None, asList=True, modal=True, isinstance=isinstance): - if self.__doinit: - self.__doinit = False - self.__name = None - self.__parent = None - self.__accumNames = {} - self.__asList = asList - self.__modal = modal - if toklist is None: - toklist = [] - if isinstance(toklist, list): - self.__toklist = toklist[:] - elif isinstance(toklist, _generatorType): - self.__toklist = list(toklist) - else: - self.__toklist = [toklist] - self.__tokdict = dict() - - if name is not None and name: - if not modal: - self.__accumNames[name] = 0 - if isinstance(name, int): - name = _ustr(name) # will always return a str, but use _ustr for consistency - self.__name = name - if not (isinstance(toklist, (type(None), basestring, list)) and toklist in (None, '', [])): - if isinstance(toklist, basestring): - toklist = [toklist] - if asList: - if isinstance(toklist, ParseResults): - self[name] = _ParseResultsWithOffset(ParseResults(toklist.__toklist), 0) - else: - self[name] = _ParseResultsWithOffset(ParseResults(toklist[0]), 0) - self[name].__name = name - else: - try: - self[name] = toklist[0] - except (KeyError, TypeError, IndexError): - self[name] = toklist - - def __getitem__(self, i): - if isinstance(i, (int, slice)): - return self.__toklist[i] - else: - if i not in self.__accumNames: - return self.__tokdict[i][-1][0] - else: - return ParseResults([v[0] for v in self.__tokdict[i]]) - - def __setitem__(self, k, v, isinstance=isinstance): - if isinstance(v, _ParseResultsWithOffset): - self.__tokdict[k] = self.__tokdict.get(k, list()) + [v] - sub = v[0] - elif isinstance(k, (int, slice)): - self.__toklist[k] = v - sub = v - else: - self.__tokdict[k] = self.__tokdict.get(k, list()) + [_ParseResultsWithOffset(v, 0)] - sub = v - if isinstance(sub, ParseResults): - sub.__parent = wkref(self) - - def __delitem__(self, i): - if isinstance(i, (int, slice)): - mylen = len(self.__toklist) - del self.__toklist[i] - - # convert int to slice - if isinstance(i, int): - if i < 0: - i += mylen - i = slice(i, i + 1) - # get removed indices - removed = list(range(*i.indices(mylen))) - removed.reverse() - # fixup indices in token dictionary - for name, occurrences in self.__tokdict.items(): - for j in removed: - for k, (value, position) in enumerate(occurrences): - occurrences[k] = _ParseResultsWithOffset(value, position - (position > j)) - else: - del self.__tokdict[i] - - def __contains__(self, k): - return k in self.__tokdict - - def __len__(self): - return len(self.__toklist) - - def __bool__(self): - return (not not self.__toklist) - __nonzero__ = __bool__ - - def __iter__(self): - return iter(self.__toklist) - - def __reversed__(self): - return iter(self.__toklist[::-1]) - - def _iterkeys(self): - if hasattr(self.__tokdict, "iterkeys"): - return self.__tokdict.iterkeys() - else: - return iter(self.__tokdict) - - def _itervalues(self): - return (self[k] for k in self._iterkeys()) - - def _iteritems(self): - return ((k, self[k]) for k in self._iterkeys()) - - if PY_3: - keys = _iterkeys - """Returns an iterator of all named result keys.""" - - values = _itervalues - """Returns an iterator of all named result values.""" - - items = _iteritems - """Returns an iterator of all named result key-value tuples.""" - - else: - iterkeys = _iterkeys - """Returns an iterator of all named result keys (Python 2.x only).""" - - itervalues = _itervalues - """Returns an iterator of all named result values (Python 2.x only).""" - - iteritems = _iteritems - """Returns an iterator of all named result key-value tuples (Python 2.x only).""" - - def keys(self): - """Returns all named result keys (as a list in Python 2.x, as an iterator in Python 3.x).""" - return list(self.iterkeys()) - - def values(self): - """Returns all named result values (as a list in Python 2.x, as an iterator in Python 3.x).""" - return list(self.itervalues()) - - def items(self): - """Returns all named result key-values (as a list of tuples in Python 2.x, as an iterator in Python 3.x).""" - return list(self.iteritems()) - - def haskeys(self): - """Since keys() returns an iterator, this method is helpful in bypassing - code that looks for the existence of any defined results names.""" - return bool(self.__tokdict) - - def pop(self, *args, **kwargs): - """ - Removes and returns item at specified index (default= ``last``). - Supports both ``list`` and ``dict`` semantics for ``pop()``. If - passed no argument or an integer argument, it will use ``list`` - semantics and pop tokens from the list of parsed tokens. If passed - a non-integer argument (most likely a string), it will use ``dict`` - semantics and pop the corresponding value from any defined results - names. A second default return value argument is supported, just as in - ``dict.pop()``. - - Example:: - - def remove_first(tokens): - tokens.pop(0) - print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] - print(OneOrMore(Word(nums)).addParseAction(remove_first).parseString("0 123 321")) # -> ['123', '321'] - - label = Word(alphas) - patt = label("LABEL") + OneOrMore(Word(nums)) - print(patt.parseString("AAB 123 321").dump()) - - # Use pop() in a parse action to remove named result (note that corresponding value is not - # removed from list form of results) - def remove_LABEL(tokens): - tokens.pop("LABEL") - return tokens - patt.addParseAction(remove_LABEL) - print(patt.parseString("AAB 123 321").dump()) - - prints:: - - ['AAB', '123', '321'] - - LABEL: AAB - - ['AAB', '123', '321'] - """ - if not args: - args = [-1] - for k, v in kwargs.items(): - if k == 'default': - args = (args[0], v) - else: - raise TypeError("pop() got an unexpected keyword argument '%s'" % k) - if (isinstance(args[0], int) - or len(args) == 1 - or args[0] in self): - index = args[0] - ret = self[index] - del self[index] - return ret - else: - defaultvalue = args[1] - return defaultvalue - - def get(self, key, defaultValue=None): - """ - Returns named result matching the given key, or if there is no - such name, then returns the given ``defaultValue`` or ``None`` if no - ``defaultValue`` is specified. - - Similar to ``dict.get()``. - - Example:: - - integer = Word(nums) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - result = date_str.parseString("1999/12/31") - print(result.get("year")) # -> '1999' - print(result.get("hour", "not specified")) # -> 'not specified' - print(result.get("hour")) # -> None - """ - if key in self: - return self[key] - else: - return defaultValue - - def insert(self, index, insStr): - """ - Inserts new element at location index in the list of parsed tokens. - - Similar to ``list.insert()``. - - Example:: - - print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] - - # use a parse action to insert the parse location in the front of the parsed results - def insert_locn(locn, tokens): - tokens.insert(0, locn) - print(OneOrMore(Word(nums)).addParseAction(insert_locn).parseString("0 123 321")) # -> [0, '0', '123', '321'] - """ - self.__toklist.insert(index, insStr) - # fixup indices in token dictionary - for name, occurrences in self.__tokdict.items(): - for k, (value, position) in enumerate(occurrences): - occurrences[k] = _ParseResultsWithOffset(value, position + (position > index)) - - def append(self, item): - """ - Add single element to end of ParseResults list of elements. - - Example:: - - print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321'] - - # use a parse action to compute the sum of the parsed integers, and add it to the end - def append_sum(tokens): - tokens.append(sum(map(int, tokens))) - print(OneOrMore(Word(nums)).addParseAction(append_sum).parseString("0 123 321")) # -> ['0', '123', '321', 444] - """ - self.__toklist.append(item) - - def extend(self, itemseq): - """ - Add sequence of elements to end of ParseResults list of elements. - - Example:: - - patt = OneOrMore(Word(alphas)) - - # use a parse action to append the reverse of the matched strings, to make a palindrome - def make_palindrome(tokens): - tokens.extend(reversed([t[::-1] for t in tokens])) - return ''.join(tokens) - print(patt.addParseAction(make_palindrome).parseString("lskdj sdlkjf lksd")) # -> 'lskdjsdlkjflksddsklfjkldsjdksl' - """ - if isinstance(itemseq, ParseResults): - self.__iadd__(itemseq) - else: - self.__toklist.extend(itemseq) - - def clear(self): - """ - Clear all elements and results names. - """ - del self.__toklist[:] - self.__tokdict.clear() - - def __getattr__(self, name): - try: - return self[name] - except KeyError: - return "" - - def __add__(self, other): - ret = self.copy() - ret += other - return ret - - def __iadd__(self, other): - if other.__tokdict: - offset = len(self.__toklist) - addoffset = lambda a: offset if a < 0 else a + offset - otheritems = other.__tokdict.items() - otherdictitems = [(k, _ParseResultsWithOffset(v[0], addoffset(v[1]))) - for k, vlist in otheritems for v in vlist] - for k, v in otherdictitems: - self[k] = v - if isinstance(v[0], ParseResults): - v[0].__parent = wkref(self) - - self.__toklist += other.__toklist - self.__accumNames.update(other.__accumNames) - return self - - def __radd__(self, other): - if isinstance(other, int) and other == 0: - # useful for merging many ParseResults using sum() builtin - return self.copy() - else: - # this may raise a TypeError - so be it - return other + self - - def __repr__(self): - return "(%s, %s)" % (repr(self.__toklist), repr(self.__tokdict)) - - def __str__(self): - return '[' + ', '.join(_ustr(i) if isinstance(i, ParseResults) else repr(i) for i in self.__toklist) + ']' - - def _asStringList(self, sep=''): - out = [] - for item in self.__toklist: - if out and sep: - out.append(sep) - if isinstance(item, ParseResults): - out += item._asStringList() - else: - out.append(_ustr(item)) - return out - - def asList(self): - """ - Returns the parse results as a nested list of matching tokens, all converted to strings. - - Example:: - - patt = OneOrMore(Word(alphas)) - result = patt.parseString("sldkj lsdkj sldkj") - # even though the result prints in string-like form, it is actually a pyparsing ParseResults - print(type(result), result) # -> <class 'pyparsing.ParseResults'> ['sldkj', 'lsdkj', 'sldkj'] - - # Use asList() to create an actual list - result_list = result.asList() - print(type(result_list), result_list) # -> <class 'list'> ['sldkj', 'lsdkj', 'sldkj'] - """ - return [res.asList() if isinstance(res, ParseResults) else res for res in self.__toklist] - - def asDict(self): - """ - Returns the named parse results as a nested dictionary. - - Example:: - - integer = Word(nums) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - result = date_str.parseString('12/31/1999') - print(type(result), repr(result)) # -> <class 'pyparsing.ParseResults'> (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]}) - - result_dict = result.asDict() - print(type(result_dict), repr(result_dict)) # -> <class 'dict'> {'day': '1999', 'year': '12', 'month': '31'} - - # even though a ParseResults supports dict-like access, sometime you just need to have a dict - import json - print(json.dumps(result)) # -> Exception: TypeError: ... is not JSON serializable - print(json.dumps(result.asDict())) # -> {"month": "31", "day": "1999", "year": "12"} - """ - if PY_3: - item_fn = self.items - else: - item_fn = self.iteritems - - def toItem(obj): - if isinstance(obj, ParseResults): - if obj.haskeys(): - return obj.asDict() - else: - return [toItem(v) for v in obj] - else: - return obj - - return dict((k, toItem(v)) for k, v in item_fn()) - - def copy(self): - """ - Returns a new copy of a :class:`ParseResults` object. - """ - ret = ParseResults(self.__toklist) - ret.__tokdict = dict(self.__tokdict.items()) - ret.__parent = self.__parent - ret.__accumNames.update(self.__accumNames) - ret.__name = self.__name - return ret - - def asXML(self, doctag=None, namedItemsOnly=False, indent="", formatted=True): - """ - (Deprecated) Returns the parse results as XML. Tags are created for tokens and lists that have defined results names. - """ - nl = "\n" - out = [] - namedItems = dict((v[1], k) for (k, vlist) in self.__tokdict.items() - for v in vlist) - nextLevelIndent = indent + " " - - # collapse out indents if formatting is not desired - if not formatted: - indent = "" - nextLevelIndent = "" - nl = "" - - selfTag = None - if doctag is not None: - selfTag = doctag - else: - if self.__name: - selfTag = self.__name - - if not selfTag: - if namedItemsOnly: - return "" - else: - selfTag = "ITEM" - - out += [nl, indent, "<", selfTag, ">"] - - for i, res in enumerate(self.__toklist): - if isinstance(res, ParseResults): - if i in namedItems: - out += [res.asXML(namedItems[i], - namedItemsOnly and doctag is None, - nextLevelIndent, - formatted)] - else: - out += [res.asXML(None, - namedItemsOnly and doctag is None, - nextLevelIndent, - formatted)] - else: - # individual token, see if there is a name for it - resTag = None - if i in namedItems: - resTag = namedItems[i] - if not resTag: - if namedItemsOnly: - continue - else: - resTag = "ITEM" - xmlBodyText = _xml_escape(_ustr(res)) - out += [nl, nextLevelIndent, "<", resTag, ">", - xmlBodyText, - "</", resTag, ">"] - - out += [nl, indent, "</", selfTag, ">"] - return "".join(out) - - def __lookup(self, sub): - for k, vlist in self.__tokdict.items(): - for v, loc in vlist: - if sub is v: - return k - return None - - def getName(self): - r""" - Returns the results name for this token expression. Useful when several - different expressions might match at a particular location. - - Example:: - - integer = Word(nums) - ssn_expr = Regex(r"\d\d\d-\d\d-\d\d\d\d") - house_number_expr = Suppress('#') + Word(nums, alphanums) - user_data = (Group(house_number_expr)("house_number") - | Group(ssn_expr)("ssn") - | Group(integer)("age")) - user_info = OneOrMore(user_data) - - result = user_info.parseString("22 111-22-3333 #221B") - for item in result: - print(item.getName(), ':', item[0]) - - prints:: - - age : 22 - ssn : 111-22-3333 - house_number : 221B - """ - if self.__name: - return self.__name - elif self.__parent: - par = self.__parent() - if par: - return par.__lookup(self) - else: - return None - elif (len(self) == 1 - and len(self.__tokdict) == 1 - and next(iter(self.__tokdict.values()))[0][1] in (0, -1)): - return next(iter(self.__tokdict.keys())) - else: - return None - - def dump(self, indent='', full=True, include_list=True, _depth=0): - """ - Diagnostic method for listing out the contents of - a :class:`ParseResults`. Accepts an optional ``indent`` argument so - that this string can be embedded in a nested display of other data. - - Example:: - - integer = Word(nums) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - result = date_str.parseString('12/31/1999') - print(result.dump()) - - prints:: - - ['12', '/', '31', '/', '1999'] - - day: 1999 - - month: 31 - - year: 12 - """ - out = [] - NL = '\n' - if include_list: - out.append(indent + _ustr(self.asList())) - else: - out.append('') - - if full: - if self.haskeys(): - items = sorted((str(k), v) for k, v in self.items()) - for k, v in items: - if out: - out.append(NL) - out.append("%s%s- %s: " % (indent, (' ' * _depth), k)) - if isinstance(v, ParseResults): - if v: - out.append(v.dump(indent=indent, full=full, include_list=include_list, _depth=_depth + 1)) - else: - out.append(_ustr(v)) - else: - out.append(repr(v)) - elif any(isinstance(vv, ParseResults) for vv in self): - v = self - for i, vv in enumerate(v): - if isinstance(vv, ParseResults): - out.append("\n%s%s[%d]:\n%s%s%s" % (indent, - (' ' * (_depth)), - i, - indent, - (' ' * (_depth + 1)), - vv.dump(indent=indent, - full=full, - include_list=include_list, - _depth=_depth + 1))) - else: - out.append("\n%s%s[%d]:\n%s%s%s" % (indent, - (' ' * (_depth)), - i, - indent, - (' ' * (_depth + 1)), - _ustr(vv))) - - return "".join(out) - - def pprint(self, *args, **kwargs): - """ - Pretty-printer for parsed results as a list, using the - `pprint <https://docs.python.org/3/library/pprint.html>`_ module. - Accepts additional positional or keyword args as defined for - `pprint.pprint <https://docs.python.org/3/library/pprint.html#pprint.pprint>`_ . - - Example:: - - ident = Word(alphas, alphanums) - num = Word(nums) - func = Forward() - term = ident | num | Group('(' + func + ')') - func <<= ident + Group(Optional(delimitedList(term))) - result = func.parseString("fna a,b,(fnb c,d,200),100") - result.pprint(width=40) - - prints:: - - ['fna', - ['a', - 'b', - ['(', 'fnb', ['c', 'd', '200'], ')'], - '100']] - """ - pprint.pprint(self.asList(), *args, **kwargs) - - # add support for pickle protocol - def __getstate__(self): - return (self.__toklist, - (self.__tokdict.copy(), - self.__parent is not None and self.__parent() or None, - self.__accumNames, - self.__name)) - - def __setstate__(self, state): - self.__toklist = state[0] - self.__tokdict, par, inAccumNames, self.__name = state[1] - self.__accumNames = {} - self.__accumNames.update(inAccumNames) - if par is not None: - self.__parent = wkref(par) - else: - self.__parent = None - - def __getnewargs__(self): - return self.__toklist, self.__name, self.__asList, self.__modal - - def __dir__(self): - return dir(type(self)) + list(self.keys()) - - @classmethod - def from_dict(cls, other, name=None): - """ - Helper classmethod to construct a ParseResults from a dict, preserving the - name-value relations as results names. If an optional 'name' argument is - given, a nested ParseResults will be returned - """ - def is_iterable(obj): - try: - iter(obj) - except Exception: - return False - else: - if PY_3: - return not isinstance(obj, (str, bytes)) - else: - return not isinstance(obj, basestring) - - ret = cls([]) - for k, v in other.items(): - if isinstance(v, Mapping): - ret += cls.from_dict(v, name=k) - else: - ret += cls([v], name=k, asList=is_iterable(v)) - if name is not None: - ret = cls([ret], name=name) - return ret - -MutableMapping.register(ParseResults) - -def col (loc, strg): - """Returns current column within a string, counting newlines as line separators. - The first column is number 1. - - Note: the default parsing behavior is to expand tabs in the input string - before starting the parsing process. See - :class:`ParserElement.parseString` for more - information on parsing strings containing ``<TAB>`` s, and suggested - methods to maintain a consistent view of the parsed string, the parse - location, and line and column positions within the parsed string. - """ - s = strg - return 1 if 0 < loc < len(s) and s[loc-1] == '\n' else loc - s.rfind("\n", 0, loc) - -def lineno(loc, strg): - """Returns current line number within a string, counting newlines as line separators. - The first line is number 1. - - Note - the default parsing behavior is to expand tabs in the input string - before starting the parsing process. See :class:`ParserElement.parseString` - for more information on parsing strings containing ``<TAB>`` s, and - suggested methods to maintain a consistent view of the parsed string, the - parse location, and line and column positions within the parsed string. - """ - return strg.count("\n", 0, loc) + 1 - -def line(loc, strg): - """Returns the line of text containing loc within a string, counting newlines as line separators. - """ - lastCR = strg.rfind("\n", 0, loc) - nextCR = strg.find("\n", loc) - if nextCR >= 0: - return strg[lastCR + 1:nextCR] - else: - return strg[lastCR + 1:] - -def _defaultStartDebugAction(instring, loc, expr): - print(("Match " + _ustr(expr) + " at loc " + _ustr(loc) + "(%d,%d)" % (lineno(loc, instring), col(loc, instring)))) - -def _defaultSuccessDebugAction(instring, startloc, endloc, expr, toks): - print("Matched " + _ustr(expr) + " -> " + str(toks.asList())) - -def _defaultExceptionDebugAction(instring, loc, expr, exc): - print("Exception raised:" + _ustr(exc)) - -def nullDebugAction(*args): - """'Do-nothing' debug action, to suppress debugging output during parsing.""" - pass - -# Only works on Python 3.x - nonlocal is toxic to Python 2 installs -#~ 'decorator to trim function calls to match the arity of the target' -#~ def _trim_arity(func, maxargs=3): - #~ if func in singleArgBuiltins: - #~ return lambda s,l,t: func(t) - #~ limit = 0 - #~ foundArity = False - #~ def wrapper(*args): - #~ nonlocal limit,foundArity - #~ while 1: - #~ try: - #~ ret = func(*args[limit:]) - #~ foundArity = True - #~ return ret - #~ except TypeError: - #~ if limit == maxargs or foundArity: - #~ raise - #~ limit += 1 - #~ continue - #~ return wrapper - -# this version is Python 2.x-3.x cross-compatible -'decorator to trim function calls to match the arity of the target' -def _trim_arity(func, maxargs=2): - if func in singleArgBuiltins: - return lambda s, l, t: func(t) - limit = [0] - foundArity = [False] - - # traceback return data structure changed in Py3.5 - normalize back to plain tuples - if system_version[:2] >= (3, 5): - def extract_stack(limit=0): - # special handling for Python 3.5.0 - extra deep call stack by 1 - offset = -3 if system_version == (3, 5, 0) else -2 - frame_summary = traceback.extract_stack(limit=-offset + limit - 1)[offset] - return [frame_summary[:2]] - def extract_tb(tb, limit=0): - frames = traceback.extract_tb(tb, limit=limit) - frame_summary = frames[-1] - return [frame_summary[:2]] - else: - extract_stack = traceback.extract_stack - extract_tb = traceback.extract_tb - - # synthesize what would be returned by traceback.extract_stack at the call to - # user's parse action 'func', so that we don't incur call penalty at parse time - - LINE_DIFF = 6 - # IF ANY CODE CHANGES, EVEN JUST COMMENTS OR BLANK LINES, BETWEEN THE NEXT LINE AND - # THE CALL TO FUNC INSIDE WRAPPER, LINE_DIFF MUST BE MODIFIED!!!! - this_line = extract_stack(limit=2)[-1] - pa_call_line_synth = (this_line[0], this_line[1] + LINE_DIFF) - - def wrapper(*args): - while 1: - try: - ret = func(*args[limit[0]:]) - foundArity[0] = True - return ret - except TypeError: - # re-raise TypeErrors if they did not come from our arity testing - if foundArity[0]: - raise - else: - try: - tb = sys.exc_info()[-1] - if not extract_tb(tb, limit=2)[-1][:2] == pa_call_line_synth: - raise - finally: - try: - del tb - except NameError: - pass - - if limit[0] <= maxargs: - limit[0] += 1 - continue - raise - - # copy func name to wrapper for sensible debug output - func_name = "<parse action>" - try: - func_name = getattr(func, '__name__', - getattr(func, '__class__').__name__) - except Exception: - func_name = str(func) - wrapper.__name__ = func_name - - return wrapper - - -class ParserElement(object): - """Abstract base level parser element class.""" - DEFAULT_WHITE_CHARS = " \n\t\r" - verbose_stacktrace = False - - @staticmethod - def setDefaultWhitespaceChars(chars): - r""" - Overrides the default whitespace chars - - Example:: - - # default whitespace chars are space, <TAB> and newline - OneOrMore(Word(alphas)).parseString("abc def\nghi jkl") # -> ['abc', 'def', 'ghi', 'jkl'] - - # change to just treat newline as significant - ParserElement.setDefaultWhitespaceChars(" \t") - OneOrMore(Word(alphas)).parseString("abc def\nghi jkl") # -> ['abc', 'def'] - """ - ParserElement.DEFAULT_WHITE_CHARS = chars - - @staticmethod - def inlineLiteralsUsing(cls): - """ - Set class to be used for inclusion of string literals into a parser. - - Example:: - - # default literal class used is Literal - integer = Word(nums) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - date_str.parseString("1999/12/31") # -> ['1999', '/', '12', '/', '31'] - - - # change to Suppress - ParserElement.inlineLiteralsUsing(Suppress) - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - - date_str.parseString("1999/12/31") # -> ['1999', '12', '31'] - """ - ParserElement._literalStringClass = cls - - @classmethod - def _trim_traceback(cls, tb): - while tb.tb_next: - tb = tb.tb_next - return tb - - def __init__(self, savelist=False): - self.parseAction = list() - self.failAction = None - # ~ self.name = "<unknown>" # don't define self.name, let subclasses try/except upcall - self.strRepr = None - self.resultsName = None - self.saveAsList = savelist - self.skipWhitespace = True - self.whiteChars = set(ParserElement.DEFAULT_WHITE_CHARS) - self.copyDefaultWhiteChars = True - self.mayReturnEmpty = False # used when checking for left-recursion - self.keepTabs = False - self.ignoreExprs = list() - self.debug = False - self.streamlined = False - self.mayIndexError = True # used to optimize exception handling for subclasses that don't advance parse index - self.errmsg = "" - self.modalResults = True # used to mark results names as modal (report only last) or cumulative (list all) - self.debugActions = (None, None, None) # custom debug actions - self.re = None - self.callPreparse = True # used to avoid redundant calls to preParse - self.callDuringTry = False - - def copy(self): - """ - Make a copy of this :class:`ParserElement`. Useful for defining - different parse actions for the same parsing pattern, using copies of - the original parse element. - - Example:: - - integer = Word(nums).setParseAction(lambda toks: int(toks[0])) - integerK = integer.copy().addParseAction(lambda toks: toks[0] * 1024) + Suppress("K") - integerM = integer.copy().addParseAction(lambda toks: toks[0] * 1024 * 1024) + Suppress("M") - - print(OneOrMore(integerK | integerM | integer).parseString("5K 100 640K 256M")) - - prints:: - - [5120, 100, 655360, 268435456] - - Equivalent form of ``expr.copy()`` is just ``expr()``:: - - integerM = integer().addParseAction(lambda toks: toks[0] * 1024 * 1024) + Suppress("M") - """ - cpy = copy.copy(self) - cpy.parseAction = self.parseAction[:] - cpy.ignoreExprs = self.ignoreExprs[:] - if self.copyDefaultWhiteChars: - cpy.whiteChars = ParserElement.DEFAULT_WHITE_CHARS - return cpy - - def setName(self, name): - """ - Define name for this expression, makes debugging and exception messages clearer. - - Example:: - - Word(nums).parseString("ABC") # -> Exception: Expected W:(0123...) (at char 0), (line:1, col:1) - Word(nums).setName("integer").parseString("ABC") # -> Exception: Expected integer (at char 0), (line:1, col:1) - """ - self.name = name - self.errmsg = "Expected " + self.name - if __diag__.enable_debug_on_named_expressions: - self.setDebug() - return self - - def setResultsName(self, name, listAllMatches=False): - """ - Define name for referencing matching tokens as a nested attribute - of the returned parse results. - NOTE: this returns a *copy* of the original :class:`ParserElement` object; - this is so that the client can define a basic element, such as an - integer, and reference it in multiple places with different names. - - You can also set results names using the abbreviated syntax, - ``expr("name")`` in place of ``expr.setResultsName("name")`` - - see :class:`__call__`. - - Example:: - - date_str = (integer.setResultsName("year") + '/' - + integer.setResultsName("month") + '/' - + integer.setResultsName("day")) - - # equivalent form: - date_str = integer("year") + '/' + integer("month") + '/' + integer("day") - """ - return self._setResultsName(name, listAllMatches) - - def _setResultsName(self, name, listAllMatches=False): - newself = self.copy() - if name.endswith("*"): - name = name[:-1] - listAllMatches = True - newself.resultsName = name - newself.modalResults = not listAllMatches - return newself - - def setBreak(self, breakFlag=True): - """Method to invoke the Python pdb debugger when this element is - about to be parsed. Set ``breakFlag`` to True to enable, False to - disable. - """ - if breakFlag: - _parseMethod = self._parse - def breaker(instring, loc, doActions=True, callPreParse=True): - import pdb - # this call to pdb.set_trace() is intentional, not a checkin error - pdb.set_trace() - return _parseMethod(instring, loc, doActions, callPreParse) - breaker._originalParseMethod = _parseMethod - self._parse = breaker - else: - if hasattr(self._parse, "_originalParseMethod"): - self._parse = self._parse._originalParseMethod - return self - - def setParseAction(self, *fns, **kwargs): - """ - Define one or more actions to perform when successfully matching parse element definition. - Parse action fn is a callable method with 0-3 arguments, called as ``fn(s, loc, toks)`` , - ``fn(loc, toks)`` , ``fn(toks)`` , or just ``fn()`` , where: - - - s = the original string being parsed (see note below) - - loc = the location of the matching substring - - toks = a list of the matched tokens, packaged as a :class:`ParseResults` object - - If the functions in fns modify the tokens, they can return them as the return - value from fn, and the modified list of tokens will replace the original. - Otherwise, fn does not need to return any value. - - If None is passed as the parse action, all previously added parse actions for this - expression are cleared. - - Optional keyword arguments: - - callDuringTry = (default= ``False``) indicate if parse action should be run during lookaheads and alternate testing - - Note: the default parsing behavior is to expand tabs in the input string - before starting the parsing process. See :class:`parseString for more - information on parsing strings containing ``<TAB>`` s, and suggested - methods to maintain a consistent view of the parsed string, the parse - location, and line and column positions within the parsed string. - - Example:: - - integer = Word(nums) - date_str = integer + '/' + integer + '/' + integer - - date_str.parseString("1999/12/31") # -> ['1999', '/', '12', '/', '31'] - - # use parse action to convert to ints at parse time - integer = Word(nums).setParseAction(lambda toks: int(toks[0])) - date_str = integer + '/' + integer + '/' + integer - - # note that integer fields are now ints, not strings - date_str.parseString("1999/12/31") # -> [1999, '/', 12, '/', 31] - """ - if list(fns) == [None,]: - self.parseAction = [] - else: - if not all(callable(fn) for fn in fns): - raise TypeError("parse actions must be callable") - self.parseAction = list(map(_trim_arity, list(fns))) - self.callDuringTry = kwargs.get("callDuringTry", False) - return self - - def addParseAction(self, *fns, **kwargs): - """ - Add one or more parse actions to expression's list of parse actions. See :class:`setParseAction`. - - See examples in :class:`copy`. - """ - self.parseAction += list(map(_trim_arity, list(fns))) - self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False) - return self - - def addCondition(self, *fns, **kwargs): - """Add a boolean predicate function to expression's list of parse actions. See - :class:`setParseAction` for function call signatures. Unlike ``setParseAction``, - functions passed to ``addCondition`` need to return boolean success/fail of the condition. - - Optional keyword arguments: - - message = define a custom message to be used in the raised exception - - fatal = if True, will raise ParseFatalException to stop parsing immediately; otherwise will raise ParseException - - Example:: - - integer = Word(nums).setParseAction(lambda toks: int(toks[0])) - year_int = integer.copy() - year_int.addCondition(lambda toks: toks[0] >= 2000, message="Only support years 2000 and later") - date_str = year_int + '/' + integer + '/' + integer - - result = date_str.parseString("1999/12/31") # -> Exception: Only support years 2000 and later (at char 0), (line:1, col:1) - """ - for fn in fns: - self.parseAction.append(conditionAsParseAction(fn, message=kwargs.get('message'), - fatal=kwargs.get('fatal', False))) - - self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False) - return self - - def setFailAction(self, fn): - """Define action to perform if parsing fails at this expression. - Fail acton fn is a callable function that takes the arguments - ``fn(s, loc, expr, err)`` where: - - s = string being parsed - - loc = location where expression match was attempted and failed - - expr = the parse expression that failed - - err = the exception thrown - The function returns no value. It may throw :class:`ParseFatalException` - if it is desired to stop parsing immediately.""" - self.failAction = fn - return self - - def _skipIgnorables(self, instring, loc): - exprsFound = True - while exprsFound: - exprsFound = False - for e in self.ignoreExprs: - try: - while 1: - loc, dummy = e._parse(instring, loc) - exprsFound = True - except ParseException: - pass - return loc - - def preParse(self, instring, loc): - if self.ignoreExprs: - loc = self._skipIgnorables(instring, loc) - - if self.skipWhitespace: - wt = self.whiteChars - instrlen = len(instring) - while loc < instrlen and instring[loc] in wt: - loc += 1 - - return loc - - def parseImpl(self, instring, loc, doActions=True): - return loc, [] - - def postParse(self, instring, loc, tokenlist): - return tokenlist - - # ~ @profile - def _parseNoCache(self, instring, loc, doActions=True, callPreParse=True): - TRY, MATCH, FAIL = 0, 1, 2 - debugging = (self.debug) # and doActions) - - if debugging or self.failAction: - # ~ print ("Match", self, "at loc", loc, "(%d, %d)" % (lineno(loc, instring), col(loc, instring))) - if self.debugActions[TRY]: - self.debugActions[TRY](instring, loc, self) - try: - if callPreParse and self.callPreparse: - preloc = self.preParse(instring, loc) - else: - preloc = loc - tokensStart = preloc - if self.mayIndexError or preloc >= len(instring): - try: - loc, tokens = self.parseImpl(instring, preloc, doActions) - except IndexError: - raise ParseException(instring, len(instring), self.errmsg, self) - else: - loc, tokens = self.parseImpl(instring, preloc, doActions) - except Exception as err: - # ~ print ("Exception raised:", err) - if self.debugActions[FAIL]: - self.debugActions[FAIL](instring, tokensStart, self, err) - if self.failAction: - self.failAction(instring, tokensStart, self, err) - raise - else: - if callPreParse and self.callPreparse: - preloc = self.preParse(instring, loc) - else: - preloc = loc - tokensStart = preloc - if self.mayIndexError or preloc >= len(instring): - try: - loc, tokens = self.parseImpl(instring, preloc, doActions) - except IndexError: - raise ParseException(instring, len(instring), self.errmsg, self) - else: - loc, tokens = self.parseImpl(instring, preloc, doActions) - - tokens = self.postParse(instring, loc, tokens) - - retTokens = ParseResults(tokens, self.resultsName, asList=self.saveAsList, modal=self.modalResults) - if self.parseAction and (doActions or self.callDuringTry): - if debugging: - try: - for fn in self.parseAction: - try: - tokens = fn(instring, tokensStart, retTokens) - except IndexError as parse_action_exc: - exc = ParseException("exception raised in parse action") - exc.__cause__ = parse_action_exc - raise exc - - if tokens is not None and tokens is not retTokens: - retTokens = ParseResults(tokens, - self.resultsName, - asList=self.saveAsList and isinstance(tokens, (ParseResults, list)), - modal=self.modalResults) - except Exception as err: - # ~ print "Exception raised in user parse action:", err - if self.debugActions[FAIL]: - self.debugActions[FAIL](instring, tokensStart, self, err) - raise - else: - for fn in self.parseAction: - try: - tokens = fn(instring, tokensStart, retTokens) - except IndexError as parse_action_exc: - exc = ParseException("exception raised in parse action") - exc.__cause__ = parse_action_exc - raise exc - - if tokens is not None and tokens is not retTokens: - retTokens = ParseResults(tokens, - self.resultsName, - asList=self.saveAsList and isinstance(tokens, (ParseResults, list)), - modal=self.modalResults) - if debugging: - # ~ print ("Matched", self, "->", retTokens.asList()) - if self.debugActions[MATCH]: - self.debugActions[MATCH](instring, tokensStart, loc, self, retTokens) - - return loc, retTokens - - def tryParse(self, instring, loc): - try: - return self._parse(instring, loc, doActions=False)[0] - except ParseFatalException: - raise ParseException(instring, loc, self.errmsg, self) - - def canParseNext(self, instring, loc): - try: - self.tryParse(instring, loc) - except (ParseException, IndexError): - return False - else: - return True - - class _UnboundedCache(object): - def __init__(self): - cache = {} - self.not_in_cache = not_in_cache = object() - - def get(self, key): - return cache.get(key, not_in_cache) - - def set(self, key, value): - cache[key] = value - - def clear(self): - cache.clear() - - def cache_len(self): - return len(cache) - - self.get = types.MethodType(get, self) - self.set = types.MethodType(set, self) - self.clear = types.MethodType(clear, self) - self.__len__ = types.MethodType(cache_len, self) - - if _OrderedDict is not None: - class _FifoCache(object): - def __init__(self, size): - self.not_in_cache = not_in_cache = object() - - cache = _OrderedDict() - - def get(self, key): - return cache.get(key, not_in_cache) - - def set(self, key, value): - cache[key] = value - while len(cache) > size: - try: - cache.popitem(False) - except KeyError: - pass - - def clear(self): - cache.clear() - - def cache_len(self): - return len(cache) - - self.get = types.MethodType(get, self) - self.set = types.MethodType(set, self) - self.clear = types.MethodType(clear, self) - self.__len__ = types.MethodType(cache_len, self) - - else: - class _FifoCache(object): - def __init__(self, size): - self.not_in_cache = not_in_cache = object() - - cache = {} - key_fifo = collections.deque([], size) - - def get(self, key): - return cache.get(key, not_in_cache) - - def set(self, key, value): - cache[key] = value - while len(key_fifo) > size: - cache.pop(key_fifo.popleft(), None) - key_fifo.append(key) - - def clear(self): - cache.clear() - key_fifo.clear() - - def cache_len(self): - return len(cache) - - self.get = types.MethodType(get, self) - self.set = types.MethodType(set, self) - self.clear = types.MethodType(clear, self) - self.__len__ = types.MethodType(cache_len, self) - - # argument cache for optimizing repeated calls when backtracking through recursive expressions - packrat_cache = {} # this is set later by enabledPackrat(); this is here so that resetCache() doesn't fail - packrat_cache_lock = RLock() - packrat_cache_stats = [0, 0] - - # this method gets repeatedly called during backtracking with the same arguments - - # we can cache these arguments and save ourselves the trouble of re-parsing the contained expression - def _parseCache(self, instring, loc, doActions=True, callPreParse=True): - HIT, MISS = 0, 1 - lookup = (self, instring, loc, callPreParse, doActions) - with ParserElement.packrat_cache_lock: - cache = ParserElement.packrat_cache - value = cache.get(lookup) - if value is cache.not_in_cache: - ParserElement.packrat_cache_stats[MISS] += 1 - try: - value = self._parseNoCache(instring, loc, doActions, callPreParse) - except ParseBaseException as pe: - # cache a copy of the exception, without the traceback - cache.set(lookup, pe.__class__(*pe.args)) - raise - else: - cache.set(lookup, (value[0], value[1].copy())) - return value - else: - ParserElement.packrat_cache_stats[HIT] += 1 - if isinstance(value, Exception): - raise value - return value[0], value[1].copy() - - _parse = _parseNoCache - - @staticmethod - def resetCache(): - ParserElement.packrat_cache.clear() - ParserElement.packrat_cache_stats[:] = [0] * len(ParserElement.packrat_cache_stats) - - _packratEnabled = False - @staticmethod - def enablePackrat(cache_size_limit=128): - """Enables "packrat" parsing, which adds memoizing to the parsing logic. - Repeated parse attempts at the same string location (which happens - often in many complex grammars) can immediately return a cached value, - instead of re-executing parsing/validating code. Memoizing is done of - both valid results and parsing exceptions. - - Parameters: - - - cache_size_limit - (default= ``128``) - if an integer value is provided - will limit the size of the packrat cache; if None is passed, then - the cache size will be unbounded; if 0 is passed, the cache will - be effectively disabled. - - This speedup may break existing programs that use parse actions that - have side-effects. For this reason, packrat parsing is disabled when - you first import pyparsing. To activate the packrat feature, your - program must call the class method :class:`ParserElement.enablePackrat`. - For best results, call ``enablePackrat()`` immediately after - importing pyparsing. - - Example:: - - from pip._vendor import pyparsing - pyparsing.ParserElement.enablePackrat() - """ - if not ParserElement._packratEnabled: - ParserElement._packratEnabled = True - if cache_size_limit is None: - ParserElement.packrat_cache = ParserElement._UnboundedCache() - else: - ParserElement.packrat_cache = ParserElement._FifoCache(cache_size_limit) - ParserElement._parse = ParserElement._parseCache - - def parseString(self, instring, parseAll=False): - """ - Execute the parse expression with the given string. - This is the main interface to the client code, once the complete - expression has been built. - - Returns the parsed data as a :class:`ParseResults` object, which may be - accessed as a list, or as a dict or object with attributes if the given parser - includes results names. - - If you want the grammar to require that the entire input string be - successfully parsed, then set ``parseAll`` to True (equivalent to ending - the grammar with ``StringEnd()``). - - Note: ``parseString`` implicitly calls ``expandtabs()`` on the input string, - in order to report proper column numbers in parse actions. - If the input string contains tabs and - the grammar uses parse actions that use the ``loc`` argument to index into the - string being parsed, you can ensure you have a consistent view of the input - string by: - - - calling ``parseWithTabs`` on your grammar before calling ``parseString`` - (see :class:`parseWithTabs`) - - define your parse action using the full ``(s, loc, toks)`` signature, and - reference the input string using the parse action's ``s`` argument - - explictly expand the tabs in your input string before calling - ``parseString`` - - Example:: - - Word('a').parseString('aaaaabaaa') # -> ['aaaaa'] - Word('a').parseString('aaaaabaaa', parseAll=True) # -> Exception: Expected end of text - """ - ParserElement.resetCache() - if not self.streamlined: - self.streamline() - # ~ self.saveAsList = True - for e in self.ignoreExprs: - e.streamline() - if not self.keepTabs: - instring = instring.expandtabs() - try: - loc, tokens = self._parse(instring, 0) - if parseAll: - loc = self.preParse(instring, loc) - se = Empty() + StringEnd() - se._parse(instring, loc) - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clearing out pyparsing internal stack trace - if getattr(exc, '__traceback__', None) is not None: - exc.__traceback__ = self._trim_traceback(exc.__traceback__) - raise exc - else: - return tokens - - def scanString(self, instring, maxMatches=_MAX_INT, overlap=False): - """ - Scan the input string for expression matches. Each match will return the - matching tokens, start location, and end location. May be called with optional - ``maxMatches`` argument, to clip scanning after 'n' matches are found. If - ``overlap`` is specified, then overlapping matches will be reported. - - Note that the start and end locations are reported relative to the string - being parsed. See :class:`parseString` for more information on parsing - strings with embedded tabs. - - Example:: - - source = "sldjf123lsdjjkf345sldkjf879lkjsfd987" - print(source) - for tokens, start, end in Word(alphas).scanString(source): - print(' '*start + '^'*(end-start)) - print(' '*start + tokens[0]) - - prints:: - - sldjf123lsdjjkf345sldkjf879lkjsfd987 - ^^^^^ - sldjf - ^^^^^^^ - lsdjjkf - ^^^^^^ - sldkjf - ^^^^^^ - lkjsfd - """ - if not self.streamlined: - self.streamline() - for e in self.ignoreExprs: - e.streamline() - - if not self.keepTabs: - instring = _ustr(instring).expandtabs() - instrlen = len(instring) - loc = 0 - preparseFn = self.preParse - parseFn = self._parse - ParserElement.resetCache() - matches = 0 - try: - while loc <= instrlen and matches < maxMatches: - try: - preloc = preparseFn(instring, loc) - nextLoc, tokens = parseFn(instring, preloc, callPreParse=False) - except ParseException: - loc = preloc + 1 - else: - if nextLoc > loc: - matches += 1 - yield tokens, preloc, nextLoc - if overlap: - nextloc = preparseFn(instring, loc) - if nextloc > loc: - loc = nextLoc - else: - loc += 1 - else: - loc = nextLoc - else: - loc = preloc + 1 - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clearing out pyparsing internal stack trace - if getattr(exc, '__traceback__', None) is not None: - exc.__traceback__ = self._trim_traceback(exc.__traceback__) - raise exc - - def transformString(self, instring): - """ - Extension to :class:`scanString`, to modify matching text with modified tokens that may - be returned from a parse action. To use ``transformString``, define a grammar and - attach a parse action to it that modifies the returned token list. - Invoking ``transformString()`` on a target string will then scan for matches, - and replace the matched text patterns according to the logic in the parse - action. ``transformString()`` returns the resulting transformed string. - - Example:: - - wd = Word(alphas) - wd.setParseAction(lambda toks: toks[0].title()) - - print(wd.transformString("now is the winter of our discontent made glorious summer by this sun of york.")) - - prints:: - - Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York. - """ - out = [] - lastE = 0 - # force preservation of <TAB>s, to minimize unwanted transformation of string, and to - # keep string locs straight between transformString and scanString - self.keepTabs = True - try: - for t, s, e in self.scanString(instring): - out.append(instring[lastE:s]) - if t: - if isinstance(t, ParseResults): - out += t.asList() - elif isinstance(t, list): - out += t - else: - out.append(t) - lastE = e - out.append(instring[lastE:]) - out = [o for o in out if o] - return "".join(map(_ustr, _flatten(out))) - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clearing out pyparsing internal stack trace - if getattr(exc, '__traceback__', None) is not None: - exc.__traceback__ = self._trim_traceback(exc.__traceback__) - raise exc - - def searchString(self, instring, maxMatches=_MAX_INT): - """ - Another extension to :class:`scanString`, simplifying the access to the tokens found - to match the given parse expression. May be called with optional - ``maxMatches`` argument, to clip searching after 'n' matches are found. - - Example:: - - # a capitalized word starts with an uppercase letter, followed by zero or more lowercase letters - cap_word = Word(alphas.upper(), alphas.lower()) - - print(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity")) - - # the sum() builtin can be used to merge results into a single ParseResults object - print(sum(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity"))) - - prints:: - - [['More'], ['Iron'], ['Lead'], ['Gold'], ['I'], ['Electricity']] - ['More', 'Iron', 'Lead', 'Gold', 'I', 'Electricity'] - """ - try: - return ParseResults([t for t, s, e in self.scanString(instring, maxMatches)]) - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clearing out pyparsing internal stack trace - if getattr(exc, '__traceback__', None) is not None: - exc.__traceback__ = self._trim_traceback(exc.__traceback__) - raise exc - - def split(self, instring, maxsplit=_MAX_INT, includeSeparators=False): - """ - Generator method to split a string using the given expression as a separator. - May be called with optional ``maxsplit`` argument, to limit the number of splits; - and the optional ``includeSeparators`` argument (default= ``False``), if the separating - matching text should be included in the split results. - - Example:: - - punc = oneOf(list(".,;:/-!?")) - print(list(punc.split("This, this?, this sentence, is badly punctuated!"))) - - prints:: - - ['This', ' this', '', ' this sentence', ' is badly punctuated', ''] - """ - splits = 0 - last = 0 - for t, s, e in self.scanString(instring, maxMatches=maxsplit): - yield instring[last:s] - if includeSeparators: - yield t[0] - last = e - yield instring[last:] - - def __add__(self, other): - """ - Implementation of + operator - returns :class:`And`. Adding strings to a ParserElement - converts them to :class:`Literal`s by default. - - Example:: - - greet = Word(alphas) + "," + Word(alphas) + "!" - hello = "Hello, World!" - print (hello, "->", greet.parseString(hello)) - - prints:: - - Hello, World! -> ['Hello', ',', 'World', '!'] - - ``...`` may be used as a parse expression as a short form of :class:`SkipTo`. - - Literal('start') + ... + Literal('end') - - is equivalent to: - - Literal('start') + SkipTo('end')("_skipped*") + Literal('end') - - Note that the skipped text is returned with '_skipped' as a results name, - and to support having multiple skips in the same parser, the value returned is - a list of all skipped text. - """ - if other is Ellipsis: - return _PendingSkip(self) - - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return And([self, other]) - - def __radd__(self, other): - """ - Implementation of + operator when left operand is not a :class:`ParserElement` - """ - if other is Ellipsis: - return SkipTo(self)("_skipped*") + self - - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return other + self - - def __sub__(self, other): - """ - Implementation of - operator, returns :class:`And` with error stop - """ - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return self + And._ErrorStop() + other - - def __rsub__(self, other): - """ - Implementation of - operator when left operand is not a :class:`ParserElement` - """ - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return other - self - - def __mul__(self, other): - """ - Implementation of * operator, allows use of ``expr * 3`` in place of - ``expr + expr + expr``. Expressions may also me multiplied by a 2-integer - tuple, similar to ``{min, max}`` multipliers in regular expressions. Tuples - may also include ``None`` as in: - - ``expr*(n, None)`` or ``expr*(n, )`` is equivalent - to ``expr*n + ZeroOrMore(expr)`` - (read as "at least n instances of ``expr``") - - ``expr*(None, n)`` is equivalent to ``expr*(0, n)`` - (read as "0 to n instances of ``expr``") - - ``expr*(None, None)`` is equivalent to ``ZeroOrMore(expr)`` - - ``expr*(1, None)`` is equivalent to ``OneOrMore(expr)`` - - Note that ``expr*(None, n)`` does not raise an exception if - more than n exprs exist in the input stream; that is, - ``expr*(None, n)`` does not enforce a maximum number of expr - occurrences. If this behavior is desired, then write - ``expr*(None, n) + ~expr`` - """ - if other is Ellipsis: - other = (0, None) - elif isinstance(other, tuple) and other[:1] == (Ellipsis,): - other = ((0, ) + other[1:] + (None,))[:2] - - if isinstance(other, int): - minElements, optElements = other, 0 - elif isinstance(other, tuple): - other = tuple(o if o is not Ellipsis else None for o in other) - other = (other + (None, None))[:2] - if other[0] is None: - other = (0, other[1]) - if isinstance(other[0], int) and other[1] is None: - if other[0] == 0: - return ZeroOrMore(self) - if other[0] == 1: - return OneOrMore(self) - else: - return self * other[0] + ZeroOrMore(self) - elif isinstance(other[0], int) and isinstance(other[1], int): - minElements, optElements = other - optElements -= minElements - else: - raise TypeError("cannot multiply 'ParserElement' and ('%s', '%s') objects", type(other[0]), type(other[1])) - else: - raise TypeError("cannot multiply 'ParserElement' and '%s' objects", type(other)) - - if minElements < 0: - raise ValueError("cannot multiply ParserElement by negative value") - if optElements < 0: - raise ValueError("second tuple value must be greater or equal to first tuple value") - if minElements == optElements == 0: - raise ValueError("cannot multiply ParserElement by 0 or (0, 0)") - - if optElements: - def makeOptionalList(n): - if n > 1: - return Optional(self + makeOptionalList(n - 1)) - else: - return Optional(self) - if minElements: - if minElements == 1: - ret = self + makeOptionalList(optElements) - else: - ret = And([self] * minElements) + makeOptionalList(optElements) - else: - ret = makeOptionalList(optElements) - else: - if minElements == 1: - ret = self - else: - ret = And([self] * minElements) - return ret - - def __rmul__(self, other): - return self.__mul__(other) - - def __or__(self, other): - """ - Implementation of | operator - returns :class:`MatchFirst` - """ - if other is Ellipsis: - return _PendingSkip(self, must_skip=True) - - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return MatchFirst([self, other]) - - def __ror__(self, other): - """ - Implementation of | operator when left operand is not a :class:`ParserElement` - """ - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return other | self - - def __xor__(self, other): - """ - Implementation of ^ operator - returns :class:`Or` - """ - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return Or([self, other]) - - def __rxor__(self, other): - """ - Implementation of ^ operator when left operand is not a :class:`ParserElement` - """ - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return other ^ self - - def __and__(self, other): - """ - Implementation of & operator - returns :class:`Each` - """ - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return Each([self, other]) - - def __rand__(self, other): - """ - Implementation of & operator when left operand is not a :class:`ParserElement` - """ - if isinstance(other, basestring): - other = self._literalStringClass(other) - if not isinstance(other, ParserElement): - warnings.warn("Cannot combine element of type %s with ParserElement" % type(other), - SyntaxWarning, stacklevel=2) - return None - return other & self - - def __invert__(self): - """ - Implementation of ~ operator - returns :class:`NotAny` - """ - return NotAny(self) - - def __iter__(self): - # must implement __iter__ to override legacy use of sequential access to __getitem__ to - # iterate over a sequence - raise TypeError('%r object is not iterable' % self.__class__.__name__) - - def __getitem__(self, key): - """ - use ``[]`` indexing notation as a short form for expression repetition: - - ``expr[n]`` is equivalent to ``expr*n`` - - ``expr[m, n]`` is equivalent to ``expr*(m, n)`` - - ``expr[n, ...]`` or ``expr[n,]`` is equivalent - to ``expr*n + ZeroOrMore(expr)`` - (read as "at least n instances of ``expr``") - - ``expr[..., n]`` is equivalent to ``expr*(0, n)`` - (read as "0 to n instances of ``expr``") - - ``expr[...]`` and ``expr[0, ...]`` are equivalent to ``ZeroOrMore(expr)`` - - ``expr[1, ...]`` is equivalent to ``OneOrMore(expr)`` - ``None`` may be used in place of ``...``. - - Note that ``expr[..., n]`` and ``expr[m, n]``do not raise an exception - if more than ``n`` ``expr``s exist in the input stream. If this behavior is - desired, then write ``expr[..., n] + ~expr``. - """ - - # convert single arg keys to tuples - try: - if isinstance(key, str): - key = (key,) - iter(key) - except TypeError: - key = (key, key) - - if len(key) > 2: - warnings.warn("only 1 or 2 index arguments supported ({0}{1})".format(key[:5], - '... [{0}]'.format(len(key)) - if len(key) > 5 else '')) - - # clip to 2 elements - ret = self * tuple(key[:2]) - return ret - - def __call__(self, name=None): - """ - Shortcut for :class:`setResultsName`, with ``listAllMatches=False``. - - If ``name`` is given with a trailing ``'*'`` character, then ``listAllMatches`` will be - passed as ``True``. - - If ``name` is omitted, same as calling :class:`copy`. - - Example:: - - # these are equivalent - userdata = Word(alphas).setResultsName("name") + Word(nums + "-").setResultsName("socsecno") - userdata = Word(alphas)("name") + Word(nums + "-")("socsecno") - """ - if name is not None: - return self._setResultsName(name) - else: - return self.copy() - - def suppress(self): - """ - Suppresses the output of this :class:`ParserElement`; useful to keep punctuation from - cluttering up returned output. - """ - return Suppress(self) - - def leaveWhitespace(self): - """ - Disables the skipping of whitespace before matching the characters in the - :class:`ParserElement`'s defined pattern. This is normally only used internally by - the pyparsing module, but may be needed in some whitespace-sensitive grammars. - """ - self.skipWhitespace = False - return self - - def setWhitespaceChars(self, chars): - """ - Overrides the default whitespace chars - """ - self.skipWhitespace = True - self.whiteChars = chars - self.copyDefaultWhiteChars = False - return self - - def parseWithTabs(self): - """ - Overrides default behavior to expand ``<TAB>``s to spaces before parsing the input string. - Must be called before ``parseString`` when the input grammar contains elements that - match ``<TAB>`` characters. - """ - self.keepTabs = True - return self - - def ignore(self, other): - """ - Define expression to be ignored (e.g., comments) while doing pattern - matching; may be called repeatedly, to define multiple comment or other - ignorable patterns. - - Example:: - - patt = OneOrMore(Word(alphas)) - patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj'] - - patt.ignore(cStyleComment) - patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj', 'lskjd'] - """ - if isinstance(other, basestring): - other = Suppress(other) - - if isinstance(other, Suppress): - if other not in self.ignoreExprs: - self.ignoreExprs.append(other) - else: - self.ignoreExprs.append(Suppress(other.copy())) - return self - - def setDebugActions(self, startAction, successAction, exceptionAction): - """ - Enable display of debugging messages while doing pattern matching. - """ - self.debugActions = (startAction or _defaultStartDebugAction, - successAction or _defaultSuccessDebugAction, - exceptionAction or _defaultExceptionDebugAction) - self.debug = True - return self - - def setDebug(self, flag=True): - """ - Enable display of debugging messages while doing pattern matching. - Set ``flag`` to True to enable, False to disable. - - Example:: - - wd = Word(alphas).setName("alphaword") - integer = Word(nums).setName("numword") - term = wd | integer - - # turn on debugging for wd - wd.setDebug() - - OneOrMore(term).parseString("abc 123 xyz 890") - - prints:: - - Match alphaword at loc 0(1,1) - Matched alphaword -> ['abc'] - Match alphaword at loc 3(1,4) - Exception raised:Expected alphaword (at char 4), (line:1, col:5) - Match alphaword at loc 7(1,8) - Matched alphaword -> ['xyz'] - Match alphaword at loc 11(1,12) - Exception raised:Expected alphaword (at char 12), (line:1, col:13) - Match alphaword at loc 15(1,16) - Exception raised:Expected alphaword (at char 15), (line:1, col:16) - - The output shown is that produced by the default debug actions - custom debug actions can be - specified using :class:`setDebugActions`. Prior to attempting - to match the ``wd`` expression, the debugging message ``"Match <exprname> at loc <n>(<line>,<col>)"`` - is shown. Then if the parse succeeds, a ``"Matched"`` message is shown, or an ``"Exception raised"`` - message is shown. Also note the use of :class:`setName` to assign a human-readable name to the expression, - which makes debugging and exception messages easier to understand - for instance, the default - name created for the :class:`Word` expression without calling ``setName`` is ``"W:(ABCD...)"``. - """ - if flag: - self.setDebugActions(_defaultStartDebugAction, _defaultSuccessDebugAction, _defaultExceptionDebugAction) - else: - self.debug = False - return self - - def __str__(self): - return self.name - - def __repr__(self): - return _ustr(self) - - def streamline(self): - self.streamlined = True - self.strRepr = None - return self - - def checkRecursion(self, parseElementList): - pass - - def validate(self, validateTrace=None): - """ - Check defined expressions for valid structure, check for infinite recursive definitions. - """ - self.checkRecursion([]) - - def parseFile(self, file_or_filename, parseAll=False): - """ - Execute the parse expression on the given file or filename. - If a filename is specified (instead of a file object), - the entire file is opened, read, and closed before parsing. - """ - try: - file_contents = file_or_filename.read() - except AttributeError: - with open(file_or_filename, "r") as f: - file_contents = f.read() - try: - return self.parseString(file_contents, parseAll) - except ParseBaseException as exc: - if ParserElement.verbose_stacktrace: - raise - else: - # catch and re-raise exception from here, clearing out pyparsing internal stack trace - if getattr(exc, '__traceback__', None) is not None: - exc.__traceback__ = self._trim_traceback(exc.__traceback__) - raise exc - - def __eq__(self, other): - if self is other: - return True - elif isinstance(other, basestring): - return self.matches(other) - elif isinstance(other, ParserElement): - return vars(self) == vars(other) - return False - - def __ne__(self, other): - return not (self == other) - - def __hash__(self): - return id(self) - - def __req__(self, other): - return self == other - - def __rne__(self, other): - return not (self == other) - - def matches(self, testString, parseAll=True): - """ - Method for quick testing of a parser against a test string. Good for simple - inline microtests of sub expressions while building up larger parser. - - Parameters: - - testString - to test against this expression for a match - - parseAll - (default= ``True``) - flag to pass to :class:`parseString` when running tests - - Example:: - - expr = Word(nums) - assert expr.matches("100") - """ - try: - self.parseString(_ustr(testString), parseAll=parseAll) - return True - except ParseBaseException: - return False - - def runTests(self, tests, parseAll=True, comment='#', - fullDump=True, printResults=True, failureTests=False, postParse=None, - file=None): - """ - Execute the parse expression on a series of test strings, showing each - test, the parsed results or where the parse failed. Quick and easy way to - run a parse expression against a list of sample strings. - - Parameters: - - tests - a list of separate test strings, or a multiline string of test strings - - parseAll - (default= ``True``) - flag to pass to :class:`parseString` when running tests - - comment - (default= ``'#'``) - expression for indicating embedded comments in the test - string; pass None to disable comment filtering - - fullDump - (default= ``True``) - dump results as list followed by results names in nested outline; - if False, only dump nested list - - printResults - (default= ``True``) prints test output to stdout - - failureTests - (default= ``False``) indicates if these tests are expected to fail parsing - - postParse - (default= ``None``) optional callback for successful parse results; called as - `fn(test_string, parse_results)` and returns a string to be added to the test output - - file - (default=``None``) optional file-like object to which test output will be written; - if None, will default to ``sys.stdout`` - - Returns: a (success, results) tuple, where success indicates that all tests succeeded - (or failed if ``failureTests`` is True), and the results contain a list of lines of each - test's output - - Example:: - - number_expr = pyparsing_common.number.copy() - - result = number_expr.runTests(''' - # unsigned integer - 100 - # negative integer - -100 - # float with scientific notation - 6.02e23 - # integer with scientific notation - 1e-12 - ''') - print("Success" if result[0] else "Failed!") - - result = number_expr.runTests(''' - # stray character - 100Z - # missing leading digit before '.' - -.100 - # too many '.' - 3.14.159 - ''', failureTests=True) - print("Success" if result[0] else "Failed!") - - prints:: - - # unsigned integer - 100 - [100] - - # negative integer - -100 - [-100] - - # float with scientific notation - 6.02e23 - [6.02e+23] - - # integer with scientific notation - 1e-12 - [1e-12] - - Success - - # stray character - 100Z - ^ - FAIL: Expected end of text (at char 3), (line:1, col:4) - - # missing leading digit before '.' - -.100 - ^ - FAIL: Expected {real number with scientific notation | real number | signed integer} (at char 0), (line:1, col:1) - - # too many '.' - 3.14.159 - ^ - FAIL: Expected end of text (at char 4), (line:1, col:5) - - Success - - Each test string must be on a single line. If you want to test a string that spans multiple - lines, create a test like this:: - - expr.runTest(r"this is a test\\n of strings that spans \\n 3 lines") - - (Note that this is a raw string literal, you must include the leading 'r'.) - """ - if isinstance(tests, basestring): - tests = list(map(str.strip, tests.rstrip().splitlines())) - if isinstance(comment, basestring): - comment = Literal(comment) - if file is None: - file = sys.stdout - print_ = file.write - - allResults = [] - comments = [] - success = True - NL = Literal(r'\n').addParseAction(replaceWith('\n')).ignore(quotedString) - BOM = u'\ufeff' - for t in tests: - if comment is not None and comment.matches(t, False) or comments and not t: - comments.append(t) - continue - if not t: - continue - out = ['\n' + '\n'.join(comments) if comments else '', t] - comments = [] - try: - # convert newline marks to actual newlines, and strip leading BOM if present - t = NL.transformString(t.lstrip(BOM)) - result = self.parseString(t, parseAll=parseAll) - except ParseBaseException as pe: - fatal = "(FATAL)" if isinstance(pe, ParseFatalException) else "" - if '\n' in t: - out.append(line(pe.loc, t)) - out.append(' ' * (col(pe.loc, t) - 1) + '^' + fatal) - else: - out.append(' ' * pe.loc + '^' + fatal) - out.append("FAIL: " + str(pe)) - success = success and failureTests - result = pe - except Exception as exc: - out.append("FAIL-EXCEPTION: " + str(exc)) - success = success and failureTests - result = exc - else: - success = success and not failureTests - if postParse is not None: - try: - pp_value = postParse(t, result) - if pp_value is not None: - if isinstance(pp_value, ParseResults): - out.append(pp_value.dump()) - else: - out.append(str(pp_value)) - else: - out.append(result.dump()) - except Exception as e: - out.append(result.dump(full=fullDump)) - out.append("{0} failed: {1}: {2}".format(postParse.__name__, type(e).__name__, e)) - else: - out.append(result.dump(full=fullDump)) - - if printResults: - if fullDump: - out.append('') - print_('\n'.join(out)) - - allResults.append((t, result)) - - return success, allResults - - -class _PendingSkip(ParserElement): - # internal placeholder class to hold a place were '...' is added to a parser element, - # once another ParserElement is added, this placeholder will be replaced with a SkipTo - def __init__(self, expr, must_skip=False): - super(_PendingSkip, self).__init__() - self.strRepr = str(expr + Empty()).replace('Empty', '...') - self.name = self.strRepr - self.anchor = expr - self.must_skip = must_skip - - def __add__(self, other): - skipper = SkipTo(other).setName("...")("_skipped*") - if self.must_skip: - def must_skip(t): - if not t._skipped or t._skipped.asList() == ['']: - del t[0] - t.pop("_skipped", None) - def show_skip(t): - if t._skipped.asList()[-1:] == ['']: - skipped = t.pop('_skipped') - t['_skipped'] = 'missing <' + repr(self.anchor) + '>' - return (self.anchor + skipper().addParseAction(must_skip) - | skipper().addParseAction(show_skip)) + other - - return self.anchor + skipper + other - - def __repr__(self): - return self.strRepr - - def parseImpl(self, *args): - raise Exception("use of `...` expression without following SkipTo target expression") - - -class Token(ParserElement): - """Abstract :class:`ParserElement` subclass, for defining atomic - matching patterns. - """ - def __init__(self): - super(Token, self).__init__(savelist=False) - - -class Empty(Token): - """An empty token, will always match. - """ - def __init__(self): - super(Empty, self).__init__() - self.name = "Empty" - self.mayReturnEmpty = True - self.mayIndexError = False - - -class NoMatch(Token): - """A token that will never match. - """ - def __init__(self): - super(NoMatch, self).__init__() - self.name = "NoMatch" - self.mayReturnEmpty = True - self.mayIndexError = False - self.errmsg = "Unmatchable token" - - def parseImpl(self, instring, loc, doActions=True): - raise ParseException(instring, loc, self.errmsg, self) - - -class Literal(Token): - """Token to exactly match a specified string. - - Example:: - - Literal('blah').parseString('blah') # -> ['blah'] - Literal('blah').parseString('blahfooblah') # -> ['blah'] - Literal('blah').parseString('bla') # -> Exception: Expected "blah" - - For case-insensitive matching, use :class:`CaselessLiteral`. - - For keyword matching (force word break before and after the matched string), - use :class:`Keyword` or :class:`CaselessKeyword`. - """ - def __init__(self, matchString): - super(Literal, self).__init__() - self.match = matchString - self.matchLen = len(matchString) - try: - self.firstMatchChar = matchString[0] - except IndexError: - warnings.warn("null string passed to Literal; use Empty() instead", - SyntaxWarning, stacklevel=2) - self.__class__ = Empty - self.name = '"%s"' % _ustr(self.match) - self.errmsg = "Expected " + self.name - self.mayReturnEmpty = False - self.mayIndexError = False - - # Performance tuning: modify __class__ to select - # a parseImpl optimized for single-character check - if self.matchLen == 1 and type(self) is Literal: - self.__class__ = _SingleCharLiteral - - def parseImpl(self, instring, loc, doActions=True): - if instring[loc] == self.firstMatchChar and instring.startswith(self.match, loc): - return loc + self.matchLen, self.match - raise ParseException(instring, loc, self.errmsg, self) - -class _SingleCharLiteral(Literal): - def parseImpl(self, instring, loc, doActions=True): - if instring[loc] == self.firstMatchChar: - return loc + 1, self.match - raise ParseException(instring, loc, self.errmsg, self) - -_L = Literal -ParserElement._literalStringClass = Literal - -class Keyword(Token): - """Token to exactly match a specified string as a keyword, that is, - it must be immediately followed by a non-keyword character. Compare - with :class:`Literal`: - - - ``Literal("if")`` will match the leading ``'if'`` in - ``'ifAndOnlyIf'``. - - ``Keyword("if")`` will not; it will only match the leading - ``'if'`` in ``'if x=1'``, or ``'if(y==2)'`` - - Accepts two optional constructor arguments in addition to the - keyword string: - - - ``identChars`` is a string of characters that would be valid - identifier characters, defaulting to all alphanumerics + "_" and - "$" - - ``caseless`` allows case-insensitive matching, default is ``False``. - - Example:: - - Keyword("start").parseString("start") # -> ['start'] - Keyword("start").parseString("starting") # -> Exception - - For case-insensitive matching, use :class:`CaselessKeyword`. - """ - DEFAULT_KEYWORD_CHARS = alphanums + "_$" - - def __init__(self, matchString, identChars=None, caseless=False): - super(Keyword, self).__init__() - if identChars is None: - identChars = Keyword.DEFAULT_KEYWORD_CHARS - self.match = matchString - self.matchLen = len(matchString) - try: - self.firstMatchChar = matchString[0] - except IndexError: - warnings.warn("null string passed to Keyword; use Empty() instead", - SyntaxWarning, stacklevel=2) - self.name = '"%s"' % self.match - self.errmsg = "Expected " + self.name - self.mayReturnEmpty = False - self.mayIndexError = False - self.caseless = caseless - if caseless: - self.caselessmatch = matchString.upper() - identChars = identChars.upper() - self.identChars = set(identChars) - - def parseImpl(self, instring, loc, doActions=True): - if self.caseless: - if ((instring[loc:loc + self.matchLen].upper() == self.caselessmatch) - and (loc >= len(instring) - self.matchLen - or instring[loc + self.matchLen].upper() not in self.identChars) - and (loc == 0 - or instring[loc - 1].upper() not in self.identChars)): - return loc + self.matchLen, self.match - - else: - if instring[loc] == self.firstMatchChar: - if ((self.matchLen == 1 or instring.startswith(self.match, loc)) - and (loc >= len(instring) - self.matchLen - or instring[loc + self.matchLen] not in self.identChars) - and (loc == 0 or instring[loc - 1] not in self.identChars)): - return loc + self.matchLen, self.match - - raise ParseException(instring, loc, self.errmsg, self) - - def copy(self): - c = super(Keyword, self).copy() - c.identChars = Keyword.DEFAULT_KEYWORD_CHARS - return c - - @staticmethod - def setDefaultKeywordChars(chars): - """Overrides the default Keyword chars - """ - Keyword.DEFAULT_KEYWORD_CHARS = chars - -class CaselessLiteral(Literal): - """Token to match a specified string, ignoring case of letters. - Note: the matched results will always be in the case of the given - match string, NOT the case of the input text. - - Example:: - - OneOrMore(CaselessLiteral("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD', 'CMD'] - - (Contrast with example for :class:`CaselessKeyword`.) - """ - def __init__(self, matchString): - super(CaselessLiteral, self).__init__(matchString.upper()) - # Preserve the defining literal. - self.returnString = matchString - self.name = "'%s'" % self.returnString - self.errmsg = "Expected " + self.name - - def parseImpl(self, instring, loc, doActions=True): - if instring[loc:loc + self.matchLen].upper() == self.match: - return loc + self.matchLen, self.returnString - raise ParseException(instring, loc, self.errmsg, self) - -class CaselessKeyword(Keyword): - """ - Caseless version of :class:`Keyword`. - - Example:: - - OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD'] - - (Contrast with example for :class:`CaselessLiteral`.) - """ - def __init__(self, matchString, identChars=None): - super(CaselessKeyword, self).__init__(matchString, identChars, caseless=True) - -class CloseMatch(Token): - """A variation on :class:`Literal` which matches "close" matches, - that is, strings with at most 'n' mismatching characters. - :class:`CloseMatch` takes parameters: - - - ``match_string`` - string to be matched - - ``maxMismatches`` - (``default=1``) maximum number of - mismatches allowed to count as a match - - The results from a successful parse will contain the matched text - from the input string and the following named results: - - - ``mismatches`` - a list of the positions within the - match_string where mismatches were found - - ``original`` - the original match_string used to compare - against the input string - - If ``mismatches`` is an empty list, then the match was an exact - match. - - Example:: - - patt = CloseMatch("ATCATCGAATGGA") - patt.parseString("ATCATCGAAXGGA") # -> (['ATCATCGAAXGGA'], {'mismatches': [[9]], 'original': ['ATCATCGAATGGA']}) - patt.parseString("ATCAXCGAAXGGA") # -> Exception: Expected 'ATCATCGAATGGA' (with up to 1 mismatches) (at char 0), (line:1, col:1) - - # exact match - patt.parseString("ATCATCGAATGGA") # -> (['ATCATCGAATGGA'], {'mismatches': [[]], 'original': ['ATCATCGAATGGA']}) - - # close match allowing up to 2 mismatches - patt = CloseMatch("ATCATCGAATGGA", maxMismatches=2) - patt.parseString("ATCAXCGAAXGGA") # -> (['ATCAXCGAAXGGA'], {'mismatches': [[4, 9]], 'original': ['ATCATCGAATGGA']}) - """ - def __init__(self, match_string, maxMismatches=1): - super(CloseMatch, self).__init__() - self.name = match_string - self.match_string = match_string - self.maxMismatches = maxMismatches - self.errmsg = "Expected %r (with up to %d mismatches)" % (self.match_string, self.maxMismatches) - self.mayIndexError = False - self.mayReturnEmpty = False - - def parseImpl(self, instring, loc, doActions=True): - start = loc - instrlen = len(instring) - maxloc = start + len(self.match_string) - - if maxloc <= instrlen: - match_string = self.match_string - match_stringloc = 0 - mismatches = [] - maxMismatches = self.maxMismatches - - for match_stringloc, s_m in enumerate(zip(instring[loc:maxloc], match_string)): - src, mat = s_m - if src != mat: - mismatches.append(match_stringloc) - if len(mismatches) > maxMismatches: - break - else: - loc = match_stringloc + 1 - results = ParseResults([instring[start:loc]]) - results['original'] = match_string - results['mismatches'] = mismatches - return loc, results - - raise ParseException(instring, loc, self.errmsg, self) - - -class Word(Token): - """Token for matching words composed of allowed character sets. - Defined with string containing all allowed initial characters, an - optional string containing allowed body characters (if omitted, - defaults to the initial character set), and an optional minimum, - maximum, and/or exact length. The default value for ``min`` is - 1 (a minimum value < 1 is not valid); the default values for - ``max`` and ``exact`` are 0, meaning no maximum or exact - length restriction. An optional ``excludeChars`` parameter can - list characters that might be found in the input ``bodyChars`` - string; useful to define a word of all printables except for one or - two characters, for instance. - - :class:`srange` is useful for defining custom character set strings - for defining ``Word`` expressions, using range notation from - regular expression character sets. - - A common mistake is to use :class:`Word` to match a specific literal - string, as in ``Word("Address")``. Remember that :class:`Word` - uses the string argument to define *sets* of matchable characters. - This expression would match "Add", "AAA", "dAred", or any other word - made up of the characters 'A', 'd', 'r', 'e', and 's'. To match an - exact literal string, use :class:`Literal` or :class:`Keyword`. - - pyparsing includes helper strings for building Words: - - - :class:`alphas` - - :class:`nums` - - :class:`alphanums` - - :class:`hexnums` - - :class:`alphas8bit` (alphabetic characters in ASCII range 128-255 - - accented, tilded, umlauted, etc.) - - :class:`punc8bit` (non-alphabetic characters in ASCII range - 128-255 - currency, symbols, superscripts, diacriticals, etc.) - - :class:`printables` (any non-whitespace character) - - Example:: - - # a word composed of digits - integer = Word(nums) # equivalent to Word("0123456789") or Word(srange("0-9")) - - # a word with a leading capital, and zero or more lowercase - capital_word = Word(alphas.upper(), alphas.lower()) - - # hostnames are alphanumeric, with leading alpha, and '-' - hostname = Word(alphas, alphanums + '-') - - # roman numeral (not a strict parser, accepts invalid mix of characters) - roman = Word("IVXLCDM") - - # any string of non-whitespace characters, except for ',' - csv_value = Word(printables, excludeChars=",") - """ - def __init__(self, initChars, bodyChars=None, min=1, max=0, exact=0, asKeyword=False, excludeChars=None): - super(Word, self).__init__() - if excludeChars: - excludeChars = set(excludeChars) - initChars = ''.join(c for c in initChars if c not in excludeChars) - if bodyChars: - bodyChars = ''.join(c for c in bodyChars if c not in excludeChars) - self.initCharsOrig = initChars - self.initChars = set(initChars) - if bodyChars: - self.bodyCharsOrig = bodyChars - self.bodyChars = set(bodyChars) - else: - self.bodyCharsOrig = initChars - self.bodyChars = set(initChars) - - self.maxSpecified = max > 0 - - if min < 1: - raise ValueError("cannot specify a minimum length < 1; use Optional(Word()) if zero-length word is permitted") - - self.minLen = min - - if max > 0: - self.maxLen = max - else: - self.maxLen = _MAX_INT - - if exact > 0: - self.maxLen = exact - self.minLen = exact - - self.name = _ustr(self) - self.errmsg = "Expected " + self.name - self.mayIndexError = False - self.asKeyword = asKeyword - - if ' ' not in self.initCharsOrig + self.bodyCharsOrig and (min == 1 and max == 0 and exact == 0): - if self.bodyCharsOrig == self.initCharsOrig: - self.reString = "[%s]+" % _escapeRegexRangeChars(self.initCharsOrig) - elif len(self.initCharsOrig) == 1: - self.reString = "%s[%s]*" % (re.escape(self.initCharsOrig), - _escapeRegexRangeChars(self.bodyCharsOrig),) - else: - self.reString = "[%s][%s]*" % (_escapeRegexRangeChars(self.initCharsOrig), - _escapeRegexRangeChars(self.bodyCharsOrig),) - if self.asKeyword: - self.reString = r"\b" + self.reString + r"\b" - - try: - self.re = re.compile(self.reString) - except Exception: - self.re = None - else: - self.re_match = self.re.match - self.__class__ = _WordRegex - - def parseImpl(self, instring, loc, doActions=True): - if instring[loc] not in self.initChars: - raise ParseException(instring, loc, self.errmsg, self) - - start = loc - loc += 1 - instrlen = len(instring) - bodychars = self.bodyChars - maxloc = start + self.maxLen - maxloc = min(maxloc, instrlen) - while loc < maxloc and instring[loc] in bodychars: - loc += 1 - - throwException = False - if loc - start < self.minLen: - throwException = True - elif self.maxSpecified and loc < instrlen and instring[loc] in bodychars: - throwException = True - elif self.asKeyword: - if (start > 0 and instring[start - 1] in bodychars - or loc < instrlen and instring[loc] in bodychars): - throwException = True - - if throwException: - raise ParseException(instring, loc, self.errmsg, self) - - return loc, instring[start:loc] - - def __str__(self): - try: - return super(Word, self).__str__() - except Exception: - pass - - if self.strRepr is None: - - def charsAsStr(s): - if len(s) > 4: - return s[:4] + "..." - else: - return s - - if self.initCharsOrig != self.bodyCharsOrig: - self.strRepr = "W:(%s, %s)" % (charsAsStr(self.initCharsOrig), charsAsStr(self.bodyCharsOrig)) - else: - self.strRepr = "W:(%s)" % charsAsStr(self.initCharsOrig) - - return self.strRepr - -class _WordRegex(Word): - def parseImpl(self, instring, loc, doActions=True): - result = self.re_match(instring, loc) - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - return loc, result.group() - - -class Char(_WordRegex): - """A short-cut class for defining ``Word(characters, exact=1)``, - when defining a match of any single character in a string of - characters. - """ - def __init__(self, charset, asKeyword=False, excludeChars=None): - super(Char, self).__init__(charset, exact=1, asKeyword=asKeyword, excludeChars=excludeChars) - self.reString = "[%s]" % _escapeRegexRangeChars(''.join(self.initChars)) - if asKeyword: - self.reString = r"\b%s\b" % self.reString - self.re = re.compile(self.reString) - self.re_match = self.re.match - - -class Regex(Token): - r"""Token for matching strings that match a given regular - expression. Defined with string specifying the regular expression in - a form recognized by the stdlib Python `re module <https://docs.python.org/3/library/re.html>`_. - If the given regex contains named groups (defined using ``(?P<name>...)``), - these will be preserved as named parse results. - - If instead of the Python stdlib re module you wish to use a different RE module - (such as the `regex` module), you can replace it by either building your - Regex object with a compiled RE that was compiled using regex: - - Example:: - - realnum = Regex(r"[+-]?\d+\.\d*") - date = Regex(r'(?P<year>\d{4})-(?P<month>\d\d?)-(?P<day>\d\d?)') - # ref: https://stackoverflow.com/questions/267399/how-do-you-match-only-valid-roman-numerals-with-a-regular-expression - roman = Regex(r"M{0,4}(CM|CD|D?{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})") - - # use regex module instead of stdlib re module to construct a Regex using - # a compiled regular expression - import regex - parser = pp.Regex(regex.compile(r'[0-9]')) - - """ - def __init__(self, pattern, flags=0, asGroupList=False, asMatch=False): - """The parameters ``pattern`` and ``flags`` are passed - to the ``re.compile()`` function as-is. See the Python - `re module <https://docs.python.org/3/library/re.html>`_ module for an - explanation of the acceptable patterns and flags. - """ - super(Regex, self).__init__() - - if isinstance(pattern, basestring): - if not pattern: - warnings.warn("null string passed to Regex; use Empty() instead", - SyntaxWarning, stacklevel=2) - - self.pattern = pattern - self.flags = flags - - try: - self.re = re.compile(self.pattern, self.flags) - self.reString = self.pattern - except sre_constants.error: - warnings.warn("invalid pattern (%s) passed to Regex" % pattern, - SyntaxWarning, stacklevel=2) - raise - - elif hasattr(pattern, 'pattern') and hasattr(pattern, 'match'): - self.re = pattern - self.pattern = self.reString = pattern.pattern - self.flags = flags - - else: - raise TypeError("Regex may only be constructed with a string or a compiled RE object") - - self.re_match = self.re.match - - self.name = _ustr(self) - self.errmsg = "Expected " + self.name - self.mayIndexError = False - self.mayReturnEmpty = self.re_match("") is not None - self.asGroupList = asGroupList - self.asMatch = asMatch - if self.asGroupList: - self.parseImpl = self.parseImplAsGroupList - if self.asMatch: - self.parseImpl = self.parseImplAsMatch - - def parseImpl(self, instring, loc, doActions=True): - result = self.re_match(instring, loc) - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - ret = ParseResults(result.group()) - d = result.groupdict() - if d: - for k, v in d.items(): - ret[k] = v - return loc, ret - - def parseImplAsGroupList(self, instring, loc, doActions=True): - result = self.re_match(instring, loc) - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - ret = result.groups() - return loc, ret - - def parseImplAsMatch(self, instring, loc, doActions=True): - result = self.re_match(instring, loc) - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - ret = result - return loc, ret - - def __str__(self): - try: - return super(Regex, self).__str__() - except Exception: - pass - - if self.strRepr is None: - self.strRepr = "Re:(%s)" % repr(self.pattern) - - return self.strRepr - - def sub(self, repl): - r""" - Return Regex with an attached parse action to transform the parsed - result as if called using `re.sub(expr, repl, string) <https://docs.python.org/3/library/re.html#re.sub>`_. - - Example:: - - make_html = Regex(r"(\w+):(.*?):").sub(r"<\1>\2</\1>") - print(make_html.transformString("h1:main title:")) - # prints "<h1>main title</h1>" - """ - if self.asGroupList: - warnings.warn("cannot use sub() with Regex(asGroupList=True)", - SyntaxWarning, stacklevel=2) - raise SyntaxError() - - if self.asMatch and callable(repl): - warnings.warn("cannot use sub() with a callable with Regex(asMatch=True)", - SyntaxWarning, stacklevel=2) - raise SyntaxError() - - if self.asMatch: - def pa(tokens): - return tokens[0].expand(repl) - else: - def pa(tokens): - return self.re.sub(repl, tokens[0]) - return self.addParseAction(pa) - -class QuotedString(Token): - r""" - Token for matching strings that are delimited by quoting characters. - - Defined with the following parameters: - - - quoteChar - string of one or more characters defining the - quote delimiting string - - escChar - character to escape quotes, typically backslash - (default= ``None``) - - escQuote - special quote sequence to escape an embedded quote - string (such as SQL's ``""`` to escape an embedded ``"``) - (default= ``None``) - - multiline - boolean indicating whether quotes can span - multiple lines (default= ``False``) - - unquoteResults - boolean indicating whether the matched text - should be unquoted (default= ``True``) - - endQuoteChar - string of one or more characters defining the - end of the quote delimited string (default= ``None`` => same as - quoteChar) - - convertWhitespaceEscapes - convert escaped whitespace - (``'\t'``, ``'\n'``, etc.) to actual whitespace - (default= ``True``) - - Example:: - - qs = QuotedString('"') - print(qs.searchString('lsjdf "This is the quote" sldjf')) - complex_qs = QuotedString('{{', endQuoteChar='}}') - print(complex_qs.searchString('lsjdf {{This is the "quote"}} sldjf')) - sql_qs = QuotedString('"', escQuote='""') - print(sql_qs.searchString('lsjdf "This is the quote with ""embedded"" quotes" sldjf')) - - prints:: - - [['This is the quote']] - [['This is the "quote"']] - [['This is the quote with "embedded" quotes']] - """ - def __init__(self, quoteChar, escChar=None, escQuote=None, multiline=False, - unquoteResults=True, endQuoteChar=None, convertWhitespaceEscapes=True): - super(QuotedString, self).__init__() - - # remove white space from quote chars - wont work anyway - quoteChar = quoteChar.strip() - if not quoteChar: - warnings.warn("quoteChar cannot be the empty string", SyntaxWarning, stacklevel=2) - raise SyntaxError() - - if endQuoteChar is None: - endQuoteChar = quoteChar - else: - endQuoteChar = endQuoteChar.strip() - if not endQuoteChar: - warnings.warn("endQuoteChar cannot be the empty string", SyntaxWarning, stacklevel=2) - raise SyntaxError() - - self.quoteChar = quoteChar - self.quoteCharLen = len(quoteChar) - self.firstQuoteChar = quoteChar[0] - self.endQuoteChar = endQuoteChar - self.endQuoteCharLen = len(endQuoteChar) - self.escChar = escChar - self.escQuote = escQuote - self.unquoteResults = unquoteResults - self.convertWhitespaceEscapes = convertWhitespaceEscapes - - if multiline: - self.flags = re.MULTILINE | re.DOTALL - self.pattern = r'%s(?:[^%s%s]' % (re.escape(self.quoteChar), - _escapeRegexRangeChars(self.endQuoteChar[0]), - (escChar is not None and _escapeRegexRangeChars(escChar) or '')) - else: - self.flags = 0 - self.pattern = r'%s(?:[^%s\n\r%s]' % (re.escape(self.quoteChar), - _escapeRegexRangeChars(self.endQuoteChar[0]), - (escChar is not None and _escapeRegexRangeChars(escChar) or '')) - if len(self.endQuoteChar) > 1: - self.pattern += ( - '|(?:' + ')|(?:'.join("%s[^%s]" % (re.escape(self.endQuoteChar[:i]), - _escapeRegexRangeChars(self.endQuoteChar[i])) - for i in range(len(self.endQuoteChar) - 1, 0, -1)) + ')') - - if escQuote: - self.pattern += (r'|(?:%s)' % re.escape(escQuote)) - if escChar: - self.pattern += (r'|(?:%s.)' % re.escape(escChar)) - self.escCharReplacePattern = re.escape(self.escChar) + "(.)" - self.pattern += (r')*%s' % re.escape(self.endQuoteChar)) - - try: - self.re = re.compile(self.pattern, self.flags) - self.reString = self.pattern - self.re_match = self.re.match - except sre_constants.error: - warnings.warn("invalid pattern (%s) passed to Regex" % self.pattern, - SyntaxWarning, stacklevel=2) - raise - - self.name = _ustr(self) - self.errmsg = "Expected " + self.name - self.mayIndexError = False - self.mayReturnEmpty = True - - def parseImpl(self, instring, loc, doActions=True): - result = instring[loc] == self.firstQuoteChar and self.re_match(instring, loc) or None - if not result: - raise ParseException(instring, loc, self.errmsg, self) - - loc = result.end() - ret = result.group() - - if self.unquoteResults: - - # strip off quotes - ret = ret[self.quoteCharLen: -self.endQuoteCharLen] - - if isinstance(ret, basestring): - # replace escaped whitespace - if '\\' in ret and self.convertWhitespaceEscapes: - ws_map = { - r'\t': '\t', - r'\n': '\n', - r'\f': '\f', - r'\r': '\r', - } - for wslit, wschar in ws_map.items(): - ret = ret.replace(wslit, wschar) - - # replace escaped characters - if self.escChar: - ret = re.sub(self.escCharReplacePattern, r"\g<1>", ret) - - # replace escaped quotes - if self.escQuote: - ret = ret.replace(self.escQuote, self.endQuoteChar) - - return loc, ret - - def __str__(self): - try: - return super(QuotedString, self).__str__() - except Exception: - pass - - if self.strRepr is None: - self.strRepr = "quoted string, starting with %s ending with %s" % (self.quoteChar, self.endQuoteChar) - - return self.strRepr - - -class CharsNotIn(Token): - """Token for matching words composed of characters *not* in a given - set (will include whitespace in matched characters if not listed in - the provided exclusion set - see example). Defined with string - containing all disallowed characters, and an optional minimum, - maximum, and/or exact length. The default value for ``min`` is - 1 (a minimum value < 1 is not valid); the default values for - ``max`` and ``exact`` are 0, meaning no maximum or exact - length restriction. - - Example:: - - # define a comma-separated-value as anything that is not a ',' - csv_value = CharsNotIn(',') - print(delimitedList(csv_value).parseString("dkls,lsdkjf,s12 34,@!#,213")) - - prints:: - - ['dkls', 'lsdkjf', 's12 34', '@!#', '213'] - """ - def __init__(self, notChars, min=1, max=0, exact=0): - super(CharsNotIn, self).__init__() - self.skipWhitespace = False - self.notChars = notChars - - if min < 1: - raise ValueError("cannot specify a minimum length < 1; use " - "Optional(CharsNotIn()) if zero-length char group is permitted") - - self.minLen = min - - if max > 0: - self.maxLen = max - else: - self.maxLen = _MAX_INT - - if exact > 0: - self.maxLen = exact - self.minLen = exact - - self.name = _ustr(self) - self.errmsg = "Expected " + self.name - self.mayReturnEmpty = (self.minLen == 0) - self.mayIndexError = False - - def parseImpl(self, instring, loc, doActions=True): - if instring[loc] in self.notChars: - raise ParseException(instring, loc, self.errmsg, self) - - start = loc - loc += 1 - notchars = self.notChars - maxlen = min(start + self.maxLen, len(instring)) - while loc < maxlen and instring[loc] not in notchars: - loc += 1 - - if loc - start < self.minLen: - raise ParseException(instring, loc, self.errmsg, self) - - return loc, instring[start:loc] - - def __str__(self): - try: - return super(CharsNotIn, self).__str__() - except Exception: - pass - - if self.strRepr is None: - if len(self.notChars) > 4: - self.strRepr = "!W:(%s...)" % self.notChars[:4] - else: - self.strRepr = "!W:(%s)" % self.notChars - - return self.strRepr - -class White(Token): - """Special matching class for matching whitespace. Normally, - whitespace is ignored by pyparsing grammars. This class is included - when some whitespace structures are significant. Define with - a string containing the whitespace characters to be matched; default - is ``" \\t\\r\\n"``. Also takes optional ``min``, - ``max``, and ``exact`` arguments, as defined for the - :class:`Word` class. - """ - whiteStrs = { - ' ' : '<SP>', - '\t': '<TAB>', - '\n': '<LF>', - '\r': '<CR>', - '\f': '<FF>', - u'\u00A0': '<NBSP>', - u'\u1680': '<OGHAM_SPACE_MARK>', - u'\u180E': '<MONGOLIAN_VOWEL_SEPARATOR>', - u'\u2000': '<EN_QUAD>', - u'\u2001': '<EM_QUAD>', - u'\u2002': '<EN_SPACE>', - u'\u2003': '<EM_SPACE>', - u'\u2004': '<THREE-PER-EM_SPACE>', - u'\u2005': '<FOUR-PER-EM_SPACE>', - u'\u2006': '<SIX-PER-EM_SPACE>', - u'\u2007': '<FIGURE_SPACE>', - u'\u2008': '<PUNCTUATION_SPACE>', - u'\u2009': '<THIN_SPACE>', - u'\u200A': '<HAIR_SPACE>', - u'\u200B': '<ZERO_WIDTH_SPACE>', - u'\u202F': '<NNBSP>', - u'\u205F': '<MMSP>', - u'\u3000': '<IDEOGRAPHIC_SPACE>', - } - def __init__(self, ws=" \t\r\n", min=1, max=0, exact=0): - super(White, self).__init__() - self.matchWhite = ws - self.setWhitespaceChars("".join(c for c in self.whiteChars if c not in self.matchWhite)) - # ~ self.leaveWhitespace() - self.name = ("".join(White.whiteStrs[c] for c in self.matchWhite)) - self.mayReturnEmpty = True - self.errmsg = "Expected " + self.name - - self.minLen = min - - if max > 0: - self.maxLen = max - else: - self.maxLen = _MAX_INT - - if exact > 0: - self.maxLen = exact - self.minLen = exact - - def parseImpl(self, instring, loc, doActions=True): - if instring[loc] not in self.matchWhite: - raise ParseException(instring, loc, self.errmsg, self) - start = loc - loc += 1 - maxloc = start + self.maxLen - maxloc = min(maxloc, len(instring)) - while loc < maxloc and instring[loc] in self.matchWhite: - loc += 1 - - if loc - start < self.minLen: - raise ParseException(instring, loc, self.errmsg, self) - - return loc, instring[start:loc] - - -class _PositionToken(Token): - def __init__(self): - super(_PositionToken, self).__init__() - self.name = self.__class__.__name__ - self.mayReturnEmpty = True - self.mayIndexError = False - -class GoToColumn(_PositionToken): - """Token to advance to a specific column of input text; useful for - tabular report scraping. - """ - def __init__(self, colno): - super(GoToColumn, self).__init__() - self.col = colno - - def preParse(self, instring, loc): - if col(loc, instring) != self.col: - instrlen = len(instring) - if self.ignoreExprs: - loc = self._skipIgnorables(instring, loc) - while loc < instrlen and instring[loc].isspace() and col(loc, instring) != self.col: - loc += 1 - return loc - - def parseImpl(self, instring, loc, doActions=True): - thiscol = col(loc, instring) - if thiscol > self.col: - raise ParseException(instring, loc, "Text not in expected column", self) - newloc = loc + self.col - thiscol - ret = instring[loc: newloc] - return newloc, ret - - -class LineStart(_PositionToken): - r"""Matches if current position is at the beginning of a line within - the parse string - - Example:: - - test = '''\ - AAA this line - AAA and this line - AAA but not this one - B AAA and definitely not this one - ''' - - for t in (LineStart() + 'AAA' + restOfLine).searchString(test): - print(t) - - prints:: - - ['AAA', ' this line'] - ['AAA', ' and this line'] - - """ - def __init__(self): - super(LineStart, self).__init__() - self.errmsg = "Expected start of line" - - def parseImpl(self, instring, loc, doActions=True): - if col(loc, instring) == 1: - return loc, [] - raise ParseException(instring, loc, self.errmsg, self) - -class LineEnd(_PositionToken): - """Matches if current position is at the end of a line within the - parse string - """ - def __init__(self): - super(LineEnd, self).__init__() - self.setWhitespaceChars(ParserElement.DEFAULT_WHITE_CHARS.replace("\n", "")) - self.errmsg = "Expected end of line" - - def parseImpl(self, instring, loc, doActions=True): - if loc < len(instring): - if instring[loc] == "\n": - return loc + 1, "\n" - else: - raise ParseException(instring, loc, self.errmsg, self) - elif loc == len(instring): - return loc + 1, [] - else: - raise ParseException(instring, loc, self.errmsg, self) - -class StringStart(_PositionToken): - """Matches if current position is at the beginning of the parse - string - """ - def __init__(self): - super(StringStart, self).__init__() - self.errmsg = "Expected start of text" - - def parseImpl(self, instring, loc, doActions=True): - if loc != 0: - # see if entire string up to here is just whitespace and ignoreables - if loc != self.preParse(instring, 0): - raise ParseException(instring, loc, self.errmsg, self) - return loc, [] - -class StringEnd(_PositionToken): - """Matches if current position is at the end of the parse string - """ - def __init__(self): - super(StringEnd, self).__init__() - self.errmsg = "Expected end of text" - - def parseImpl(self, instring, loc, doActions=True): - if loc < len(instring): - raise ParseException(instring, loc, self.errmsg, self) - elif loc == len(instring): - return loc + 1, [] - elif loc > len(instring): - return loc, [] - else: - raise ParseException(instring, loc, self.errmsg, self) - -class WordStart(_PositionToken): - """Matches if the current position is at the beginning of a Word, - and is not preceded by any character in a given set of - ``wordChars`` (default= ``printables``). To emulate the - ``\b`` behavior of regular expressions, use - ``WordStart(alphanums)``. ``WordStart`` will also match at - the beginning of the string being parsed, or at the beginning of - a line. - """ - def __init__(self, wordChars=printables): - super(WordStart, self).__init__() - self.wordChars = set(wordChars) - self.errmsg = "Not at the start of a word" - - def parseImpl(self, instring, loc, doActions=True): - if loc != 0: - if (instring[loc - 1] in self.wordChars - or instring[loc] not in self.wordChars): - raise ParseException(instring, loc, self.errmsg, self) - return loc, [] - -class WordEnd(_PositionToken): - """Matches if the current position is at the end of a Word, and is - not followed by any character in a given set of ``wordChars`` - (default= ``printables``). To emulate the ``\b`` behavior of - regular expressions, use ``WordEnd(alphanums)``. ``WordEnd`` - will also match at the end of the string being parsed, or at the end - of a line. - """ - def __init__(self, wordChars=printables): - super(WordEnd, self).__init__() - self.wordChars = set(wordChars) - self.skipWhitespace = False - self.errmsg = "Not at the end of a word" - - def parseImpl(self, instring, loc, doActions=True): - instrlen = len(instring) - if instrlen > 0 and loc < instrlen: - if (instring[loc] in self.wordChars or - instring[loc - 1] not in self.wordChars): - raise ParseException(instring, loc, self.errmsg, self) - return loc, [] - - -class ParseExpression(ParserElement): - """Abstract subclass of ParserElement, for combining and - post-processing parsed tokens. - """ - def __init__(self, exprs, savelist=False): - super(ParseExpression, self).__init__(savelist) - if isinstance(exprs, _generatorType): - exprs = list(exprs) - - if isinstance(exprs, basestring): - self.exprs = [self._literalStringClass(exprs)] - elif isinstance(exprs, ParserElement): - self.exprs = [exprs] - elif isinstance(exprs, Iterable): - exprs = list(exprs) - # if sequence of strings provided, wrap with Literal - if any(isinstance(expr, basestring) for expr in exprs): - exprs = (self._literalStringClass(e) if isinstance(e, basestring) else e for e in exprs) - self.exprs = list(exprs) - else: - try: - self.exprs = list(exprs) - except TypeError: - self.exprs = [exprs] - self.callPreparse = False - - def append(self, other): - self.exprs.append(other) - self.strRepr = None - return self - - def leaveWhitespace(self): - """Extends ``leaveWhitespace`` defined in base class, and also invokes ``leaveWhitespace`` on - all contained expressions.""" - self.skipWhitespace = False - self.exprs = [e.copy() for e in self.exprs] - for e in self.exprs: - e.leaveWhitespace() - return self - - def ignore(self, other): - if isinstance(other, Suppress): - if other not in self.ignoreExprs: - super(ParseExpression, self).ignore(other) - for e in self.exprs: - e.ignore(self.ignoreExprs[-1]) - else: - super(ParseExpression, self).ignore(other) - for e in self.exprs: - e.ignore(self.ignoreExprs[-1]) - return self - - def __str__(self): - try: - return super(ParseExpression, self).__str__() - except Exception: - pass - - if self.strRepr is None: - self.strRepr = "%s:(%s)" % (self.__class__.__name__, _ustr(self.exprs)) - return self.strRepr - - def streamline(self): - super(ParseExpression, self).streamline() - - for e in self.exprs: - e.streamline() - - # collapse nested And's of the form And(And(And(a, b), c), d) to And(a, b, c, d) - # but only if there are no parse actions or resultsNames on the nested And's - # (likewise for Or's and MatchFirst's) - if len(self.exprs) == 2: - other = self.exprs[0] - if (isinstance(other, self.__class__) - and not other.parseAction - and other.resultsName is None - and not other.debug): - self.exprs = other.exprs[:] + [self.exprs[1]] - self.strRepr = None - self.mayReturnEmpty |= other.mayReturnEmpty - self.mayIndexError |= other.mayIndexError - - other = self.exprs[-1] - if (isinstance(other, self.__class__) - and not other.parseAction - and other.resultsName is None - and not other.debug): - self.exprs = self.exprs[:-1] + other.exprs[:] - self.strRepr = None - self.mayReturnEmpty |= other.mayReturnEmpty - self.mayIndexError |= other.mayIndexError - - self.errmsg = "Expected " + _ustr(self) - - return self - - def validate(self, validateTrace=None): - tmp = (validateTrace if validateTrace is not None else [])[:] + [self] - for e in self.exprs: - e.validate(tmp) - self.checkRecursion([]) - - def copy(self): - ret = super(ParseExpression, self).copy() - ret.exprs = [e.copy() for e in self.exprs] - return ret - - def _setResultsName(self, name, listAllMatches=False): - if __diag__.warn_ungrouped_named_tokens_in_collection: - for e in self.exprs: - if isinstance(e, ParserElement) and e.resultsName: - warnings.warn("{0}: setting results name {1!r} on {2} expression " - "collides with {3!r} on contained expression".format("warn_ungrouped_named_tokens_in_collection", - name, - type(self).__name__, - e.resultsName), - stacklevel=3) - - return super(ParseExpression, self)._setResultsName(name, listAllMatches) - - -class And(ParseExpression): - """ - Requires all given :class:`ParseExpression` s to be found in the given order. - Expressions may be separated by whitespace. - May be constructed using the ``'+'`` operator. - May also be constructed using the ``'-'`` operator, which will - suppress backtracking. - - Example:: - - integer = Word(nums) - name_expr = OneOrMore(Word(alphas)) - - expr = And([integer("id"), name_expr("name"), integer("age")]) - # more easily written as: - expr = integer("id") + name_expr("name") + integer("age") - """ - - class _ErrorStop(Empty): - def __init__(self, *args, **kwargs): - super(And._ErrorStop, self).__init__(*args, **kwargs) - self.name = '-' - self.leaveWhitespace() - - def __init__(self, exprs, savelist=True): - exprs = list(exprs) - if exprs and Ellipsis in exprs: - tmp = [] - for i, expr in enumerate(exprs): - if expr is Ellipsis: - if i < len(exprs) - 1: - skipto_arg = (Empty() + exprs[i + 1]).exprs[-1] - tmp.append(SkipTo(skipto_arg)("_skipped*")) - else: - raise Exception("cannot construct And with sequence ending in ...") - else: - tmp.append(expr) - exprs[:] = tmp - super(And, self).__init__(exprs, savelist) - self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) - self.setWhitespaceChars(self.exprs[0].whiteChars) - self.skipWhitespace = self.exprs[0].skipWhitespace - self.callPreparse = True - - def streamline(self): - # collapse any _PendingSkip's - if self.exprs: - if any(isinstance(e, ParseExpression) and e.exprs and isinstance(e.exprs[-1], _PendingSkip) - for e in self.exprs[:-1]): - for i, e in enumerate(self.exprs[:-1]): - if e is None: - continue - if (isinstance(e, ParseExpression) - and e.exprs and isinstance(e.exprs[-1], _PendingSkip)): - e.exprs[-1] = e.exprs[-1] + self.exprs[i + 1] - self.exprs[i + 1] = None - self.exprs = [e for e in self.exprs if e is not None] - - super(And, self).streamline() - self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) - return self - - def parseImpl(self, instring, loc, doActions=True): - # pass False as last arg to _parse for first element, since we already - # pre-parsed the string as part of our And pre-parsing - loc, resultlist = self.exprs[0]._parse(instring, loc, doActions, callPreParse=False) - errorStop = False - for e in self.exprs[1:]: - if isinstance(e, And._ErrorStop): - errorStop = True - continue - if errorStop: - try: - loc, exprtokens = e._parse(instring, loc, doActions) - except ParseSyntaxException: - raise - except ParseBaseException as pe: - pe.__traceback__ = None - raise ParseSyntaxException._from_exception(pe) - except IndexError: - raise ParseSyntaxException(instring, len(instring), self.errmsg, self) - else: - loc, exprtokens = e._parse(instring, loc, doActions) - if exprtokens or exprtokens.haskeys(): - resultlist += exprtokens - return loc, resultlist - - def __iadd__(self, other): - if isinstance(other, basestring): - other = self._literalStringClass(other) - return self.append(other) # And([self, other]) - - def checkRecursion(self, parseElementList): - subRecCheckList = parseElementList[:] + [self] - for e in self.exprs: - e.checkRecursion(subRecCheckList) - if not e.mayReturnEmpty: - break - - def __str__(self): - if hasattr(self, "name"): - return self.name - - if self.strRepr is None: - self.strRepr = "{" + " ".join(_ustr(e) for e in self.exprs) + "}" - - return self.strRepr - - -class Or(ParseExpression): - """Requires that at least one :class:`ParseExpression` is found. If - two expressions match, the expression that matches the longest - string will be used. May be constructed using the ``'^'`` - operator. - - Example:: - - # construct Or using '^' operator - - number = Word(nums) ^ Combine(Word(nums) + '.' + Word(nums)) - print(number.searchString("123 3.1416 789")) - - prints:: - - [['123'], ['3.1416'], ['789']] - """ - def __init__(self, exprs, savelist=False): - super(Or, self).__init__(exprs, savelist) - if self.exprs: - self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) - else: - self.mayReturnEmpty = True - - def streamline(self): - super(Or, self).streamline() - if __compat__.collect_all_And_tokens: - self.saveAsList = any(e.saveAsList for e in self.exprs) - return self - - def parseImpl(self, instring, loc, doActions=True): - maxExcLoc = -1 - maxException = None - matches = [] - for e in self.exprs: - try: - loc2 = e.tryParse(instring, loc) - except ParseException as err: - err.__traceback__ = None - if err.loc > maxExcLoc: - maxException = err - maxExcLoc = err.loc - except IndexError: - if len(instring) > maxExcLoc: - maxException = ParseException(instring, len(instring), e.errmsg, self) - maxExcLoc = len(instring) - else: - # save match among all matches, to retry longest to shortest - matches.append((loc2, e)) - - if matches: - # re-evaluate all matches in descending order of length of match, in case attached actions - # might change whether or how much they match of the input. - matches.sort(key=itemgetter(0), reverse=True) - - if not doActions: - # no further conditions or parse actions to change the selection of - # alternative, so the first match will be the best match - best_expr = matches[0][1] - return best_expr._parse(instring, loc, doActions) - - longest = -1, None - for loc1, expr1 in matches: - if loc1 <= longest[0]: - # already have a longer match than this one will deliver, we are done - return longest - - try: - loc2, toks = expr1._parse(instring, loc, doActions) - except ParseException as err: - err.__traceback__ = None - if err.loc > maxExcLoc: - maxException = err - maxExcLoc = err.loc - else: - if loc2 >= loc1: - return loc2, toks - # didn't match as much as before - elif loc2 > longest[0]: - longest = loc2, toks - - if longest != (-1, None): - return longest - - if maxException is not None: - maxException.msg = self.errmsg - raise maxException - else: - raise ParseException(instring, loc, "no defined alternatives to match", self) - - - def __ixor__(self, other): - if isinstance(other, basestring): - other = self._literalStringClass(other) - return self.append(other) # Or([self, other]) - - def __str__(self): - if hasattr(self, "name"): - return self.name - - if self.strRepr is None: - self.strRepr = "{" + " ^ ".join(_ustr(e) for e in self.exprs) + "}" - - return self.strRepr - - def checkRecursion(self, parseElementList): - subRecCheckList = parseElementList[:] + [self] - for e in self.exprs: - e.checkRecursion(subRecCheckList) - - def _setResultsName(self, name, listAllMatches=False): - if (not __compat__.collect_all_And_tokens - and __diag__.warn_multiple_tokens_in_named_alternation): - if any(isinstance(e, And) for e in self.exprs): - warnings.warn("{0}: setting results name {1!r} on {2} expression " - "may only return a single token for an And alternative, " - "in future will return the full list of tokens".format( - "warn_multiple_tokens_in_named_alternation", name, type(self).__name__), - stacklevel=3) - - return super(Or, self)._setResultsName(name, listAllMatches) - - -class MatchFirst(ParseExpression): - """Requires that at least one :class:`ParseExpression` is found. If - two expressions match, the first one listed is the one that will - match. May be constructed using the ``'|'`` operator. - - Example:: - - # construct MatchFirst using '|' operator - - # watch the order of expressions to match - number = Word(nums) | Combine(Word(nums) + '.' + Word(nums)) - print(number.searchString("123 3.1416 789")) # Fail! -> [['123'], ['3'], ['1416'], ['789']] - - # put more selective expression first - number = Combine(Word(nums) + '.' + Word(nums)) | Word(nums) - print(number.searchString("123 3.1416 789")) # Better -> [['123'], ['3.1416'], ['789']] - """ - def __init__(self, exprs, savelist=False): - super(MatchFirst, self).__init__(exprs, savelist) - if self.exprs: - self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs) - else: - self.mayReturnEmpty = True - - def streamline(self): - super(MatchFirst, self).streamline() - if __compat__.collect_all_And_tokens: - self.saveAsList = any(e.saveAsList for e in self.exprs) - return self - - def parseImpl(self, instring, loc, doActions=True): - maxExcLoc = -1 - maxException = None - for e in self.exprs: - try: - ret = e._parse(instring, loc, doActions) - return ret - except ParseException as err: - if err.loc > maxExcLoc: - maxException = err - maxExcLoc = err.loc - except IndexError: - if len(instring) > maxExcLoc: - maxException = ParseException(instring, len(instring), e.errmsg, self) - maxExcLoc = len(instring) - - # only got here if no expression matched, raise exception for match that made it the furthest - else: - if maxException is not None: - maxException.msg = self.errmsg - raise maxException - else: - raise ParseException(instring, loc, "no defined alternatives to match", self) - - def __ior__(self, other): - if isinstance(other, basestring): - other = self._literalStringClass(other) - return self.append(other) # MatchFirst([self, other]) - - def __str__(self): - if hasattr(self, "name"): - return self.name - - if self.strRepr is None: - self.strRepr = "{" + " | ".join(_ustr(e) for e in self.exprs) + "}" - - return self.strRepr - - def checkRecursion(self, parseElementList): - subRecCheckList = parseElementList[:] + [self] - for e in self.exprs: - e.checkRecursion(subRecCheckList) - - def _setResultsName(self, name, listAllMatches=False): - if (not __compat__.collect_all_And_tokens - and __diag__.warn_multiple_tokens_in_named_alternation): - if any(isinstance(e, And) for e in self.exprs): - warnings.warn("{0}: setting results name {1!r} on {2} expression " - "may only return a single token for an And alternative, " - "in future will return the full list of tokens".format( - "warn_multiple_tokens_in_named_alternation", name, type(self).__name__), - stacklevel=3) - - return super(MatchFirst, self)._setResultsName(name, listAllMatches) - - -class Each(ParseExpression): - """Requires all given :class:`ParseExpression` s to be found, but in - any order. Expressions may be separated by whitespace. - - May be constructed using the ``'&'`` operator. - - Example:: - - color = oneOf("RED ORANGE YELLOW GREEN BLUE PURPLE BLACK WHITE BROWN") - shape_type = oneOf("SQUARE CIRCLE TRIANGLE STAR HEXAGON OCTAGON") - integer = Word(nums) - shape_attr = "shape:" + shape_type("shape") - posn_attr = "posn:" + Group(integer("x") + ',' + integer("y"))("posn") - color_attr = "color:" + color("color") - size_attr = "size:" + integer("size") - - # use Each (using operator '&') to accept attributes in any order - # (shape and posn are required, color and size are optional) - shape_spec = shape_attr & posn_attr & Optional(color_attr) & Optional(size_attr) - - shape_spec.runTests(''' - shape: SQUARE color: BLACK posn: 100, 120 - shape: CIRCLE size: 50 color: BLUE posn: 50,80 - color:GREEN size:20 shape:TRIANGLE posn:20,40 - ''' - ) - - prints:: - - shape: SQUARE color: BLACK posn: 100, 120 - ['shape:', 'SQUARE', 'color:', 'BLACK', 'posn:', ['100', ',', '120']] - - color: BLACK - - posn: ['100', ',', '120'] - - x: 100 - - y: 120 - - shape: SQUARE - - - shape: CIRCLE size: 50 color: BLUE posn: 50,80 - ['shape:', 'CIRCLE', 'size:', '50', 'color:', 'BLUE', 'posn:', ['50', ',', '80']] - - color: BLUE - - posn: ['50', ',', '80'] - - x: 50 - - y: 80 - - shape: CIRCLE - - size: 50 - - - color: GREEN size: 20 shape: TRIANGLE posn: 20,40 - ['color:', 'GREEN', 'size:', '20', 'shape:', 'TRIANGLE', 'posn:', ['20', ',', '40']] - - color: GREEN - - posn: ['20', ',', '40'] - - x: 20 - - y: 40 - - shape: TRIANGLE - - size: 20 - """ - def __init__(self, exprs, savelist=True): - super(Each, self).__init__(exprs, savelist) - self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) - self.skipWhitespace = True - self.initExprGroups = True - self.saveAsList = True - - def streamline(self): - super(Each, self).streamline() - self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs) - return self - - def parseImpl(self, instring, loc, doActions=True): - if self.initExprGroups: - self.opt1map = dict((id(e.expr), e) for e in self.exprs if isinstance(e, Optional)) - opt1 = [e.expr for e in self.exprs if isinstance(e, Optional)] - opt2 = [e for e in self.exprs if e.mayReturnEmpty and not isinstance(e, (Optional, Regex))] - self.optionals = opt1 + opt2 - self.multioptionals = [e.expr for e in self.exprs if isinstance(e, ZeroOrMore)] - self.multirequired = [e.expr for e in self.exprs if isinstance(e, OneOrMore)] - self.required = [e for e in self.exprs if not isinstance(e, (Optional, ZeroOrMore, OneOrMore))] - self.required += self.multirequired - self.initExprGroups = False - tmpLoc = loc - tmpReqd = self.required[:] - tmpOpt = self.optionals[:] - matchOrder = [] - - keepMatching = True - while keepMatching: - tmpExprs = tmpReqd + tmpOpt + self.multioptionals + self.multirequired - failed = [] - for e in tmpExprs: - try: - tmpLoc = e.tryParse(instring, tmpLoc) - except ParseException: - failed.append(e) - else: - matchOrder.append(self.opt1map.get(id(e), e)) - if e in tmpReqd: - tmpReqd.remove(e) - elif e in tmpOpt: - tmpOpt.remove(e) - if len(failed) == len(tmpExprs): - keepMatching = False - - if tmpReqd: - missing = ", ".join(_ustr(e) for e in tmpReqd) - raise ParseException(instring, loc, "Missing one or more required elements (%s)" % missing) - - # add any unmatched Optionals, in case they have default values defined - matchOrder += [e for e in self.exprs if isinstance(e, Optional) and e.expr in tmpOpt] - - resultlist = [] - for e in matchOrder: - loc, results = e._parse(instring, loc, doActions) - resultlist.append(results) - - finalResults = sum(resultlist, ParseResults([])) - return loc, finalResults - - def __str__(self): - if hasattr(self, "name"): - return self.name - - if self.strRepr is None: - self.strRepr = "{" + " & ".join(_ustr(e) for e in self.exprs) + "}" - - return self.strRepr - - def checkRecursion(self, parseElementList): - subRecCheckList = parseElementList[:] + [self] - for e in self.exprs: - e.checkRecursion(subRecCheckList) - - -class ParseElementEnhance(ParserElement): - """Abstract subclass of :class:`ParserElement`, for combining and - post-processing parsed tokens. - """ - def __init__(self, expr, savelist=False): - super(ParseElementEnhance, self).__init__(savelist) - if isinstance(expr, basestring): - if issubclass(self._literalStringClass, Token): - expr = self._literalStringClass(expr) - else: - expr = self._literalStringClass(Literal(expr)) - self.expr = expr - self.strRepr = None - if expr is not None: - self.mayIndexError = expr.mayIndexError - self.mayReturnEmpty = expr.mayReturnEmpty - self.setWhitespaceChars(expr.whiteChars) - self.skipWhitespace = expr.skipWhitespace - self.saveAsList = expr.saveAsList - self.callPreparse = expr.callPreparse - self.ignoreExprs.extend(expr.ignoreExprs) - - def parseImpl(self, instring, loc, doActions=True): - if self.expr is not None: - return self.expr._parse(instring, loc, doActions, callPreParse=False) - else: - raise ParseException("", loc, self.errmsg, self) - - def leaveWhitespace(self): - self.skipWhitespace = False - self.expr = self.expr.copy() - if self.expr is not None: - self.expr.leaveWhitespace() - return self - - def ignore(self, other): - if isinstance(other, Suppress): - if other not in self.ignoreExprs: - super(ParseElementEnhance, self).ignore(other) - if self.expr is not None: - self.expr.ignore(self.ignoreExprs[-1]) - else: - super(ParseElementEnhance, self).ignore(other) - if self.expr is not None: - self.expr.ignore(self.ignoreExprs[-1]) - return self - - def streamline(self): - super(ParseElementEnhance, self).streamline() - if self.expr is not None: - self.expr.streamline() - return self - - def checkRecursion(self, parseElementList): - if self in parseElementList: - raise RecursiveGrammarException(parseElementList + [self]) - subRecCheckList = parseElementList[:] + [self] - if self.expr is not None: - self.expr.checkRecursion(subRecCheckList) - - def validate(self, validateTrace=None): - if validateTrace is None: - validateTrace = [] - tmp = validateTrace[:] + [self] - if self.expr is not None: - self.expr.validate(tmp) - self.checkRecursion([]) - - def __str__(self): - try: - return super(ParseElementEnhance, self).__str__() - except Exception: - pass - - if self.strRepr is None and self.expr is not None: - self.strRepr = "%s:(%s)" % (self.__class__.__name__, _ustr(self.expr)) - return self.strRepr - - -class FollowedBy(ParseElementEnhance): - """Lookahead matching of the given parse expression. - ``FollowedBy`` does *not* advance the parsing position within - the input string, it only verifies that the specified parse - expression matches at the current position. ``FollowedBy`` - always returns a null token list. If any results names are defined - in the lookahead expression, those *will* be returned for access by - name. - - Example:: - - # use FollowedBy to match a label only if it is followed by a ':' - data_word = Word(alphas) - label = data_word + FollowedBy(':') - attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) - - OneOrMore(attr_expr).parseString("shape: SQUARE color: BLACK posn: upper left").pprint() - - prints:: - - [['shape', 'SQUARE'], ['color', 'BLACK'], ['posn', 'upper left']] - """ - def __init__(self, expr): - super(FollowedBy, self).__init__(expr) - self.mayReturnEmpty = True - - def parseImpl(self, instring, loc, doActions=True): - # by using self._expr.parse and deleting the contents of the returned ParseResults list - # we keep any named results that were defined in the FollowedBy expression - _, ret = self.expr._parse(instring, loc, doActions=doActions) - del ret[:] - - return loc, ret - - -class PrecededBy(ParseElementEnhance): - """Lookbehind matching of the given parse expression. - ``PrecededBy`` does not advance the parsing position within the - input string, it only verifies that the specified parse expression - matches prior to the current position. ``PrecededBy`` always - returns a null token list, but if a results name is defined on the - given expression, it is returned. - - Parameters: - - - expr - expression that must match prior to the current parse - location - - retreat - (default= ``None``) - (int) maximum number of characters - to lookbehind prior to the current parse location - - If the lookbehind expression is a string, Literal, Keyword, or - a Word or CharsNotIn with a specified exact or maximum length, then - the retreat parameter is not required. Otherwise, retreat must be - specified to give a maximum number of characters to look back from - the current parse position for a lookbehind match. - - Example:: - - # VB-style variable names with type prefixes - int_var = PrecededBy("#") + pyparsing_common.identifier - str_var = PrecededBy("$") + pyparsing_common.identifier - - """ - def __init__(self, expr, retreat=None): - super(PrecededBy, self).__init__(expr) - self.expr = self.expr().leaveWhitespace() - self.mayReturnEmpty = True - self.mayIndexError = False - self.exact = False - if isinstance(expr, str): - retreat = len(expr) - self.exact = True - elif isinstance(expr, (Literal, Keyword)): - retreat = expr.matchLen - self.exact = True - elif isinstance(expr, (Word, CharsNotIn)) and expr.maxLen != _MAX_INT: - retreat = expr.maxLen - self.exact = True - elif isinstance(expr, _PositionToken): - retreat = 0 - self.exact = True - self.retreat = retreat - self.errmsg = "not preceded by " + str(expr) - self.skipWhitespace = False - self.parseAction.append(lambda s, l, t: t.__delitem__(slice(None, None))) - - def parseImpl(self, instring, loc=0, doActions=True): - if self.exact: - if loc < self.retreat: - raise ParseException(instring, loc, self.errmsg) - start = loc - self.retreat - _, ret = self.expr._parse(instring, start) - else: - # retreat specified a maximum lookbehind window, iterate - test_expr = self.expr + StringEnd() - instring_slice = instring[max(0, loc - self.retreat):loc] - last_expr = ParseException(instring, loc, self.errmsg) - for offset in range(1, min(loc, self.retreat + 1)+1): - try: - # print('trying', offset, instring_slice, repr(instring_slice[loc - offset:])) - _, ret = test_expr._parse(instring_slice, len(instring_slice) - offset) - except ParseBaseException as pbe: - last_expr = pbe - else: - break - else: - raise last_expr - return loc, ret - - -class NotAny(ParseElementEnhance): - """Lookahead to disallow matching with the given parse expression. - ``NotAny`` does *not* advance the parsing position within the - input string, it only verifies that the specified parse expression - does *not* match at the current position. Also, ``NotAny`` does - *not* skip over leading whitespace. ``NotAny`` always returns - a null token list. May be constructed using the '~' operator. - - Example:: - - AND, OR, NOT = map(CaselessKeyword, "AND OR NOT".split()) - - # take care not to mistake keywords for identifiers - ident = ~(AND | OR | NOT) + Word(alphas) - boolean_term = Optional(NOT) + ident - - # very crude boolean expression - to support parenthesis groups and - # operation hierarchy, use infixNotation - boolean_expr = boolean_term + ZeroOrMore((AND | OR) + boolean_term) - - # integers that are followed by "." are actually floats - integer = Word(nums) + ~Char(".") - """ - def __init__(self, expr): - super(NotAny, self).__init__(expr) - # ~ self.leaveWhitespace() - self.skipWhitespace = False # do NOT use self.leaveWhitespace(), don't want to propagate to exprs - self.mayReturnEmpty = True - self.errmsg = "Found unwanted token, " + _ustr(self.expr) - - def parseImpl(self, instring, loc, doActions=True): - if self.expr.canParseNext(instring, loc): - raise ParseException(instring, loc, self.errmsg, self) - return loc, [] - - def __str__(self): - if hasattr(self, "name"): - return self.name - - if self.strRepr is None: - self.strRepr = "~{" + _ustr(self.expr) + "}" - - return self.strRepr - -class _MultipleMatch(ParseElementEnhance): - def __init__(self, expr, stopOn=None): - super(_MultipleMatch, self).__init__(expr) - self.saveAsList = True - ender = stopOn - if isinstance(ender, basestring): - ender = self._literalStringClass(ender) - self.stopOn(ender) - - def stopOn(self, ender): - if isinstance(ender, basestring): - ender = self._literalStringClass(ender) - self.not_ender = ~ender if ender is not None else None - return self - - def parseImpl(self, instring, loc, doActions=True): - self_expr_parse = self.expr._parse - self_skip_ignorables = self._skipIgnorables - check_ender = self.not_ender is not None - if check_ender: - try_not_ender = self.not_ender.tryParse - - # must be at least one (but first see if we are the stopOn sentinel; - # if so, fail) - if check_ender: - try_not_ender(instring, loc) - loc, tokens = self_expr_parse(instring, loc, doActions, callPreParse=False) - try: - hasIgnoreExprs = (not not self.ignoreExprs) - while 1: - if check_ender: - try_not_ender(instring, loc) - if hasIgnoreExprs: - preloc = self_skip_ignorables(instring, loc) - else: - preloc = loc - loc, tmptokens = self_expr_parse(instring, preloc, doActions) - if tmptokens or tmptokens.haskeys(): - tokens += tmptokens - except (ParseException, IndexError): - pass - - return loc, tokens - - def _setResultsName(self, name, listAllMatches=False): - if __diag__.warn_ungrouped_named_tokens_in_collection: - for e in [self.expr] + getattr(self.expr, 'exprs', []): - if isinstance(e, ParserElement) and e.resultsName: - warnings.warn("{0}: setting results name {1!r} on {2} expression " - "collides with {3!r} on contained expression".format("warn_ungrouped_named_tokens_in_collection", - name, - type(self).__name__, - e.resultsName), - stacklevel=3) - - return super(_MultipleMatch, self)._setResultsName(name, listAllMatches) - - -class OneOrMore(_MultipleMatch): - """Repetition of one or more of the given expression. - - Parameters: - - expr - expression that must match one or more times - - stopOn - (default= ``None``) - expression for a terminating sentinel - (only required if the sentinel would ordinarily match the repetition - expression) - - Example:: - - data_word = Word(alphas) - label = data_word + FollowedBy(':') - attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join)) - - text = "shape: SQUARE posn: upper left color: BLACK" - OneOrMore(attr_expr).parseString(text).pprint() # Fail! read 'color' as data instead of next label -> [['shape', 'SQUARE color']] - - # use stopOn attribute for OneOrMore to avoid reading label string as part of the data - attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) - OneOrMore(attr_expr).parseString(text).pprint() # Better -> [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'BLACK']] - - # could also be written as - (attr_expr * (1,)).parseString(text).pprint() - """ - - def __str__(self): - if hasattr(self, "name"): - return self.name - - if self.strRepr is None: - self.strRepr = "{" + _ustr(self.expr) + "}..." - - return self.strRepr - -class ZeroOrMore(_MultipleMatch): - """Optional repetition of zero or more of the given expression. - - Parameters: - - expr - expression that must match zero or more times - - stopOn - (default= ``None``) - expression for a terminating sentinel - (only required if the sentinel would ordinarily match the repetition - expression) - - Example: similar to :class:`OneOrMore` - """ - def __init__(self, expr, stopOn=None): - super(ZeroOrMore, self).__init__(expr, stopOn=stopOn) - self.mayReturnEmpty = True - - def parseImpl(self, instring, loc, doActions=True): - try: - return super(ZeroOrMore, self).parseImpl(instring, loc, doActions) - except (ParseException, IndexError): - return loc, [] - - def __str__(self): - if hasattr(self, "name"): - return self.name - - if self.strRepr is None: - self.strRepr = "[" + _ustr(self.expr) + "]..." - - return self.strRepr - - -class _NullToken(object): - def __bool__(self): - return False - __nonzero__ = __bool__ - def __str__(self): - return "" - -class Optional(ParseElementEnhance): - """Optional matching of the given expression. - - Parameters: - - expr - expression that must match zero or more times - - default (optional) - value to be returned if the optional expression is not found. - - Example:: - - # US postal code can be a 5-digit zip, plus optional 4-digit qualifier - zip = Combine(Word(nums, exact=5) + Optional('-' + Word(nums, exact=4))) - zip.runTests(''' - # traditional ZIP code - 12345 - - # ZIP+4 form - 12101-0001 - - # invalid ZIP - 98765- - ''') - - prints:: - - # traditional ZIP code - 12345 - ['12345'] - - # ZIP+4 form - 12101-0001 - ['12101-0001'] - - # invalid ZIP - 98765- - ^ - FAIL: Expected end of text (at char 5), (line:1, col:6) - """ - __optionalNotMatched = _NullToken() - - def __init__(self, expr, default=__optionalNotMatched): - super(Optional, self).__init__(expr, savelist=False) - self.saveAsList = self.expr.saveAsList - self.defaultValue = default - self.mayReturnEmpty = True - - def parseImpl(self, instring, loc, doActions=True): - try: - loc, tokens = self.expr._parse(instring, loc, doActions, callPreParse=False) - except (ParseException, IndexError): - if self.defaultValue is not self.__optionalNotMatched: - if self.expr.resultsName: - tokens = ParseResults([self.defaultValue]) - tokens[self.expr.resultsName] = self.defaultValue - else: - tokens = [self.defaultValue] - else: - tokens = [] - return loc, tokens - - def __str__(self): - if hasattr(self, "name"): - return self.name - - if self.strRepr is None: - self.strRepr = "[" + _ustr(self.expr) + "]" - - return self.strRepr - -class SkipTo(ParseElementEnhance): - """Token for skipping over all undefined text until the matched - expression is found. - - Parameters: - - expr - target expression marking the end of the data to be skipped - - include - (default= ``False``) if True, the target expression is also parsed - (the skipped text and target expression are returned as a 2-element list). - - ignore - (default= ``None``) used to define grammars (typically quoted strings and - comments) that might contain false matches to the target expression - - failOn - (default= ``None``) define expressions that are not allowed to be - included in the skipped test; if found before the target expression is found, - the SkipTo is not a match - - Example:: - - report = ''' - Outstanding Issues Report - 1 Jan 2000 - - # | Severity | Description | Days Open - -----+----------+-------------------------------------------+----------- - 101 | Critical | Intermittent system crash | 6 - 94 | Cosmetic | Spelling error on Login ('log|n') | 14 - 79 | Minor | System slow when running too many reports | 47 - ''' - integer = Word(nums) - SEP = Suppress('|') - # use SkipTo to simply match everything up until the next SEP - # - ignore quoted strings, so that a '|' character inside a quoted string does not match - # - parse action will call token.strip() for each matched token, i.e., the description body - string_data = SkipTo(SEP, ignore=quotedString) - string_data.setParseAction(tokenMap(str.strip)) - ticket_expr = (integer("issue_num") + SEP - + string_data("sev") + SEP - + string_data("desc") + SEP - + integer("days_open")) - - for tkt in ticket_expr.searchString(report): - print tkt.dump() - - prints:: - - ['101', 'Critical', 'Intermittent system crash', '6'] - - days_open: 6 - - desc: Intermittent system crash - - issue_num: 101 - - sev: Critical - ['94', 'Cosmetic', "Spelling error on Login ('log|n')", '14'] - - days_open: 14 - - desc: Spelling error on Login ('log|n') - - issue_num: 94 - - sev: Cosmetic - ['79', 'Minor', 'System slow when running too many reports', '47'] - - days_open: 47 - - desc: System slow when running too many reports - - issue_num: 79 - - sev: Minor - """ - def __init__(self, other, include=False, ignore=None, failOn=None): - super(SkipTo, self).__init__(other) - self.ignoreExpr = ignore - self.mayReturnEmpty = True - self.mayIndexError = False - self.includeMatch = include - self.saveAsList = False - if isinstance(failOn, basestring): - self.failOn = self._literalStringClass(failOn) - else: - self.failOn = failOn - self.errmsg = "No match found for " + _ustr(self.expr) - - def parseImpl(self, instring, loc, doActions=True): - startloc = loc - instrlen = len(instring) - expr = self.expr - expr_parse = self.expr._parse - self_failOn_canParseNext = self.failOn.canParseNext if self.failOn is not None else None - self_ignoreExpr_tryParse = self.ignoreExpr.tryParse if self.ignoreExpr is not None else None - - tmploc = loc - while tmploc <= instrlen: - if self_failOn_canParseNext is not None: - # break if failOn expression matches - if self_failOn_canParseNext(instring, tmploc): - break - - if self_ignoreExpr_tryParse is not None: - # advance past ignore expressions - while 1: - try: - tmploc = self_ignoreExpr_tryParse(instring, tmploc) - except ParseBaseException: - break - - try: - expr_parse(instring, tmploc, doActions=False, callPreParse=False) - except (ParseException, IndexError): - # no match, advance loc in string - tmploc += 1 - else: - # matched skipto expr, done - break - - else: - # ran off the end of the input string without matching skipto expr, fail - raise ParseException(instring, loc, self.errmsg, self) - - # build up return values - loc = tmploc - skiptext = instring[startloc:loc] - skipresult = ParseResults(skiptext) - - if self.includeMatch: - loc, mat = expr_parse(instring, loc, doActions, callPreParse=False) - skipresult += mat - - return loc, skipresult - -class Forward(ParseElementEnhance): - """Forward declaration of an expression to be defined later - - used for recursive grammars, such as algebraic infix notation. - When the expression is known, it is assigned to the ``Forward`` - variable using the '<<' operator. - - Note: take care when assigning to ``Forward`` not to overlook - precedence of operators. - - Specifically, '|' has a lower precedence than '<<', so that:: - - fwdExpr << a | b | c - - will actually be evaluated as:: - - (fwdExpr << a) | b | c - - thereby leaving b and c out as parseable alternatives. It is recommended that you - explicitly group the values inserted into the ``Forward``:: - - fwdExpr << (a | b | c) - - Converting to use the '<<=' operator instead will avoid this problem. - - See :class:`ParseResults.pprint` for an example of a recursive - parser created using ``Forward``. - """ - def __init__(self, other=None): - super(Forward, self).__init__(other, savelist=False) - - def __lshift__(self, other): - if isinstance(other, basestring): - other = self._literalStringClass(other) - self.expr = other - self.strRepr = None - self.mayIndexError = self.expr.mayIndexError - self.mayReturnEmpty = self.expr.mayReturnEmpty - self.setWhitespaceChars(self.expr.whiteChars) - self.skipWhitespace = self.expr.skipWhitespace - self.saveAsList = self.expr.saveAsList - self.ignoreExprs.extend(self.expr.ignoreExprs) - return self - - def __ilshift__(self, other): - return self << other - - def leaveWhitespace(self): - self.skipWhitespace = False - return self - - def streamline(self): - if not self.streamlined: - self.streamlined = True - if self.expr is not None: - self.expr.streamline() - return self - - def validate(self, validateTrace=None): - if validateTrace is None: - validateTrace = [] - - if self not in validateTrace: - tmp = validateTrace[:] + [self] - if self.expr is not None: - self.expr.validate(tmp) - self.checkRecursion([]) - - def __str__(self): - if hasattr(self, "name"): - return self.name - if self.strRepr is not None: - return self.strRepr - - # Avoid infinite recursion by setting a temporary strRepr - self.strRepr = ": ..." - - # Use the string representation of main expression. - retString = '...' - try: - if self.expr is not None: - retString = _ustr(self.expr)[:1000] - else: - retString = "None" - finally: - self.strRepr = self.__class__.__name__ + ": " + retString - return self.strRepr - - def copy(self): - if self.expr is not None: - return super(Forward, self).copy() - else: - ret = Forward() - ret <<= self - return ret - - def _setResultsName(self, name, listAllMatches=False): - if __diag__.warn_name_set_on_empty_Forward: - if self.expr is None: - warnings.warn("{0}: setting results name {0!r} on {1} expression " - "that has no contained expression".format("warn_name_set_on_empty_Forward", - name, - type(self).__name__), - stacklevel=3) - - return super(Forward, self)._setResultsName(name, listAllMatches) - -class TokenConverter(ParseElementEnhance): - """ - Abstract subclass of :class:`ParseExpression`, for converting parsed results. - """ - def __init__(self, expr, savelist=False): - super(TokenConverter, self).__init__(expr) # , savelist) - self.saveAsList = False - -class Combine(TokenConverter): - """Converter to concatenate all matching tokens to a single string. - By default, the matching patterns must also be contiguous in the - input string; this can be disabled by specifying - ``'adjacent=False'`` in the constructor. - - Example:: - - real = Word(nums) + '.' + Word(nums) - print(real.parseString('3.1416')) # -> ['3', '.', '1416'] - # will also erroneously match the following - print(real.parseString('3. 1416')) # -> ['3', '.', '1416'] - - real = Combine(Word(nums) + '.' + Word(nums)) - print(real.parseString('3.1416')) # -> ['3.1416'] - # no match when there are internal spaces - print(real.parseString('3. 1416')) # -> Exception: Expected W:(0123...) - """ - def __init__(self, expr, joinString="", adjacent=True): - super(Combine, self).__init__(expr) - # suppress whitespace-stripping in contained parse expressions, but re-enable it on the Combine itself - if adjacent: - self.leaveWhitespace() - self.adjacent = adjacent - self.skipWhitespace = True - self.joinString = joinString - self.callPreparse = True - - def ignore(self, other): - if self.adjacent: - ParserElement.ignore(self, other) - else: - super(Combine, self).ignore(other) - return self - - def postParse(self, instring, loc, tokenlist): - retToks = tokenlist.copy() - del retToks[:] - retToks += ParseResults(["".join(tokenlist._asStringList(self.joinString))], modal=self.modalResults) - - if self.resultsName and retToks.haskeys(): - return [retToks] - else: - return retToks - -class Group(TokenConverter): - """Converter to return the matched tokens as a list - useful for - returning tokens of :class:`ZeroOrMore` and :class:`OneOrMore` expressions. - - Example:: - - ident = Word(alphas) - num = Word(nums) - term = ident | num - func = ident + Optional(delimitedList(term)) - print(func.parseString("fn a, b, 100")) # -> ['fn', 'a', 'b', '100'] - - func = ident + Group(Optional(delimitedList(term))) - print(func.parseString("fn a, b, 100")) # -> ['fn', ['a', 'b', '100']] - """ - def __init__(self, expr): - super(Group, self).__init__(expr) - self.saveAsList = True - - def postParse(self, instring, loc, tokenlist): - return [tokenlist] - -class Dict(TokenConverter): - """Converter to return a repetitive expression as a list, but also - as a dictionary. Each element can also be referenced using the first - token in the expression as its key. Useful for tabular report - scraping when the first column can be used as a item key. - - Example:: - - data_word = Word(alphas) - label = data_word + FollowedBy(':') - attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join)) - - text = "shape: SQUARE posn: upper left color: light blue texture: burlap" - attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) - - # print attributes as plain groups - print(OneOrMore(attr_expr).parseString(text).dump()) - - # instead of OneOrMore(expr), parse using Dict(OneOrMore(Group(expr))) - Dict will auto-assign names - result = Dict(OneOrMore(Group(attr_expr))).parseString(text) - print(result.dump()) - - # access named fields as dict entries, or output as dict - print(result['shape']) - print(result.asDict()) - - prints:: - - ['shape', 'SQUARE', 'posn', 'upper left', 'color', 'light blue', 'texture', 'burlap'] - [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] - - color: light blue - - posn: upper left - - shape: SQUARE - - texture: burlap - SQUARE - {'color': 'light blue', 'posn': 'upper left', 'texture': 'burlap', 'shape': 'SQUARE'} - - See more examples at :class:`ParseResults` of accessing fields by results name. - """ - def __init__(self, expr): - super(Dict, self).__init__(expr) - self.saveAsList = True - - def postParse(self, instring, loc, tokenlist): - for i, tok in enumerate(tokenlist): - if len(tok) == 0: - continue - ikey = tok[0] - if isinstance(ikey, int): - ikey = _ustr(tok[0]).strip() - if len(tok) == 1: - tokenlist[ikey] = _ParseResultsWithOffset("", i) - elif len(tok) == 2 and not isinstance(tok[1], ParseResults): - tokenlist[ikey] = _ParseResultsWithOffset(tok[1], i) - else: - dictvalue = tok.copy() # ParseResults(i) - del dictvalue[0] - if len(dictvalue) != 1 or (isinstance(dictvalue, ParseResults) and dictvalue.haskeys()): - tokenlist[ikey] = _ParseResultsWithOffset(dictvalue, i) - else: - tokenlist[ikey] = _ParseResultsWithOffset(dictvalue[0], i) - - if self.resultsName: - return [tokenlist] - else: - return tokenlist - - -class Suppress(TokenConverter): - """Converter for ignoring the results of a parsed expression. - - Example:: - - source = "a, b, c,d" - wd = Word(alphas) - wd_list1 = wd + ZeroOrMore(',' + wd) - print(wd_list1.parseString(source)) - - # often, delimiters that are useful during parsing are just in the - # way afterward - use Suppress to keep them out of the parsed output - wd_list2 = wd + ZeroOrMore(Suppress(',') + wd) - print(wd_list2.parseString(source)) - - prints:: - - ['a', ',', 'b', ',', 'c', ',', 'd'] - ['a', 'b', 'c', 'd'] - - (See also :class:`delimitedList`.) - """ - def postParse(self, instring, loc, tokenlist): - return [] - - def suppress(self): - return self - - -class OnlyOnce(object): - """Wrapper for parse actions, to ensure they are only called once. - """ - def __init__(self, methodCall): - self.callable = _trim_arity(methodCall) - self.called = False - def __call__(self, s, l, t): - if not self.called: - results = self.callable(s, l, t) - self.called = True - return results - raise ParseException(s, l, "") - def reset(self): - self.called = False - -def traceParseAction(f): - """Decorator for debugging parse actions. - - When the parse action is called, this decorator will print - ``">> entering method-name(line:<current_source_line>, <parse_location>, <matched_tokens>)"``. - When the parse action completes, the decorator will print - ``"<<"`` followed by the returned value, or any exception that the parse action raised. - - Example:: - - wd = Word(alphas) - - @traceParseAction - def remove_duplicate_chars(tokens): - return ''.join(sorted(set(''.join(tokens)))) - - wds = OneOrMore(wd).setParseAction(remove_duplicate_chars) - print(wds.parseString("slkdjs sld sldd sdlf sdljf")) - - prints:: - - >>entering remove_duplicate_chars(line: 'slkdjs sld sldd sdlf sdljf', 0, (['slkdjs', 'sld', 'sldd', 'sdlf', 'sdljf'], {})) - <<leaving remove_duplicate_chars (ret: 'dfjkls') - ['dfjkls'] - """ - f = _trim_arity(f) - def z(*paArgs): - thisFunc = f.__name__ - s, l, t = paArgs[-3:] - if len(paArgs) > 3: - thisFunc = paArgs[0].__class__.__name__ + '.' + thisFunc - sys.stderr.write(">>entering %s(line: '%s', %d, %r)\n" % (thisFunc, line(l, s), l, t)) - try: - ret = f(*paArgs) - except Exception as exc: - sys.stderr.write("<<leaving %s (exception: %s)\n" % (thisFunc, exc)) - raise - sys.stderr.write("<<leaving %s (ret: %r)\n" % (thisFunc, ret)) - return ret - try: - z.__name__ = f.__name__ - except AttributeError: - pass - return z - -# -# global helpers -# -def delimitedList(expr, delim=",", combine=False): - """Helper to define a delimited list of expressions - the delimiter - defaults to ','. By default, the list elements and delimiters can - have intervening whitespace, and comments, but this can be - overridden by passing ``combine=True`` in the constructor. If - ``combine`` is set to ``True``, the matching tokens are - returned as a single token string, with the delimiters included; - otherwise, the matching tokens are returned as a list of tokens, - with the delimiters suppressed. - - Example:: - - delimitedList(Word(alphas)).parseString("aa,bb,cc") # -> ['aa', 'bb', 'cc'] - delimitedList(Word(hexnums), delim=':', combine=True).parseString("AA:BB:CC:DD:EE") # -> ['AA:BB:CC:DD:EE'] - """ - dlName = _ustr(expr) + " [" + _ustr(delim) + " " + _ustr(expr) + "]..." - if combine: - return Combine(expr + ZeroOrMore(delim + expr)).setName(dlName) - else: - return (expr + ZeroOrMore(Suppress(delim) + expr)).setName(dlName) - -def countedArray(expr, intExpr=None): - """Helper to define a counted list of expressions. - - This helper defines a pattern of the form:: - - integer expr expr expr... - - where the leading integer tells how many expr expressions follow. - The matched tokens returns the array of expr tokens as a list - the - leading count token is suppressed. - - If ``intExpr`` is specified, it should be a pyparsing expression - that produces an integer value. - - Example:: - - countedArray(Word(alphas)).parseString('2 ab cd ef') # -> ['ab', 'cd'] - - # in this parser, the leading integer value is given in binary, - # '10' indicating that 2 values are in the array - binaryConstant = Word('01').setParseAction(lambda t: int(t[0], 2)) - countedArray(Word(alphas), intExpr=binaryConstant).parseString('10 ab cd ef') # -> ['ab', 'cd'] - """ - arrayExpr = Forward() - def countFieldParseAction(s, l, t): - n = t[0] - arrayExpr << (n and Group(And([expr] * n)) or Group(empty)) - return [] - if intExpr is None: - intExpr = Word(nums).setParseAction(lambda t: int(t[0])) - else: - intExpr = intExpr.copy() - intExpr.setName("arrayLen") - intExpr.addParseAction(countFieldParseAction, callDuringTry=True) - return (intExpr + arrayExpr).setName('(len) ' + _ustr(expr) + '...') - -def _flatten(L): - ret = [] - for i in L: - if isinstance(i, list): - ret.extend(_flatten(i)) - else: - ret.append(i) - return ret - -def matchPreviousLiteral(expr): - """Helper to define an expression that is indirectly defined from - the tokens matched in a previous expression, that is, it looks for - a 'repeat' of a previous expression. For example:: - - first = Word(nums) - second = matchPreviousLiteral(first) - matchExpr = first + ":" + second - - will match ``"1:1"``, but not ``"1:2"``. Because this - matches a previous literal, will also match the leading - ``"1:1"`` in ``"1:10"``. If this is not desired, use - :class:`matchPreviousExpr`. Do *not* use with packrat parsing - enabled. - """ - rep = Forward() - def copyTokenToRepeater(s, l, t): - if t: - if len(t) == 1: - rep << t[0] - else: - # flatten t tokens - tflat = _flatten(t.asList()) - rep << And(Literal(tt) for tt in tflat) - else: - rep << Empty() - expr.addParseAction(copyTokenToRepeater, callDuringTry=True) - rep.setName('(prev) ' + _ustr(expr)) - return rep - -def matchPreviousExpr(expr): - """Helper to define an expression that is indirectly defined from - the tokens matched in a previous expression, that is, it looks for - a 'repeat' of a previous expression. For example:: - - first = Word(nums) - second = matchPreviousExpr(first) - matchExpr = first + ":" + second - - will match ``"1:1"``, but not ``"1:2"``. Because this - matches by expressions, will *not* match the leading ``"1:1"`` - in ``"1:10"``; the expressions are evaluated first, and then - compared, so ``"1"`` is compared with ``"10"``. Do *not* use - with packrat parsing enabled. - """ - rep = Forward() - e2 = expr.copy() - rep <<= e2 - def copyTokenToRepeater(s, l, t): - matchTokens = _flatten(t.asList()) - def mustMatchTheseTokens(s, l, t): - theseTokens = _flatten(t.asList()) - if theseTokens != matchTokens: - raise ParseException('', 0, '') - rep.setParseAction(mustMatchTheseTokens, callDuringTry=True) - expr.addParseAction(copyTokenToRepeater, callDuringTry=True) - rep.setName('(prev) ' + _ustr(expr)) - return rep - -def _escapeRegexRangeChars(s): - # ~ escape these chars: ^-[] - for c in r"\^-[]": - s = s.replace(c, _bslash + c) - s = s.replace("\n", r"\n") - s = s.replace("\t", r"\t") - return _ustr(s) - -def oneOf(strs, caseless=False, useRegex=True, asKeyword=False): - """Helper to quickly define a set of alternative Literals, and makes - sure to do longest-first testing when there is a conflict, - regardless of the input order, but returns - a :class:`MatchFirst` for best performance. - - Parameters: - - - strs - a string of space-delimited literals, or a collection of - string literals - - caseless - (default= ``False``) - treat all literals as - caseless - - useRegex - (default= ``True``) - as an optimization, will - generate a Regex object; otherwise, will generate - a :class:`MatchFirst` object (if ``caseless=True`` or ``asKeyword=True``, or if - creating a :class:`Regex` raises an exception) - - asKeyword - (default=``False``) - enforce Keyword-style matching on the - generated expressions - - Example:: - - comp_oper = oneOf("< = > <= >= !=") - var = Word(alphas) - number = Word(nums) - term = var | number - comparison_expr = term + comp_oper + term - print(comparison_expr.searchString("B = 12 AA=23 B<=AA AA>12")) - - prints:: - - [['B', '=', '12'], ['AA', '=', '23'], ['B', '<=', 'AA'], ['AA', '>', '12']] - """ - if isinstance(caseless, basestring): - warnings.warn("More than one string argument passed to oneOf, pass " - "choices as a list or space-delimited string", stacklevel=2) - - if caseless: - isequal = (lambda a, b: a.upper() == b.upper()) - masks = (lambda a, b: b.upper().startswith(a.upper())) - parseElementClass = CaselessKeyword if asKeyword else CaselessLiteral - else: - isequal = (lambda a, b: a == b) - masks = (lambda a, b: b.startswith(a)) - parseElementClass = Keyword if asKeyword else Literal - - symbols = [] - if isinstance(strs, basestring): - symbols = strs.split() - elif isinstance(strs, Iterable): - symbols = list(strs) - else: - warnings.warn("Invalid argument to oneOf, expected string or iterable", - SyntaxWarning, stacklevel=2) - if not symbols: - return NoMatch() - - if not asKeyword: - # if not producing keywords, need to reorder to take care to avoid masking - # longer choices with shorter ones - i = 0 - while i < len(symbols) - 1: - cur = symbols[i] - for j, other in enumerate(symbols[i + 1:]): - if isequal(other, cur): - del symbols[i + j + 1] - break - elif masks(cur, other): - del symbols[i + j + 1] - symbols.insert(i, other) - break - else: - i += 1 - - if not (caseless or asKeyword) and useRegex: - # ~ print (strs, "->", "|".join([_escapeRegexChars(sym) for sym in symbols])) - try: - if len(symbols) == len("".join(symbols)): - return Regex("[%s]" % "".join(_escapeRegexRangeChars(sym) for sym in symbols)).setName(' | '.join(symbols)) - else: - return Regex("|".join(re.escape(sym) for sym in symbols)).setName(' | '.join(symbols)) - except Exception: - warnings.warn("Exception creating Regex for oneOf, building MatchFirst", - SyntaxWarning, stacklevel=2) - - # last resort, just use MatchFirst - return MatchFirst(parseElementClass(sym) for sym in symbols).setName(' | '.join(symbols)) - -def dictOf(key, value): - """Helper to easily and clearly define a dictionary by specifying - the respective patterns for the key and value. Takes care of - defining the :class:`Dict`, :class:`ZeroOrMore`, and - :class:`Group` tokens in the proper order. The key pattern - can include delimiting markers or punctuation, as long as they are - suppressed, thereby leaving the significant key text. The value - pattern can include named results, so that the :class:`Dict` results - can include named token fields. - - Example:: - - text = "shape: SQUARE posn: upper left color: light blue texture: burlap" - attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)) - print(OneOrMore(attr_expr).parseString(text).dump()) - - attr_label = label - attr_value = Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join) - - # similar to Dict, but simpler call format - result = dictOf(attr_label, attr_value).parseString(text) - print(result.dump()) - print(result['shape']) - print(result.shape) # object attribute access works too - print(result.asDict()) - - prints:: - - [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']] - - color: light blue - - posn: upper left - - shape: SQUARE - - texture: burlap - SQUARE - SQUARE - {'color': 'light blue', 'shape': 'SQUARE', 'posn': 'upper left', 'texture': 'burlap'} - """ - return Dict(OneOrMore(Group(key + value))) - -def originalTextFor(expr, asString=True): - """Helper to return the original, untokenized text for a given - expression. Useful to restore the parsed fields of an HTML start - tag into the raw tag text itself, or to revert separate tokens with - intervening whitespace back to the original matching input text. By - default, returns astring containing the original parsed text. - - If the optional ``asString`` argument is passed as - ``False``, then the return value is - a :class:`ParseResults` containing any results names that - were originally matched, and a single token containing the original - matched text from the input string. So if the expression passed to - :class:`originalTextFor` contains expressions with defined - results names, you must set ``asString`` to ``False`` if you - want to preserve those results name values. - - Example:: - - src = "this is test <b> bold <i>text</i> </b> normal text " - for tag in ("b", "i"): - opener, closer = makeHTMLTags(tag) - patt = originalTextFor(opener + SkipTo(closer) + closer) - print(patt.searchString(src)[0]) - - prints:: - - ['<b> bold <i>text</i> </b>'] - ['<i>text</i>'] - """ - locMarker = Empty().setParseAction(lambda s, loc, t: loc) - endlocMarker = locMarker.copy() - endlocMarker.callPreparse = False - matchExpr = locMarker("_original_start") + expr + endlocMarker("_original_end") - if asString: - extractText = lambda s, l, t: s[t._original_start: t._original_end] - else: - def extractText(s, l, t): - t[:] = [s[t.pop('_original_start'):t.pop('_original_end')]] - matchExpr.setParseAction(extractText) - matchExpr.ignoreExprs = expr.ignoreExprs - return matchExpr - -def ungroup(expr): - """Helper to undo pyparsing's default grouping of And expressions, - even if all but one are non-empty. - """ - return TokenConverter(expr).addParseAction(lambda t: t[0]) - -def locatedExpr(expr): - """Helper to decorate a returned token with its starting and ending - locations in the input string. - - This helper adds the following results names: - - - locn_start = location where matched expression begins - - locn_end = location where matched expression ends - - value = the actual parsed results - - Be careful if the input text contains ``<TAB>`` characters, you - may want to call :class:`ParserElement.parseWithTabs` - - Example:: - - wd = Word(alphas) - for match in locatedExpr(wd).searchString("ljsdf123lksdjjf123lkkjj1222"): - print(match) - - prints:: - - [[0, 'ljsdf', 5]] - [[8, 'lksdjjf', 15]] - [[18, 'lkkjj', 23]] - """ - locator = Empty().setParseAction(lambda s, l, t: l) - return Group(locator("locn_start") + expr("value") + locator.copy().leaveWhitespace()("locn_end")) - - -# convenience constants for positional expressions -empty = Empty().setName("empty") -lineStart = LineStart().setName("lineStart") -lineEnd = LineEnd().setName("lineEnd") -stringStart = StringStart().setName("stringStart") -stringEnd = StringEnd().setName("stringEnd") - -_escapedPunc = Word(_bslash, r"\[]-*.$+^?()~ ", exact=2).setParseAction(lambda s, l, t: t[0][1]) -_escapedHexChar = Regex(r"\\0?[xX][0-9a-fA-F]+").setParseAction(lambda s, l, t: unichr(int(t[0].lstrip(r'\0x'), 16))) -_escapedOctChar = Regex(r"\\0[0-7]+").setParseAction(lambda s, l, t: unichr(int(t[0][1:], 8))) -_singleChar = _escapedPunc | _escapedHexChar | _escapedOctChar | CharsNotIn(r'\]', exact=1) -_charRange = Group(_singleChar + Suppress("-") + _singleChar) -_reBracketExpr = Literal("[") + Optional("^").setResultsName("negate") + Group(OneOrMore(_charRange | _singleChar)).setResultsName("body") + "]" - -def srange(s): - r"""Helper to easily define string ranges for use in Word - construction. Borrows syntax from regexp '[]' string range - definitions:: - - srange("[0-9]") -> "0123456789" - srange("[a-z]") -> "abcdefghijklmnopqrstuvwxyz" - srange("[a-z$_]") -> "abcdefghijklmnopqrstuvwxyz$_" - - The input string must be enclosed in []'s, and the returned string - is the expanded character set joined into a single string. The - values enclosed in the []'s may be: - - - a single character - - an escaped character with a leading backslash (such as ``\-`` - or ``\]``) - - an escaped hex character with a leading ``'\x'`` - (``\x21``, which is a ``'!'`` character) (``\0x##`` - is also supported for backwards compatibility) - - an escaped octal character with a leading ``'\0'`` - (``\041``, which is a ``'!'`` character) - - a range of any of the above, separated by a dash (``'a-z'``, - etc.) - - any combination of the above (``'aeiouy'``, - ``'a-zA-Z0-9_$'``, etc.) - """ - _expanded = lambda p: p if not isinstance(p, ParseResults) else ''.join(unichr(c) for c in range(ord(p[0]), ord(p[1]) + 1)) - try: - return "".join(_expanded(part) for part in _reBracketExpr.parseString(s).body) - except Exception: - return "" - -def matchOnlyAtCol(n): - """Helper method for defining parse actions that require matching at - a specific column in the input text. - """ - def verifyCol(strg, locn, toks): - if col(locn, strg) != n: - raise ParseException(strg, locn, "matched token not at column %d" % n) - return verifyCol - -def replaceWith(replStr): - """Helper method for common parse actions that simply return - a literal value. Especially useful when used with - :class:`transformString<ParserElement.transformString>` (). - - Example:: - - num = Word(nums).setParseAction(lambda toks: int(toks[0])) - na = oneOf("N/A NA").setParseAction(replaceWith(math.nan)) - term = na | num - - OneOrMore(term).parseString("324 234 N/A 234") # -> [324, 234, nan, 234] - """ - return lambda s, l, t: [replStr] - -def removeQuotes(s, l, t): - """Helper parse action for removing quotation marks from parsed - quoted strings. - - Example:: - - # by default, quotation marks are included in parsed results - quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["'Now is the Winter of our Discontent'"] - - # use removeQuotes to strip quotation marks from parsed results - quotedString.setParseAction(removeQuotes) - quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["Now is the Winter of our Discontent"] - """ - return t[0][1:-1] - -def tokenMap(func, *args): - """Helper to define a parse action by mapping a function to all - elements of a ParseResults list. If any additional args are passed, - they are forwarded to the given function as additional arguments - after the token, as in - ``hex_integer = Word(hexnums).setParseAction(tokenMap(int, 16))``, - which will convert the parsed data to an integer using base 16. - - Example (compare the last to example in :class:`ParserElement.transformString`:: - - hex_ints = OneOrMore(Word(hexnums)).setParseAction(tokenMap(int, 16)) - hex_ints.runTests(''' - 00 11 22 aa FF 0a 0d 1a - ''') - - upperword = Word(alphas).setParseAction(tokenMap(str.upper)) - OneOrMore(upperword).runTests(''' - my kingdom for a horse - ''') - - wd = Word(alphas).setParseAction(tokenMap(str.title)) - OneOrMore(wd).setParseAction(' '.join).runTests(''' - now is the winter of our discontent made glorious summer by this sun of york - ''') - - prints:: - - 00 11 22 aa FF 0a 0d 1a - [0, 17, 34, 170, 255, 10, 13, 26] - - my kingdom for a horse - ['MY', 'KINGDOM', 'FOR', 'A', 'HORSE'] - - now is the winter of our discontent made glorious summer by this sun of york - ['Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York'] - """ - def pa(s, l, t): - return [func(tokn, *args) for tokn in t] - - try: - func_name = getattr(func, '__name__', - getattr(func, '__class__').__name__) - except Exception: - func_name = str(func) - pa.__name__ = func_name - - return pa - -upcaseTokens = tokenMap(lambda t: _ustr(t).upper()) -"""(Deprecated) Helper parse action to convert tokens to upper case. -Deprecated in favor of :class:`pyparsing_common.upcaseTokens`""" - -downcaseTokens = tokenMap(lambda t: _ustr(t).lower()) -"""(Deprecated) Helper parse action to convert tokens to lower case. -Deprecated in favor of :class:`pyparsing_common.downcaseTokens`""" - -def _makeTags(tagStr, xml, - suppress_LT=Suppress("<"), - suppress_GT=Suppress(">")): - """Internal helper to construct opening and closing tag expressions, given a tag name""" - if isinstance(tagStr, basestring): - resname = tagStr - tagStr = Keyword(tagStr, caseless=not xml) - else: - resname = tagStr.name - - tagAttrName = Word(alphas, alphanums + "_-:") - if xml: - tagAttrValue = dblQuotedString.copy().setParseAction(removeQuotes) - openTag = (suppress_LT - + tagStr("tag") - + Dict(ZeroOrMore(Group(tagAttrName + Suppress("=") + tagAttrValue))) - + Optional("/", default=[False])("empty").setParseAction(lambda s, l, t: t[0] == '/') - + suppress_GT) - else: - tagAttrValue = quotedString.copy().setParseAction(removeQuotes) | Word(printables, excludeChars=">") - openTag = (suppress_LT - + tagStr("tag") - + Dict(ZeroOrMore(Group(tagAttrName.setParseAction(downcaseTokens) - + Optional(Suppress("=") + tagAttrValue)))) - + Optional("/", default=[False])("empty").setParseAction(lambda s, l, t: t[0] == '/') - + suppress_GT) - closeTag = Combine(_L("</") + tagStr + ">", adjacent=False) - - openTag.setName("<%s>" % resname) - # add start<tagname> results name in parse action now that ungrouped names are not reported at two levels - openTag.addParseAction(lambda t: t.__setitem__("start" + "".join(resname.replace(":", " ").title().split()), t.copy())) - closeTag = closeTag("end" + "".join(resname.replace(":", " ").title().split())).setName("</%s>" % resname) - openTag.tag = resname - closeTag.tag = resname - openTag.tag_body = SkipTo(closeTag()) - return openTag, closeTag - -def makeHTMLTags(tagStr): - """Helper to construct opening and closing tag expressions for HTML, - given a tag name. Matches tags in either upper or lower case, - attributes with namespaces and with quoted or unquoted values. - - Example:: - - text = '<td>More info at the <a href="https://github.com/pyparsing/pyparsing/wiki">pyparsing</a> wiki page</td>' - # makeHTMLTags returns pyparsing expressions for the opening and - # closing tags as a 2-tuple - a, a_end = makeHTMLTags("A") - link_expr = a + SkipTo(a_end)("link_text") + a_end - - for link in link_expr.searchString(text): - # attributes in the <A> tag (like "href" shown here) are - # also accessible as named results - print(link.link_text, '->', link.href) - - prints:: - - pyparsing -> https://github.com/pyparsing/pyparsing/wiki - """ - return _makeTags(tagStr, False) - -def makeXMLTags(tagStr): - """Helper to construct opening and closing tag expressions for XML, - given a tag name. Matches tags only in the given upper/lower case. - - Example: similar to :class:`makeHTMLTags` - """ - return _makeTags(tagStr, True) - -def withAttribute(*args, **attrDict): - """Helper to create a validating parse action to be used with start - tags created with :class:`makeXMLTags` or - :class:`makeHTMLTags`. Use ``withAttribute`` to qualify - a starting tag with a required attribute value, to avoid false - matches on common tags such as ``<TD>`` or ``<DIV>``. - - Call ``withAttribute`` with a series of attribute names and - values. Specify the list of filter attributes names and values as: - - - keyword arguments, as in ``(align="right")``, or - - as an explicit dict with ``**`` operator, when an attribute - name is also a Python reserved word, as in ``**{"class":"Customer", "align":"right"}`` - - a list of name-value tuples, as in ``(("ns1:class", "Customer"), ("ns2:align", "right"))`` - - For attribute names with a namespace prefix, you must use the second - form. Attribute names are matched insensitive to upper/lower case. - - If just testing for ``class`` (with or without a namespace), use - :class:`withClass`. - - To verify that the attribute exists, but without specifying a value, - pass ``withAttribute.ANY_VALUE`` as the value. - - Example:: - - html = ''' - <div> - Some text - <div type="grid">1 4 0 1 0</div> - <div type="graph">1,3 2,3 1,1</div> - <div>this has no type</div> - </div> - - ''' - div,div_end = makeHTMLTags("div") - - # only match div tag having a type attribute with value "grid" - div_grid = div().setParseAction(withAttribute(type="grid")) - grid_expr = div_grid + SkipTo(div | div_end)("body") - for grid_header in grid_expr.searchString(html): - print(grid_header.body) - - # construct a match with any div tag having a type attribute, regardless of the value - div_any_type = div().setParseAction(withAttribute(type=withAttribute.ANY_VALUE)) - div_expr = div_any_type + SkipTo(div | div_end)("body") - for div_header in div_expr.searchString(html): - print(div_header.body) - - prints:: - - 1 4 0 1 0 - - 1 4 0 1 0 - 1,3 2,3 1,1 - """ - if args: - attrs = args[:] - else: - attrs = attrDict.items() - attrs = [(k, v) for k, v in attrs] - def pa(s, l, tokens): - for attrName, attrValue in attrs: - if attrName not in tokens: - raise ParseException(s, l, "no matching attribute " + attrName) - if attrValue != withAttribute.ANY_VALUE and tokens[attrName] != attrValue: - raise ParseException(s, l, "attribute '%s' has value '%s', must be '%s'" % - (attrName, tokens[attrName], attrValue)) - return pa -withAttribute.ANY_VALUE = object() - -def withClass(classname, namespace=''): - """Simplified version of :class:`withAttribute` when - matching on a div class - made difficult because ``class`` is - a reserved word in Python. - - Example:: - - html = ''' - <div> - Some text - <div class="grid">1 4 0 1 0</div> - <div class="graph">1,3 2,3 1,1</div> - <div>this <div> has no class</div> - </div> - - ''' - div,div_end = makeHTMLTags("div") - div_grid = div().setParseAction(withClass("grid")) - - grid_expr = div_grid + SkipTo(div | div_end)("body") - for grid_header in grid_expr.searchString(html): - print(grid_header.body) - - div_any_type = div().setParseAction(withClass(withAttribute.ANY_VALUE)) - div_expr = div_any_type + SkipTo(div | div_end)("body") - for div_header in div_expr.searchString(html): - print(div_header.body) - - prints:: - - 1 4 0 1 0 - - 1 4 0 1 0 - 1,3 2,3 1,1 - """ - classattr = "%s:class" % namespace if namespace else "class" - return withAttribute(**{classattr: classname}) - -opAssoc = SimpleNamespace() -opAssoc.LEFT = object() -opAssoc.RIGHT = object() - -def infixNotation(baseExpr, opList, lpar=Suppress('('), rpar=Suppress(')')): - """Helper method for constructing grammars of expressions made up of - operators working in a precedence hierarchy. Operators may be unary - or binary, left- or right-associative. Parse actions can also be - attached to operator expressions. The generated parser will also - recognize the use of parentheses to override operator precedences - (see example below). - - Note: if you define a deep operator list, you may see performance - issues when using infixNotation. See - :class:`ParserElement.enablePackrat` for a mechanism to potentially - improve your parser performance. - - Parameters: - - baseExpr - expression representing the most basic element for the - nested - - opList - list of tuples, one for each operator precedence level - in the expression grammar; each tuple is of the form ``(opExpr, - numTerms, rightLeftAssoc, parseAction)``, where: - - - opExpr is the pyparsing expression for the operator; may also - be a string, which will be converted to a Literal; if numTerms - is 3, opExpr is a tuple of two expressions, for the two - operators separating the 3 terms - - numTerms is the number of terms for this operator (must be 1, - 2, or 3) - - rightLeftAssoc is the indicator whether the operator is right - or left associative, using the pyparsing-defined constants - ``opAssoc.RIGHT`` and ``opAssoc.LEFT``. - - parseAction is the parse action to be associated with - expressions matching this operator expression (the parse action - tuple member may be omitted); if the parse action is passed - a tuple or list of functions, this is equivalent to calling - ``setParseAction(*fn)`` - (:class:`ParserElement.setParseAction`) - - lpar - expression for matching left-parentheses - (default= ``Suppress('(')``) - - rpar - expression for matching right-parentheses - (default= ``Suppress(')')``) - - Example:: - - # simple example of four-function arithmetic with ints and - # variable names - integer = pyparsing_common.signed_integer - varname = pyparsing_common.identifier - - arith_expr = infixNotation(integer | varname, - [ - ('-', 1, opAssoc.RIGHT), - (oneOf('* /'), 2, opAssoc.LEFT), - (oneOf('+ -'), 2, opAssoc.LEFT), - ]) - - arith_expr.runTests(''' - 5+3*6 - (5+3)*6 - -2--11 - ''', fullDump=False) - - prints:: - - 5+3*6 - [[5, '+', [3, '*', 6]]] - - (5+3)*6 - [[[5, '+', 3], '*', 6]] - - -2--11 - [[['-', 2], '-', ['-', 11]]] - """ - # captive version of FollowedBy that does not do parse actions or capture results names - class _FB(FollowedBy): - def parseImpl(self, instring, loc, doActions=True): - self.expr.tryParse(instring, loc) - return loc, [] - - ret = Forward() - lastExpr = baseExpr | (lpar + ret + rpar) - for i, operDef in enumerate(opList): - opExpr, arity, rightLeftAssoc, pa = (operDef + (None, ))[:4] - termName = "%s term" % opExpr if arity < 3 else "%s%s term" % opExpr - if arity == 3: - if opExpr is None or len(opExpr) != 2: - raise ValueError( - "if numterms=3, opExpr must be a tuple or list of two expressions") - opExpr1, opExpr2 = opExpr - thisExpr = Forward().setName(termName) - if rightLeftAssoc == opAssoc.LEFT: - if arity == 1: - matchExpr = _FB(lastExpr + opExpr) + Group(lastExpr + OneOrMore(opExpr)) - elif arity == 2: - if opExpr is not None: - matchExpr = _FB(lastExpr + opExpr + lastExpr) + Group(lastExpr + OneOrMore(opExpr + lastExpr)) - else: - matchExpr = _FB(lastExpr + lastExpr) + Group(lastExpr + OneOrMore(lastExpr)) - elif arity == 3: - matchExpr = (_FB(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr) - + Group(lastExpr + OneOrMore(opExpr1 + lastExpr + opExpr2 + lastExpr))) - else: - raise ValueError("operator must be unary (1), binary (2), or ternary (3)") - elif rightLeftAssoc == opAssoc.RIGHT: - if arity == 1: - # try to avoid LR with this extra test - if not isinstance(opExpr, Optional): - opExpr = Optional(opExpr) - matchExpr = _FB(opExpr.expr + thisExpr) + Group(opExpr + thisExpr) - elif arity == 2: - if opExpr is not None: - matchExpr = _FB(lastExpr + opExpr + thisExpr) + Group(lastExpr + OneOrMore(opExpr + thisExpr)) - else: - matchExpr = _FB(lastExpr + thisExpr) + Group(lastExpr + OneOrMore(thisExpr)) - elif arity == 3: - matchExpr = (_FB(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr) - + Group(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr)) - else: - raise ValueError("operator must be unary (1), binary (2), or ternary (3)") - else: - raise ValueError("operator must indicate right or left associativity") - if pa: - if isinstance(pa, (tuple, list)): - matchExpr.setParseAction(*pa) - else: - matchExpr.setParseAction(pa) - thisExpr <<= (matchExpr.setName(termName) | lastExpr) - lastExpr = thisExpr - ret <<= lastExpr - return ret - -operatorPrecedence = infixNotation -"""(Deprecated) Former name of :class:`infixNotation`, will be -dropped in a future release.""" - -dblQuotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*') + '"').setName("string enclosed in double quotes") -sglQuotedString = Combine(Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*") + "'").setName("string enclosed in single quotes") -quotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*') + '"' - | Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*") + "'").setName("quotedString using single or double quotes") -unicodeString = Combine(_L('u') + quotedString.copy()).setName("unicode string literal") - -def nestedExpr(opener="(", closer=")", content=None, ignoreExpr=quotedString.copy()): - """Helper method for defining nested lists enclosed in opening and - closing delimiters ("(" and ")" are the default). - - Parameters: - - opener - opening character for a nested list - (default= ``"("``); can also be a pyparsing expression - - closer - closing character for a nested list - (default= ``")"``); can also be a pyparsing expression - - content - expression for items within the nested lists - (default= ``None``) - - ignoreExpr - expression for ignoring opening and closing - delimiters (default= :class:`quotedString`) - - If an expression is not provided for the content argument, the - nested expression will capture all whitespace-delimited content - between delimiters as a list of separate values. - - Use the ``ignoreExpr`` argument to define expressions that may - contain opening or closing characters that should not be treated as - opening or closing characters for nesting, such as quotedString or - a comment expression. Specify multiple expressions using an - :class:`Or` or :class:`MatchFirst`. The default is - :class:`quotedString`, but if no expressions are to be ignored, then - pass ``None`` for this argument. - - Example:: - - data_type = oneOf("void int short long char float double") - decl_data_type = Combine(data_type + Optional(Word('*'))) - ident = Word(alphas+'_', alphanums+'_') - number = pyparsing_common.number - arg = Group(decl_data_type + ident) - LPAR, RPAR = map(Suppress, "()") - - code_body = nestedExpr('{', '}', ignoreExpr=(quotedString | cStyleComment)) - - c_function = (decl_data_type("type") - + ident("name") - + LPAR + Optional(delimitedList(arg), [])("args") + RPAR - + code_body("body")) - c_function.ignore(cStyleComment) - - source_code = ''' - int is_odd(int x) { - return (x%2); - } - - int dec_to_hex(char hchar) { - if (hchar >= '0' && hchar <= '9') { - return (ord(hchar)-ord('0')); - } else { - return (10+ord(hchar)-ord('A')); - } - } - ''' - for func in c_function.searchString(source_code): - print("%(name)s (%(type)s) args: %(args)s" % func) - - - prints:: - - is_odd (int) args: [['int', 'x']] - dec_to_hex (int) args: [['char', 'hchar']] - """ - if opener == closer: - raise ValueError("opening and closing strings cannot be the same") - if content is None: - if isinstance(opener, basestring) and isinstance(closer, basestring): - if len(opener) == 1 and len(closer) == 1: - if ignoreExpr is not None: - content = (Combine(OneOrMore(~ignoreExpr - + CharsNotIn(opener - + closer - + ParserElement.DEFAULT_WHITE_CHARS, exact=1) - ) - ).setParseAction(lambda t: t[0].strip())) - else: - content = (empty.copy() + CharsNotIn(opener - + closer - + ParserElement.DEFAULT_WHITE_CHARS - ).setParseAction(lambda t: t[0].strip())) - else: - if ignoreExpr is not None: - content = (Combine(OneOrMore(~ignoreExpr - + ~Literal(opener) - + ~Literal(closer) - + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS, exact=1)) - ).setParseAction(lambda t: t[0].strip())) - else: - content = (Combine(OneOrMore(~Literal(opener) - + ~Literal(closer) - + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS, exact=1)) - ).setParseAction(lambda t: t[0].strip())) - else: - raise ValueError("opening and closing arguments must be strings if no content expression is given") - ret = Forward() - if ignoreExpr is not None: - ret <<= Group(Suppress(opener) + ZeroOrMore(ignoreExpr | ret | content) + Suppress(closer)) - else: - ret <<= Group(Suppress(opener) + ZeroOrMore(ret | content) + Suppress(closer)) - ret.setName('nested %s%s expression' % (opener, closer)) - return ret - -def indentedBlock(blockStatementExpr, indentStack, indent=True): - """Helper method for defining space-delimited indentation blocks, - such as those used to define block statements in Python source code. - - Parameters: - - - blockStatementExpr - expression defining syntax of statement that - is repeated within the indented block - - indentStack - list created by caller to manage indentation stack - (multiple statementWithIndentedBlock expressions within a single - grammar should share a common indentStack) - - indent - boolean indicating whether block must be indented beyond - the current level; set to False for block of left-most - statements (default= ``True``) - - A valid block must contain at least one ``blockStatement``. - - Example:: - - data = ''' - def A(z): - A1 - B = 100 - G = A2 - A2 - A3 - B - def BB(a,b,c): - BB1 - def BBA(): - bba1 - bba2 - bba3 - C - D - def spam(x,y): - def eggs(z): - pass - ''' - - - indentStack = [1] - stmt = Forward() - - identifier = Word(alphas, alphanums) - funcDecl = ("def" + identifier + Group("(" + Optional(delimitedList(identifier)) + ")") + ":") - func_body = indentedBlock(stmt, indentStack) - funcDef = Group(funcDecl + func_body) - - rvalue = Forward() - funcCall = Group(identifier + "(" + Optional(delimitedList(rvalue)) + ")") - rvalue << (funcCall | identifier | Word(nums)) - assignment = Group(identifier + "=" + rvalue) - stmt << (funcDef | assignment | identifier) - - module_body = OneOrMore(stmt) - - parseTree = module_body.parseString(data) - parseTree.pprint() - - prints:: - - [['def', - 'A', - ['(', 'z', ')'], - ':', - [['A1'], [['B', '=', '100']], [['G', '=', 'A2']], ['A2'], ['A3']]], - 'B', - ['def', - 'BB', - ['(', 'a', 'b', 'c', ')'], - ':', - [['BB1'], [['def', 'BBA', ['(', ')'], ':', [['bba1'], ['bba2'], ['bba3']]]]]], - 'C', - 'D', - ['def', - 'spam', - ['(', 'x', 'y', ')'], - ':', - [[['def', 'eggs', ['(', 'z', ')'], ':', [['pass']]]]]]] - """ - backup_stack = indentStack[:] - - def reset_stack(): - indentStack[:] = backup_stack - - def checkPeerIndent(s, l, t): - if l >= len(s): return - curCol = col(l, s) - if curCol != indentStack[-1]: - if curCol > indentStack[-1]: - raise ParseException(s, l, "illegal nesting") - raise ParseException(s, l, "not a peer entry") - - def checkSubIndent(s, l, t): - curCol = col(l, s) - if curCol > indentStack[-1]: - indentStack.append(curCol) - else: - raise ParseException(s, l, "not a subentry") - - def checkUnindent(s, l, t): - if l >= len(s): return - curCol = col(l, s) - if not(indentStack and curCol in indentStack): - raise ParseException(s, l, "not an unindent") - if curCol < indentStack[-1]: - indentStack.pop() - - NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress(), stopOn=StringEnd()) - INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT') - PEER = Empty().setParseAction(checkPeerIndent).setName('') - UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT') - if indent: - smExpr = Group(Optional(NL) - + INDENT - + OneOrMore(PEER + Group(blockStatementExpr) + Optional(NL), stopOn=StringEnd()) - + UNDENT) - else: - smExpr = Group(Optional(NL) - + OneOrMore(PEER + Group(blockStatementExpr) + Optional(NL), stopOn=StringEnd()) - + UNDENT) - smExpr.setFailAction(lambda a, b, c, d: reset_stack()) - blockStatementExpr.ignore(_bslash + LineEnd()) - return smExpr.setName('indented block') - -alphas8bit = srange(r"[\0xc0-\0xd6\0xd8-\0xf6\0xf8-\0xff]") -punc8bit = srange(r"[\0xa1-\0xbf\0xd7\0xf7]") - -anyOpenTag, anyCloseTag = makeHTMLTags(Word(alphas, alphanums + "_:").setName('any tag')) -_htmlEntityMap = dict(zip("gt lt amp nbsp quot apos".split(), '><& "\'')) -commonHTMLEntity = Regex('&(?P<entity>' + '|'.join(_htmlEntityMap.keys()) +");").setName("common HTML entity") -def replaceHTMLEntity(t): - """Helper parser action to replace common HTML entities with their special characters""" - return _htmlEntityMap.get(t.entity) - -# it's easy to get these comment structures wrong - they're very common, so may as well make them available -cStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/').setName("C style comment") -"Comment of the form ``/* ... */``" - -htmlComment = Regex(r"<!--[\s\S]*?-->").setName("HTML comment") -"Comment of the form ``<!-- ... -->``" - -restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line") -dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment") -"Comment of the form ``// ... (to end of line)``" - -cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/' | dblSlashComment).setName("C++ style comment") -"Comment of either form :class:`cStyleComment` or :class:`dblSlashComment`" - -javaStyleComment = cppStyleComment -"Same as :class:`cppStyleComment`" - -pythonStyleComment = Regex(r"#.*").setName("Python style comment") -"Comment of the form ``# ... (to end of line)``" - -_commasepitem = Combine(OneOrMore(Word(printables, excludeChars=',') - + Optional(Word(" \t") - + ~Literal(",") + ~LineEnd()))).streamline().setName("commaItem") -commaSeparatedList = delimitedList(Optional(quotedString.copy() | _commasepitem, default="")).setName("commaSeparatedList") -"""(Deprecated) Predefined expression of 1 or more printable words or -quoted strings, separated by commas. - -This expression is deprecated in favor of :class:`pyparsing_common.comma_separated_list`. -""" - -# some other useful expressions - using lower-case class name since we are really using this as a namespace -class pyparsing_common: - """Here are some common low-level expressions that may be useful in - jump-starting parser development: - - - numeric forms (:class:`integers<integer>`, :class:`reals<real>`, - :class:`scientific notation<sci_real>`) - - common :class:`programming identifiers<identifier>` - - network addresses (:class:`MAC<mac_address>`, - :class:`IPv4<ipv4_address>`, :class:`IPv6<ipv6_address>`) - - ISO8601 :class:`dates<iso8601_date>` and - :class:`datetime<iso8601_datetime>` - - :class:`UUID<uuid>` - - :class:`comma-separated list<comma_separated_list>` - - Parse actions: - - - :class:`convertToInteger` - - :class:`convertToFloat` - - :class:`convertToDate` - - :class:`convertToDatetime` - - :class:`stripHTMLTags` - - :class:`upcaseTokens` - - :class:`downcaseTokens` - - Example:: - - pyparsing_common.number.runTests(''' - # any int or real number, returned as the appropriate type - 100 - -100 - +100 - 3.14159 - 6.02e23 - 1e-12 - ''') - - pyparsing_common.fnumber.runTests(''' - # any int or real number, returned as float - 100 - -100 - +100 - 3.14159 - 6.02e23 - 1e-12 - ''') - - pyparsing_common.hex_integer.runTests(''' - # hex numbers - 100 - FF - ''') - - pyparsing_common.fraction.runTests(''' - # fractions - 1/2 - -3/4 - ''') - - pyparsing_common.mixed_integer.runTests(''' - # mixed fractions - 1 - 1/2 - -3/4 - 1-3/4 - ''') - - import uuid - pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID)) - pyparsing_common.uuid.runTests(''' - # uuid - 12345678-1234-5678-1234-567812345678 - ''') - - prints:: - - # any int or real number, returned as the appropriate type - 100 - [100] - - -100 - [-100] - - +100 - [100] - - 3.14159 - [3.14159] - - 6.02e23 - [6.02e+23] - - 1e-12 - [1e-12] - - # any int or real number, returned as float - 100 - [100.0] - - -100 - [-100.0] - - +100 - [100.0] - - 3.14159 - [3.14159] - - 6.02e23 - [6.02e+23] - - 1e-12 - [1e-12] - - # hex numbers - 100 - [256] - - FF - [255] - - # fractions - 1/2 - [0.5] - - -3/4 - [-0.75] - - # mixed fractions - 1 - [1] - - 1/2 - [0.5] - - -3/4 - [-0.75] - - 1-3/4 - [1.75] - - # uuid - 12345678-1234-5678-1234-567812345678 - [UUID('12345678-1234-5678-1234-567812345678')] - """ - - convertToInteger = tokenMap(int) - """ - Parse action for converting parsed integers to Python int - """ - - convertToFloat = tokenMap(float) - """ - Parse action for converting parsed numbers to Python float - """ - - integer = Word(nums).setName("integer").setParseAction(convertToInteger) - """expression that parses an unsigned integer, returns an int""" - - hex_integer = Word(hexnums).setName("hex integer").setParseAction(tokenMap(int, 16)) - """expression that parses a hexadecimal integer, returns an int""" - - signed_integer = Regex(r'[+-]?\d+').setName("signed integer").setParseAction(convertToInteger) - """expression that parses an integer with optional leading sign, returns an int""" - - fraction = (signed_integer().setParseAction(convertToFloat) + '/' + signed_integer().setParseAction(convertToFloat)).setName("fraction") - """fractional expression of an integer divided by an integer, returns a float""" - fraction.addParseAction(lambda t: t[0]/t[-1]) - - mixed_integer = (fraction | signed_integer + Optional(Optional('-').suppress() + fraction)).setName("fraction or mixed integer-fraction") - """mixed integer of the form 'integer - fraction', with optional leading integer, returns float""" - mixed_integer.addParseAction(sum) - - real = Regex(r'[+-]?(?:\d+\.\d*|\.\d+)').setName("real number").setParseAction(convertToFloat) - """expression that parses a floating point number and returns a float""" - - sci_real = Regex(r'[+-]?(?:\d+(?:[eE][+-]?\d+)|(?:\d+\.\d*|\.\d+)(?:[eE][+-]?\d+)?)').setName("real number with scientific notation").setParseAction(convertToFloat) - """expression that parses a floating point number with optional - scientific notation and returns a float""" - - # streamlining this expression makes the docs nicer-looking - number = (sci_real | real | signed_integer).streamline() - """any numeric expression, returns the corresponding Python type""" - - fnumber = Regex(r'[+-]?\d+\.?\d*([eE][+-]?\d+)?').setName("fnumber").setParseAction(convertToFloat) - """any int or real number, returned as float""" - - identifier = Word(alphas + '_', alphanums + '_').setName("identifier") - """typical code identifier (leading alpha or '_', followed by 0 or more alphas, nums, or '_')""" - - ipv4_address = Regex(r'(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})(\.(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})){3}').setName("IPv4 address") - "IPv4 address (``0.0.0.0 - 255.255.255.255``)" - - _ipv6_part = Regex(r'[0-9a-fA-F]{1,4}').setName("hex_integer") - _full_ipv6_address = (_ipv6_part + (':' + _ipv6_part) * 7).setName("full IPv6 address") - _short_ipv6_address = (Optional(_ipv6_part + (':' + _ipv6_part) * (0, 6)) - + "::" - + Optional(_ipv6_part + (':' + _ipv6_part) * (0, 6)) - ).setName("short IPv6 address") - _short_ipv6_address.addCondition(lambda t: sum(1 for tt in t if pyparsing_common._ipv6_part.matches(tt)) < 8) - _mixed_ipv6_address = ("::ffff:" + ipv4_address).setName("mixed IPv6 address") - ipv6_address = Combine((_full_ipv6_address | _mixed_ipv6_address | _short_ipv6_address).setName("IPv6 address")).setName("IPv6 address") - "IPv6 address (long, short, or mixed form)" - - mac_address = Regex(r'[0-9a-fA-F]{2}([:.-])[0-9a-fA-F]{2}(?:\1[0-9a-fA-F]{2}){4}').setName("MAC address") - "MAC address xx:xx:xx:xx:xx (may also have '-' or '.' delimiters)" - - @staticmethod - def convertToDate(fmt="%Y-%m-%d"): - """ - Helper to create a parse action for converting parsed date string to Python datetime.date - - Params - - - fmt - format to be passed to datetime.strptime (default= ``"%Y-%m-%d"``) - - Example:: - - date_expr = pyparsing_common.iso8601_date.copy() - date_expr.setParseAction(pyparsing_common.convertToDate()) - print(date_expr.parseString("1999-12-31")) - - prints:: - - [datetime.date(1999, 12, 31)] - """ - def cvt_fn(s, l, t): - try: - return datetime.strptime(t[0], fmt).date() - except ValueError as ve: - raise ParseException(s, l, str(ve)) - return cvt_fn - - @staticmethod - def convertToDatetime(fmt="%Y-%m-%dT%H:%M:%S.%f"): - """Helper to create a parse action for converting parsed - datetime string to Python datetime.datetime - - Params - - - fmt - format to be passed to datetime.strptime (default= ``"%Y-%m-%dT%H:%M:%S.%f"``) - - Example:: - - dt_expr = pyparsing_common.iso8601_datetime.copy() - dt_expr.setParseAction(pyparsing_common.convertToDatetime()) - print(dt_expr.parseString("1999-12-31T23:59:59.999")) - - prints:: - - [datetime.datetime(1999, 12, 31, 23, 59, 59, 999000)] - """ - def cvt_fn(s, l, t): - try: - return datetime.strptime(t[0], fmt) - except ValueError as ve: - raise ParseException(s, l, str(ve)) - return cvt_fn - - iso8601_date = Regex(r'(?P<year>\d{4})(?:-(?P<month>\d\d)(?:-(?P<day>\d\d))?)?').setName("ISO8601 date") - "ISO8601 date (``yyyy-mm-dd``)" - - iso8601_datetime = Regex(r'(?P<year>\d{4})-(?P<month>\d\d)-(?P<day>\d\d)[T ](?P<hour>\d\d):(?P<minute>\d\d)(:(?P<second>\d\d(\.\d*)?)?)?(?P<tz>Z|[+-]\d\d:?\d\d)?').setName("ISO8601 datetime") - "ISO8601 datetime (``yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)``) - trailing seconds, milliseconds, and timezone optional; accepts separating ``'T'`` or ``' '``" - - uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID") - "UUID (``xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx``)" - - _html_stripper = anyOpenTag.suppress() | anyCloseTag.suppress() - @staticmethod - def stripHTMLTags(s, l, tokens): - """Parse action to remove HTML tags from web page HTML source - - Example:: - - # strip HTML links from normal text - text = '<td>More info at the <a href="https://github.com/pyparsing/pyparsing/wiki">pyparsing</a> wiki page</td>' - td, td_end = makeHTMLTags("TD") - table_text = td + SkipTo(td_end).setParseAction(pyparsing_common.stripHTMLTags)("body") + td_end - print(table_text.parseString(text).body) - - Prints:: - - More info at the pyparsing wiki page - """ - return pyparsing_common._html_stripper.transformString(tokens[0]) - - _commasepitem = Combine(OneOrMore(~Literal(",") - + ~LineEnd() - + Word(printables, excludeChars=',') - + Optional(White(" \t")))).streamline().setName("commaItem") - comma_separated_list = delimitedList(Optional(quotedString.copy() - | _commasepitem, default='') - ).setName("comma separated list") - """Predefined expression of 1 or more printable words or quoted strings, separated by commas.""" - - upcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).upper())) - """Parse action to convert tokens to upper case.""" - - downcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).lower())) - """Parse action to convert tokens to lower case.""" - - -class _lazyclassproperty(object): - def __init__(self, fn): - self.fn = fn - self.__doc__ = fn.__doc__ - self.__name__ = fn.__name__ - - def __get__(self, obj, cls): - if cls is None: - cls = type(obj) - if not hasattr(cls, '_intern') or any(cls._intern is getattr(superclass, '_intern', []) - for superclass in cls.__mro__[1:]): - cls._intern = {} - attrname = self.fn.__name__ - if attrname not in cls._intern: - cls._intern[attrname] = self.fn(cls) - return cls._intern[attrname] - - -class unicode_set(object): - """ - A set of Unicode characters, for language-specific strings for - ``alphas``, ``nums``, ``alphanums``, and ``printables``. - A unicode_set is defined by a list of ranges in the Unicode character - set, in a class attribute ``_ranges``, such as:: - - _ranges = [(0x0020, 0x007e), (0x00a0, 0x00ff),] - - A unicode set can also be defined using multiple inheritance of other unicode sets:: - - class CJK(Chinese, Japanese, Korean): - pass - """ - _ranges = [] - - @classmethod - def _get_chars_for_ranges(cls): - ret = [] - for cc in cls.__mro__: - if cc is unicode_set: - break - for rr in cc._ranges: - ret.extend(range(rr[0], rr[-1] + 1)) - return [unichr(c) for c in sorted(set(ret))] - - @_lazyclassproperty - def printables(cls): - "all non-whitespace characters in this range" - return u''.join(filterfalse(unicode.isspace, cls._get_chars_for_ranges())) - - @_lazyclassproperty - def alphas(cls): - "all alphabetic characters in this range" - return u''.join(filter(unicode.isalpha, cls._get_chars_for_ranges())) - - @_lazyclassproperty - def nums(cls): - "all numeric digit characters in this range" - return u''.join(filter(unicode.isdigit, cls._get_chars_for_ranges())) - - @_lazyclassproperty - def alphanums(cls): - "all alphanumeric characters in this range" - return cls.alphas + cls.nums - - -class pyparsing_unicode(unicode_set): - """ - A namespace class for defining common language unicode_sets. - """ - _ranges = [(32, sys.maxunicode)] - - class Latin1(unicode_set): - "Unicode set for Latin-1 Unicode Character Range" - _ranges = [(0x0020, 0x007e), (0x00a0, 0x00ff),] - - class LatinA(unicode_set): - "Unicode set for Latin-A Unicode Character Range" - _ranges = [(0x0100, 0x017f),] - - class LatinB(unicode_set): - "Unicode set for Latin-B Unicode Character Range" - _ranges = [(0x0180, 0x024f),] - - class Greek(unicode_set): - "Unicode set for Greek Unicode Character Ranges" - _ranges = [ - (0x0370, 0x03ff), (0x1f00, 0x1f15), (0x1f18, 0x1f1d), (0x1f20, 0x1f45), (0x1f48, 0x1f4d), - (0x1f50, 0x1f57), (0x1f59,), (0x1f5b,), (0x1f5d,), (0x1f5f, 0x1f7d), (0x1f80, 0x1fb4), (0x1fb6, 0x1fc4), - (0x1fc6, 0x1fd3), (0x1fd6, 0x1fdb), (0x1fdd, 0x1fef), (0x1ff2, 0x1ff4), (0x1ff6, 0x1ffe), - ] - - class Cyrillic(unicode_set): - "Unicode set for Cyrillic Unicode Character Range" - _ranges = [(0x0400, 0x04ff)] - - class Chinese(unicode_set): - "Unicode set for Chinese Unicode Character Range" - _ranges = [(0x4e00, 0x9fff), (0x3000, 0x303f),] - - class Japanese(unicode_set): - "Unicode set for Japanese Unicode Character Range, combining Kanji, Hiragana, and Katakana ranges" - _ranges = [] - - class Kanji(unicode_set): - "Unicode set for Kanji Unicode Character Range" - _ranges = [(0x4E00, 0x9Fbf), (0x3000, 0x303f),] - - class Hiragana(unicode_set): - "Unicode set for Hiragana Unicode Character Range" - _ranges = [(0x3040, 0x309f),] - - class Katakana(unicode_set): - "Unicode set for Katakana Unicode Character Range" - _ranges = [(0x30a0, 0x30ff),] - - class Korean(unicode_set): - "Unicode set for Korean Unicode Character Range" - _ranges = [(0xac00, 0xd7af), (0x1100, 0x11ff), (0x3130, 0x318f), (0xa960, 0xa97f), (0xd7b0, 0xd7ff), (0x3000, 0x303f),] - - class CJK(Chinese, Japanese, Korean): - "Unicode set for combined Chinese, Japanese, and Korean (CJK) Unicode Character Range" - pass - - class Thai(unicode_set): - "Unicode set for Thai Unicode Character Range" - _ranges = [(0x0e01, 0x0e3a), (0x0e3f, 0x0e5b),] - - class Arabic(unicode_set): - "Unicode set for Arabic Unicode Character Range" - _ranges = [(0x0600, 0x061b), (0x061e, 0x06ff), (0x0700, 0x077f),] - - class Hebrew(unicode_set): - "Unicode set for Hebrew Unicode Character Range" - _ranges = [(0x0590, 0x05ff),] - - class Devanagari(unicode_set): - "Unicode set for Devanagari Unicode Character Range" - _ranges = [(0x0900, 0x097f), (0xa8e0, 0xa8ff)] - -pyparsing_unicode.Japanese._ranges = (pyparsing_unicode.Japanese.Kanji._ranges - + pyparsing_unicode.Japanese.Hiragana._ranges - + pyparsing_unicode.Japanese.Katakana._ranges) - -# define ranges in language character sets -if PY_3: - setattr(pyparsing_unicode, u"العربية", pyparsing_unicode.Arabic) - setattr(pyparsing_unicode, u"中文", pyparsing_unicode.Chinese) - setattr(pyparsing_unicode, u"кириллица", pyparsing_unicode.Cyrillic) - setattr(pyparsing_unicode, u"Ελληνικά", pyparsing_unicode.Greek) - setattr(pyparsing_unicode, u"עִברִית", pyparsing_unicode.Hebrew) - setattr(pyparsing_unicode, u"日本語", pyparsing_unicode.Japanese) - setattr(pyparsing_unicode.Japanese, u"漢字", pyparsing_unicode.Japanese.Kanji) - setattr(pyparsing_unicode.Japanese, u"カタカナ", pyparsing_unicode.Japanese.Katakana) - setattr(pyparsing_unicode.Japanese, u"ひらがな", pyparsing_unicode.Japanese.Hiragana) - setattr(pyparsing_unicode, u"한국어", pyparsing_unicode.Korean) - setattr(pyparsing_unicode, u"ไทย", pyparsing_unicode.Thai) - setattr(pyparsing_unicode, u"देवनागरी", pyparsing_unicode.Devanagari) - - -class pyparsing_test: - """ - namespace class for classes useful in writing unit tests - """ - - class reset_pyparsing_context: - """ - Context manager to be used when writing unit tests that modify pyparsing config values: - - packrat parsing - - default whitespace characters. - - default keyword characters - - literal string auto-conversion class - - __diag__ settings - - Example: - with reset_pyparsing_context(): - # test that literals used to construct a grammar are automatically suppressed - ParserElement.inlineLiteralsUsing(Suppress) - - term = Word(alphas) | Word(nums) - group = Group('(' + term[...] + ')') - - # assert that the '()' characters are not included in the parsed tokens - self.assertParseAndCheckLisst(group, "(abc 123 def)", ['abc', '123', 'def']) - - # after exiting context manager, literals are converted to Literal expressions again - """ - - def __init__(self): - self._save_context = {} - - def save(self): - self._save_context["default_whitespace"] = ParserElement.DEFAULT_WHITE_CHARS - self._save_context["default_keyword_chars"] = Keyword.DEFAULT_KEYWORD_CHARS - self._save_context[ - "literal_string_class" - ] = ParserElement._literalStringClass - self._save_context["packrat_enabled"] = ParserElement._packratEnabled - self._save_context["packrat_parse"] = ParserElement._parse - self._save_context["__diag__"] = { - name: getattr(__diag__, name) for name in __diag__._all_names - } - self._save_context["__compat__"] = { - "collect_all_And_tokens": __compat__.collect_all_And_tokens - } - return self - - def restore(self): - # reset pyparsing global state - if ( - ParserElement.DEFAULT_WHITE_CHARS - != self._save_context["default_whitespace"] - ): - ParserElement.setDefaultWhitespaceChars( - self._save_context["default_whitespace"] - ) - Keyword.DEFAULT_KEYWORD_CHARS = self._save_context["default_keyword_chars"] - ParserElement.inlineLiteralsUsing( - self._save_context["literal_string_class"] - ) - for name, value in self._save_context["__diag__"].items(): - setattr(__diag__, name, value) - ParserElement._packratEnabled = self._save_context["packrat_enabled"] - ParserElement._parse = self._save_context["packrat_parse"] - __compat__.collect_all_And_tokens = self._save_context["__compat__"] - - def __enter__(self): - return self.save() - - def __exit__(self, *args): - return self.restore() - - class TestParseResultsAsserts: - """ - A mixin class to add parse results assertion methods to normal unittest.TestCase classes. - """ - def assertParseResultsEquals( - self, result, expected_list=None, expected_dict=None, msg=None - ): - """ - Unit test assertion to compare a ParseResults object with an optional expected_list, - and compare any defined results names with an optional expected_dict. - """ - if expected_list is not None: - self.assertEqual(expected_list, result.asList(), msg=msg) - if expected_dict is not None: - self.assertEqual(expected_dict, result.asDict(), msg=msg) - - def assertParseAndCheckList( - self, expr, test_string, expected_list, msg=None, verbose=True - ): - """ - Convenience wrapper assert to test a parser element and input string, and assert that - the resulting ParseResults.asList() is equal to the expected_list. - """ - result = expr.parseString(test_string, parseAll=True) - if verbose: - print(result.dump()) - self.assertParseResultsEquals(result, expected_list=expected_list, msg=msg) - - def assertParseAndCheckDict( - self, expr, test_string, expected_dict, msg=None, verbose=True - ): - """ - Convenience wrapper assert to test a parser element and input string, and assert that - the resulting ParseResults.asDict() is equal to the expected_dict. - """ - result = expr.parseString(test_string, parseAll=True) - if verbose: - print(result.dump()) - self.assertParseResultsEquals(result, expected_dict=expected_dict, msg=msg) - - def assertRunTestResults( - self, run_tests_report, expected_parse_results=None, msg=None - ): - """ - Unit test assertion to evaluate output of ParserElement.runTests(). If a list of - list-dict tuples is given as the expected_parse_results argument, then these are zipped - with the report tuples returned by runTests and evaluated using assertParseResultsEquals. - Finally, asserts that the overall runTests() success value is True. - - :param run_tests_report: tuple(bool, [tuple(str, ParseResults or Exception)]) returned from runTests - :param expected_parse_results (optional): [tuple(str, list, dict, Exception)] - """ - run_test_success, run_test_results = run_tests_report - - if expected_parse_results is not None: - merged = [ - (rpt[0], rpt[1], expected) - for rpt, expected in zip(run_test_results, expected_parse_results) - ] - for test_string, result, expected in merged: - # expected should be a tuple containing a list and/or a dict or an exception, - # and optional failure message string - # an empty tuple will skip any result validation - fail_msg = next( - (exp for exp in expected if isinstance(exp, str)), None - ) - expected_exception = next( - ( - exp - for exp in expected - if isinstance(exp, type) and issubclass(exp, Exception) - ), - None, - ) - if expected_exception is not None: - with self.assertRaises( - expected_exception=expected_exception, msg=fail_msg or msg - ): - if isinstance(result, Exception): - raise result - else: - expected_list = next( - (exp for exp in expected if isinstance(exp, list)), None - ) - expected_dict = next( - (exp for exp in expected if isinstance(exp, dict)), None - ) - if (expected_list, expected_dict) != (None, None): - self.assertParseResultsEquals( - result, - expected_list=expected_list, - expected_dict=expected_dict, - msg=fail_msg or msg, - ) - else: - # warning here maybe? - print("no validation for {!r}".format(test_string)) - - # do this last, in case some specific test results can be reported instead - self.assertTrue( - run_test_success, msg=msg if msg is not None else "failed runTests" - ) - - @contextmanager - def assertRaisesParseException(self, exc_type=ParseException, msg=None): - with self.assertRaises(exc_type, msg=msg): - yield - - -if __name__ == "__main__": - - selectToken = CaselessLiteral("select") - fromToken = CaselessLiteral("from") - - ident = Word(alphas, alphanums + "_$") - - columnName = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens) - columnNameList = Group(delimitedList(columnName)).setName("columns") - columnSpec = ('*' | columnNameList) - - tableName = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens) - tableNameList = Group(delimitedList(tableName)).setName("tables") - - simpleSQL = selectToken("command") + columnSpec("columns") + fromToken + tableNameList("tables") - - # demo runTests method, including embedded comments in test string - simpleSQL.runTests(""" - # '*' as column list and dotted table name - select * from SYS.XYZZY - - # caseless match on "SELECT", and casts back to "select" - SELECT * from XYZZY, ABC - - # list of column names, and mixed case SELECT keyword - Select AA,BB,CC from Sys.dual - - # multiple tables - Select A, B, C from Sys.dual, Table2 - - # invalid SELECT keyword - should fail - Xelect A, B, C from Sys.dual - - # incomplete command - should fail - Select - - # invalid column name - should fail - Select ^^^ frox Sys.dual - - """) - - pyparsing_common.number.runTests(""" - 100 - -100 - +100 - 3.14159 - 6.02e23 - 1e-12 - """) - - # any int or real number, returned as float - pyparsing_common.fnumber.runTests(""" - 100 - -100 - +100 - 3.14159 - 6.02e23 - 1e-12 - """) - - pyparsing_common.hex_integer.runTests(""" - 100 - FF - """) - - import uuid - pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID)) - pyparsing_common.uuid.runTests(""" - 12345678-1234-5678-1234-567812345678 - """) diff --git a/env/Lib/site-packages/pip/_vendor/requests/__init__.py b/env/Lib/site-packages/pip/_vendor/requests/__init__.py index 18046c45..10ff67ff 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/requests/__init__.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - # __ # /__) _ _ _ _ _/ _ # / ( (- (/ (/ (- _) / _) @@ -40,53 +38,78 @@ is at <https://requests.readthedocs.io>. :license: Apache 2.0, see LICENSE for more details. """ -from pip._vendor import urllib3 -from pip._vendor import chardet import warnings + +from pip._vendor import urllib3 + from .exceptions import RequestsDependencyWarning +charset_normalizer_version = None + +try: + from pip._vendor.chardet import __version__ as chardet_version +except ImportError: + chardet_version = None + -def check_compatibility(urllib3_version, chardet_version): - urllib3_version = urllib3_version.split('.') - assert urllib3_version != ['dev'] # Verify urllib3 isn't installed from git. +def check_compatibility(urllib3_version, chardet_version, charset_normalizer_version): + urllib3_version = urllib3_version.split(".") + assert urllib3_version != ["dev"] # Verify urllib3 isn't installed from git. # Sometimes, urllib3 only reports its version as 16.1. if len(urllib3_version) == 2: - urllib3_version.append('0') + urllib3_version.append("0") # Check urllib3 for compatibility. major, minor, patch = urllib3_version # noqa: F811 major, minor, patch = int(major), int(minor), int(patch) - # urllib3 >= 1.21.1, <= 1.26 - assert major == 1 - assert minor >= 21 - assert minor <= 26 - - # Check chardet for compatibility. - major, minor, patch = chardet_version.split('.')[:3] - major, minor, patch = int(major), int(minor), int(patch) - # chardet >= 3.0.2, < 5.0.0 - assert (3, 0, 2) <= (major, minor, patch) < (5, 0, 0) + # urllib3 >= 1.21.1 + assert major >= 1 + if major == 1: + assert minor >= 21 + + # Check charset_normalizer for compatibility. + if chardet_version: + major, minor, patch = chardet_version.split(".")[:3] + major, minor, patch = int(major), int(minor), int(patch) + # chardet_version >= 3.0.2, < 6.0.0 + assert (3, 0, 2) <= (major, minor, patch) < (6, 0, 0) + elif charset_normalizer_version: + major, minor, patch = charset_normalizer_version.split(".")[:3] + major, minor, patch = int(major), int(minor), int(patch) + # charset_normalizer >= 2.0.0 < 4.0.0 + assert (2, 0, 0) <= (major, minor, patch) < (4, 0, 0) + else: + raise Exception("You need either charset_normalizer or chardet installed") def _check_cryptography(cryptography_version): # cryptography < 1.3.4 try: - cryptography_version = list(map(int, cryptography_version.split('.'))) + cryptography_version = list(map(int, cryptography_version.split("."))) except ValueError: return if cryptography_version < [1, 3, 4]: - warning = 'Old version of cryptography ({}) may cause slowdown.'.format(cryptography_version) + warning = "Old version of cryptography ({}) may cause slowdown.".format( + cryptography_version + ) warnings.warn(warning, RequestsDependencyWarning) + # Check imported dependencies for compatibility. try: - check_compatibility(urllib3.__version__, chardet.__version__) + check_compatibility( + urllib3.__version__, chardet_version, charset_normalizer_version + ) except (AssertionError, ValueError): - warnings.warn("urllib3 ({}) or chardet ({}) doesn't match a supported " - "version!".format(urllib3.__version__, chardet.__version__), - RequestsDependencyWarning) + warnings.warn( + "urllib3 ({}) or chardet ({})/charset_normalizer ({}) doesn't match a supported " + "version!".format( + urllib3.__version__, chardet_version, charset_normalizer_version + ), + RequestsDependencyWarning, + ) # Attempt to enable urllib3's fallback for SNI support # if the standard library doesn't support SNI or the @@ -104,39 +127,56 @@ try: if not getattr(ssl, "HAS_SNI", False): from pip._vendor.urllib3.contrib import pyopenssl + pyopenssl.inject_into_urllib3() # Check cryptography version from cryptography import __version__ as cryptography_version + _check_cryptography(cryptography_version) except ImportError: pass # urllib3's DependencyWarnings should be silenced. from pip._vendor.urllib3.exceptions import DependencyWarning -warnings.simplefilter('ignore', DependencyWarning) - -from .__version__ import __title__, __description__, __url__, __version__ -from .__version__ import __build__, __author__, __author_email__, __license__ -from .__version__ import __copyright__, __cake__ -from . import utils -from . import packages -from .models import Request, Response, PreparedRequest -from .api import request, get, head, post, patch, put, delete, options -from .sessions import session, Session -from .status_codes import codes -from .exceptions import ( - RequestException, Timeout, URLRequired, - TooManyRedirects, HTTPError, ConnectionError, - FileModeWarning, ConnectTimeout, ReadTimeout -) +warnings.simplefilter("ignore", DependencyWarning) # Set default logging handler to avoid "No handler found" warnings. import logging from logging import NullHandler +from . import packages, utils +from .__version__ import ( + __author__, + __author_email__, + __build__, + __cake__, + __copyright__, + __description__, + __license__, + __title__, + __url__, + __version__, +) +from .api import delete, get, head, options, patch, post, put, request +from .exceptions import ( + ConnectionError, + ConnectTimeout, + FileModeWarning, + HTTPError, + JSONDecodeError, + ReadTimeout, + RequestException, + Timeout, + TooManyRedirects, + URLRequired, +) +from .models import PreparedRequest, Request, Response +from .sessions import Session, session +from .status_codes import codes + logging.getLogger(__name__).addHandler(NullHandler()) # FileModeWarnings go off per the default. -warnings.simplefilter('default', FileModeWarning, append=True) +warnings.simplefilter("default", FileModeWarning, append=True) diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 352e07bdce4aebb4420eb0b53a2840e8d474e02b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3697 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 X1;FAWj2esrj694w>>P|dOhU{6Nfi+) diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-39.pyc deleted file mode 100644 index 14b384f2fe0b155693eda83433bd2e85ff380d4a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 583 zcmYe~<>g{vU|^UdaWHi!BLl-@5C<7EGB7YWFfcF_>o71dq%cG=q%cM?rZ7b@r7%Y^ zr?5n^q_9S@rm#h^rLae_r*K4Zq;N)Yrf>x_Xma1;C`v6XO)V}dt`ZNZEXl~vQ}750 z2~bGOFH-O*%}vZJ)~k}wC@Co@w$j&!Db*`VO-w1tNKMI4F4oJ;uVOROGcwgP%w$w$ zVyNQvPR+|pEy+*_O3f^(suIpkb;yQ@6oCZv@{7`|xEu=-lQU8kjPwkuWSsL0DvL7H zGfEVU42%pEP_&owFfcGYnzKUT!~EV23XkTj@YCeF#Tg%8l39|I8Xtd)KR!MswK%yb zv!En1KQBK17JGbrX;Dsm{4MVI__EZZVu&bbe0)-AW==|c{4K8d_{7qZjQpbb_*(*S zc4}^7CRA5WW^!s?G01S<`1oX)+v4MIam2?bCuXO{$FF240yzsz{AzKwiU}=FEh>&l z%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwu ziAglk&B;&CEH25+j!Dfci}A@!iYd-4N!2Y#OwLYBPc4oq$Sly0FH6l!$uEM(fIgD% d^a?6(aoFVMr<CTT+OdL?fe-@&0}CTM1OSlUxV``Y diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-39.pyc deleted file mode 100644 index 374571eee1605a25b55e8d58efb33f090fa984aa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1330 zcmYe~<>g{vU|^UdaWK_`g@NHQh=Yuo85kHG7#J9e^%xi!QW&BbQW#U1au{=&qL^}- zqnLA9qF5LiQaDpsQdnCUqgYeeQrKG<qS#V6f*CZqs@8E8r52W^7MB$3#b@S~q!#5R z=ERqlWaboe)u8|`u7INavdom!Vg-<NW=W+&T4`Q#NoIatu|i2kVu?axQK~|6eqM2D zZfc4G%&eSBg``S_AgCQ&<r$gD844+>1*v%{3i){osTCzfskx~+l?rL8<scr|0SXzZ zIR&Xj#R?k5rO6oziNy-Z`MCv&C7N6>85tNDG?{O)WfsR5R2tplPAbjJDap)>FD@y% z#S9`?6N{5GGn1K+f(R5sAnXhar4oi3h7!hRrXqnFhFYdPsS>6lg&Kwh%r%S)8EcvH zxM~;{ut3-~Ou-DAj8&)IGs{x*6cQDRONuh{(iQTPvQm>vbQFqG(-VtQa#D+n74p** zN-7IdL1HDPMR~;vi3&xj1x2aFsd*)dpiolCPvcThP=JIL)SS#bg_4X^g}lU)%(7IN z;Sgg|^OEyZKz1eOr6{DNLOJCbsYR(^WAajyQ;Uleiz@XLLNYRo6%va<0bi`(80_rn zsZg2+c2r4zPKrW)Nk(c>d1i5{9$2F$>n*O#;>^6_lEl2^)FM#86oEqP78}^g)LU#| z+fqTH3~}Zy4zNsSUivNO{L+$@3`IN)3=F?IoULL)i&Kk=V^VWcGK*sT^HN=kK>pBG z2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwuiAglk&B;&CEH25+j!Dfc zi}A@!iYd-4N!2Y#OwLYBPc4oq$Sly0FH6l!$uH7}B~yL0WU5zCc}t)qKOPc>pmdO# zm(B-@X^<lsSh*P4m{=Hjn7EjVK%&W@1O!VPAT|dB0|Pi=STHa!z!F9=pBF<DW0gP+ z!vdxh#)XWG4B-qZOu-B+3?<B!MvM#~7|D>r9L!+AkirtopvhXb#U-^QwJ0|;FI6Ek zO`$X|GdVv69;NwtIhCNiQIeRM2aBTQjKreE<dW2)Vm&T!#8?$17A59_Qh`D#)E`#p z29@M1Bxj^1XX`2WmKK*NB&EU>fK31;FHmyH%P&y~s4U6I&r>i`NGL8TN`OSYRS_s{ zSt%st=jVVm6tOZeFod}IX|fctF)%O`v49A61_p*(LZJ{JxPp>ls%ueEevu~QEe@E& zz$pMi@Pd>JKs_9vSsV|}fO7B{VCQ3GV&r0EW8`5h5@cXt@Y7@jTdT=_i#<L*B|kYn y{uUb~e}mH@Bt?Q<0*WxO9*9k#2!*h~c5>L{=BJeAq}qX!a52dJEF2=tTmk?yEPJj1 diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-39.pyc deleted file mode 100644 index df29b1900ffe0afb90f0b3fb96e51ee647c48a4e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 17001 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 diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/api.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/api.cpython-39.pyc deleted file mode 100644 index 14204a4270461ca36cb2de310a9dbde001094927..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6787 zcmYe~<>g{vU|^UdaWFMOl7Zndh=Yuo85kHG7#J9eV;C41QW&BbQW#U1au{=&qL>&N zQkYX%S{S03Q$$kOQrKG<qgYZnQaD=}qF7V7Qn*_fqS#VIQ+QH%TNtC*Q^ZpEQutdK zqc~E;Qv^~3TNtA_Q-o54TNt9aQdol-G$pF$aTTQ&mZlb$6ze4xWOCIZ0WPkPjLc$% z-29Z%oK%I(+=86c+|<01Vug~7RD~d@E(ON`PdzR!tK|HG%A(Blj1nsajbu#)BLhPt zg``Ra@6^1!)RGK^pw!HgDm^Z%oXq6Zyy8?V1;>KK<cw4!9fji5R0SVTXIH;qSB13v zB8A-iqEv;H)RM%^oMJt$my8Sy44RC$IEqt?i!<}{ij$d;LW+fffq{d8fx#OTSWXNK z3?&Q;7#A}1tJN~sFlRBPG1M^BFs3lhVX9$T!q~?c&cMWw!o<SB!qCjj$Pmn6$WUxz zz`zKGkqnFsDNMl(n#_qmI2jn6^Ye;Jib|79iWL&`QWT0)^HPcx5*4hHa}tY-trDQV zSFnLH>=N|2xD*r=6s!soixP7ca#Kq(@>8s!G}vFDK+8)lM>irtAwMZAHMzt}AtAxt zH6$THM<F4>KOn@@-!B-#@o;r?fv^JngP{rnLSYQY5N8jNY<`hKLV}B{k86l)LV_N$ zTS|*^tQ10ne28%cibk+kimenh@(W5b^YapOG!<MjlflfQN*#rq%;FM-{4|A<(t@1S zVuk!7g`~=o)MAB_d~k4qod61w%sg;{DJ)Gbs#GX0Day=ChdTu=JW(B<l30>Rr0qHo zyLCXWNXyJg)y>JwPKCPw62dTtDL@^Rl%G-wc7H}HMx>yGLsoHq9*R306}*D|{S=B* zi!u{)GOH4ka#9rnDoZl*^PrJQwpAIai7BZ?xWXLdT91&B00j?-GPpJ6nI#$EK*k%M z$@%%&nW>nDg96PNEa#P2gzf|4j0S}{roo^@Qv?p<gaq}x#N1SMD+Q2BaO~(pVx>4C zK|uqYc&kyAfKyd%LV_kZt>l*Glw=kp7L_QZ<|XH+fRa#YK~8>R3M8UH$t)oOY&2M3 zLV`kaVxB@$szRcIkuF$BAt6CS9i#&64jr&N@{_VOL3zg*uM!;v_2m4#lGMDC_>#(k zRCUdS1VqXzQb<%VAxXQALUL(wNq%lTG_JueD9=bON>xZmfZ3!AwkaV&Arn;UKr#*7 z(v;M+%sfyKfQl5T(-c4&K<NV{mY!Lbng{kFxbR9yK(#R;K_O8gB{R7M91pMv2N{$I zF*h+KB@>*@a}=PCgxg(`uaKCM0*(`qO`rgUL;<wmODrwPK+P+qpri>ZB0#A%H4mIw zoDz#Oll5IP(^HE}^qs-Mp#V<Uj-@3TDCU)9=BDPCf+`h6A>@%?u8^CUSE*2(nw$?R zmrL>$$`dn7;I1l8Eh<Yb0@(*Dw-rF;2;2inscE1JCOxwZ6oRD%Itq!PAWqB4Pb>i! zABhT9MX7042^z`yd3mYHB??d{=qMDWCZ@p6fr@G>*g#pub_tN85bAz#gh1u26u{<# zG8#BBf=z*iSWZrUd3;f7N@h`NatUfCa>~!oNlnbtQ*Z@`n|?}WF*y9(T|@Mtb%Z{s zQqT_w4bcw(RR#KxDnK7pX(+%9&CJi!Q*cR5ODxR+)!z9E2?-%ZrK#|G0_@a8bay1> z=jR|hw4f-z0$cF`&E>g?1qGlWEhx$_$xqJD0R=xOiGXSzP%V*>ssJ*f5*j?<%0;0p zwJ0;K5+%X7W|m~6g0dCJ{?x=g9Z-2)o{^cHp^%(doT`vnq5w*&Mfo|!3gsE8V8!LB zP?Ny!1(gOM46+@P6x53qLVSW1l2eOHGSf1X6H8K|Q4PsiSggn`EiQqS9|ege8K}nQ zD<mp7J1QiV=B4DMg1lK;oQgMmA$~0`DN0SuMe%E9nnFT?TVhUeDySF&xwj~_xFA2T zI2G*2)Vvaf^30qZkV7(ab5m0?6H8KaDiu=l%kw~mUn;ctgQg^q_t1?G2G_Sb3LsyA zoLXF*qmZ1F2{IX^98ySV=oO^qYU(L?rYVGga;lDkhB`=AT}MGZJGD|>Q=uR+vj`e- zMX4pFMR`_8RVLKMHbGFg+rip2;9#>V0wpgi1$Z+PrVP?x3N21dPqngwa1<2m?Cd}- z&HSPgxCXE(5SgOXLIqp6gdWsL4Rv?d5Rh9lN=gcft@QOlbW&!XUVc%!etK$&x+ba- zP#)a93eiRe2C;TvVNIr6Y>>v=E#}gq96wFwB2a_#7JD$H{dtQWYN;km5vZA71Zslb zV#_X1EJ`oF#SU$yu4E|UWME+URpV?G6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e z8Wijq;ux&p>F46_=Njzk7!&O3>lz&58l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>b zQ=D0ns#}nloSm4SS{zf5S)d<ZmYSE6U!)IpS+Ra%L8e|oWf2<#1A_plWejp7gANxX zSi}#d1r728NE+ONR$^das9{<F?rtn(Vq_>`Oku8JNMlN2sbS1ygtVc988lfFQy3W- zf}u@fch?YDjG(rGhitnuMk_`O5}{TK{?MkcLSj*RDXjOCSfY@S01fSg1cj2s?9^ha z=MGQ_c8edaR1UetoSs^8iw#_&6t85u#Z{bIl9CE8*}<`^$qY`BMZ63Q3`Oi90+bNJ zsj&#u=`7-b^({fM&cMyX2o^~Ob+cd{D^P+5$%4~_94JjNVy1~qh8jjtpDLI^lcnk< zG%@5UKx-u`r-;E5BSqW{3=AQ+*deWv;vzl<28NYPkTAy<+@SpD56^>~Jd8yk5z2x) zF&ioSK`VN27oJM_kG#-U@Js`jprCY{fR=2*?by8h5>N}EEHfoFMF&)k!>YF8)DlqD z1g!`aG!l#92IUtN<QJ!=fTTgSBQ&KeSb>UYD|i-ENJ`B}EX&L<(xgc)1jo7CEf!E) z7#!h6f><(^5Ca1PXuPHvly$%v3nY>ZDqvw53naq|8?KN54_Blxf(qCg#u}y+ra4SC z%+M^woOl2!jzLX4D(5Irn;507fV*c;-@Y}dvkh*sgW??Ad?&TLPG0f_CpjzXHEuxJ z;1)|kesPH=(=8TIaNlA9`E4bn7S?2elo=wRlq3owu$3Od3=9m}pwa_WBs1_7f%v$q zZ!x44mBNHlWiu!4M@~<n)UL8Y{u@nB#U-?D4KNp!mK1?g3@EBsLaTbP0JhX4&cMJ> zg_L?gd@@tdLFCi}>SvA?N5qaE4x-|SwIH!1IRlY`ia>P`q-_XpC4w7>k_-$Cok*z$ z#K+xU0o8FO43Jt3sY%FG^&HwHRDcXfP&vH}qCjO!NzF+uNi70pNvsV6DFz0H8Snt* zECTU08T~Yw{QN)^qn{@CE%x~Ml>FrQ_*)F%?k2b?4{n%)n~O!DPzD$NMW8%f1d0-{ mF-UO-kHA|THo4##8#_?bqZp)>g^P!o!+?vQgO`J!3k(4iq~weM diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-39.pyc deleted file mode 100644 index 7a92375c9f29e9ad6e4ded4cb5b504ef84437755..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8359 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 F0|2U{^sxW{ diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-39.pyc deleted file mode 100644 index d0348e7aafc7bdc2141b1a15da6910c69d712750..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 661 zcmYe~<>g{vU|^UdaWM5FBLl-@5C<7EF)%PVFfcF_t1&Pzq%cG=q%fv1<uK+lMKLil zq%x;4XEPNkrLv?lH8V6bGBTvF1T$!|mbx)AFmM&67M7+KmlW$IrxukIbJd{$F0PP_ z%wmPy{FKt1RE46{lG38QVug~7RE2_~)U?#1qSO?Hl+?7u(wq_nXGaB)5t(V3$%!SY z3Q47TDLJWn3LzP(MX3sz#a#J$Ih6|ed8rDI8m54a0I}1G@^ir)s8)r7#N_P6^i(}A zF3&WD%KTD=#G+KFU}j#rLJ-uoItr<J>3TW}Y57G8i3&cMd8HK!DVfD3MVU#ZC7Jno z3SjZv#Jt4x)D*7Nyt2%q{Jh-Myb>L-p~;DP3dtFXdFiQO%TrR*GV?Ma`qC82K`z$N zR4B=Z`dA@Rp*Xc5u_&=5HK&pb>cSL|hoPS2dI^dQO~zZSV7<3E;^T7@GxOr({WMu` zvB$@!<R{0+-x4m!EYOQDOU+BkF9L^lW?E(uDCR)w^AdAY<Ku6!78GUXm8@ha;$UEa z5Wni2tztrpQ;UjYQgc!=i(>rqQeBEN%Tg6|6+-<y!(4-cJwqIW6+Hc1{QX>mJso3$ zU431HLtKLt%whrpd}0z!baV34GmA?yvtv^8%3^#nlVXZ9OHy^A9x09~$Slx@x=SCH i9P~jEQmj`{d5gm)7aaX|ET9C&#=yY9!p+0P!3Y2dtkXgO diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-39.pyc deleted file mode 100644 index 5c24a9d94c66d7c7c7b8d367cab8cd078b2a0818..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1640 zcmYe~<>g{vU|^UdaWM5SI|IXG5C<7EGcYhXFfcF_uVZ9jNMVR#NMTH2%3;i9ieh2} zv6*w2qnJ~fvsj{7Q(03OB^gp!vYDdTplsG`rYQCl#uVlpjwp^)wxUldj45n6oVi?4 zT)Es)+_^kaJh{A4yt#Z)e7XEl{J8>A0=a@wg1JIbLSWO`bA)q+ql9xsqC|2<qeOGX zqQr8=qr|~-961uXl2MXiHgk?tlvE013TKXVu1u5+Sd1%2Hdi)E7R=_(k;|2jlFwC$ zQpi<|Qp{C~QetFCRgO|gRgO|kRf|$iRgY3n)kxJ$)k<TI(gv~8n4)y@cBHaTU@Tgd z!kEI7ql@7ZkgL&s0&^X2jvmN$SbfEpqn~RKB?WdFXO1C~i;dte=FgFXxH5$?MIgr* z+4XRjE2pYPsirEYs-`i4U9XkK1af;CW0Xz`b1;LZU{xVkQEFjnYH>-iUUGhJL1GD4 z9V+1B3dzVUR>;jyDa}b$$Vkjf$w@6%$jmLsFDg-hXvs{<%*iaNRLCqYE=?^~NJ=d! zPfg8J2&gQ{$j?(SQb^28;ev9E^|)Sw5|1Y1E%xM$#G;hc62F&B3=9k}LCHvy^A>Ai zX?{uSE%wqp2!jhu#TVq17T@B53PO0CrA0ZZdCB=HskgY&Q%eep@+&e^i*NCO7?tr! zl?92##kVAodGV=vWtm0!dAX^1CAY*7dXU96S#NQa7UdKq78R%7;wml5Db0hh*-MLZ zvhp+Yz|zG9IhiH5KrTp0O)E-F*JQlK4^|eRQBqP6pOaZ!qRDuR%{RZOI5kI;@fJsL zNl|8Ax~IP;%PkJ)#GIVOq@2`S?7oQw1(|v2xA=TZOF$wpKDU2SN@`JRic4m4i6&PO z9|HqJ5kH6!01<*9f)hlrf(SMc!44ugK!gwj1A``OkuZo2%D6?`AQlgZ-~~xB-r`Ko z&(F?G%}OlNWGs>di7^+6f#k(Ogak;y<Q98;d`f<DeEco$g3JQF__EZzl>DM1P)yxo zF0L%T#Z#7ARGgWg7oVAzmVb*SzAUxq7F%X<d_koVls3M_l2x3acZ;pGC?_W~sR)~6 z!M?!aN~~T6`Ro=b8gep|jKCg*c_k+^=@y$a*jGg&AWw)gFfiQWPR`HCNlh-v%+D)E z^B~yUx0s7dif(Zym1gFYWah<#IIKyPC8@=r)RzfKSV@V+sm0*9yTzQDS8|IbCqFO! z7He8geqzZj-n`P>)S}Gf_>#(k)Z$ybnRz9t>8V9fE)T@tdf;?%ix0|!=C)fbpoCH+ z1#%}3h^YsOl;T@VnfbT)kzB5qn3TMdp~wQ{EfDdm-q|W9v^ce>I3_hGC9^2TKQGm# zD6=e8L02Kv&oj(5DA+T^F<8OV&&A)*HQ3WJCfL>2H8{jINWm;7AiyUk(L^^VKRvU! zBr`iEHLonjCo?IgII|>Gw;(Y&J25@AIHn-8Kpz_8`cU^4>qD}-UP0w84x3zXVPFT! zvc)b83=AwBJWL$yY|K2&Je(YCEQ~tLGK@To9E?1SJWLYIEQ}Dy#mL3P#%RC@k^{-` NFp4liWH=Z(7y-F;(6;~p diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-39.pyc deleted file mode 100644 index a7ccf7ba7d882764fffa266e696cb587eeefaf6c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18850 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⋙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 diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-39.pyc deleted file mode 100644 index 2458922bbb3e95b7590746342d0e8059d3c97942..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5273 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 BqhJ64 diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/help.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/help.cpython-39.pyc deleted file mode 100644 index d12a2de85885cf37b9ceae801f6bb718a9da7d00..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2744 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 G9E<=!4*K!{ diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-39.pyc deleted file mode 100644 index 0b85dce6ca22560e9f9887ee792b05b55ad6ef00..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1018 zcmYe~<>g{vU|^UdaWM5O69dCz5C<7EF)%PVFfcF_%P}x8q%cG=q%fv4Mlq%^r7*WJ zL@}kXq_DOyL@}qZ1v6-}S8e1fN-Zo+EiNh6%gE2qF6OF30bE=m8JWcjx%nxjIjIT- zMfqi!DXGN@B^jv-$%zGtNtrpBC7G$k3TgR8V8I}$VG3Zw6pAa0OHy<7xVRk45;JoW zlX6la5>{MX2?<51#Rd6!#i<DiR$K}S3JM_^sR}SLh4j?C)S|?a)D(rZqWoNiL<OkH zdR(_SV2YBFy$xc6yzb1vz);Kw@;YM*Qwu{0g9}45V=#jzvtKeJNDUN&l(H}|Fa(2? z3o$S-WHQt+#B$X#)-a|sOlB%%31(QyPy|w?$#jcJ&)^noYFTPt30MS7{Hk-diU}=F zEh>&l%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1 ziwOwuiAglk&B;&CEH25+j!Dfci}A@!iYd-4N!2Y#OwLYBPc4oq$Sly0FH6l!$uH7} z#gaZaVD$<rZ*keAWG0s+=jRsKf!zNY<gqHnl+?7u(wvfbh%%d;{N%)(Vmm#AT201V ztRDXU-oapBAQ7w#3=Fq;QS=Lf0tXZZ42(sb3=9m(%pgmkn2mvf0i?$pq$q%afuV-6 zfGv{&6oLyFY8VzWf>=d9C5$zUDU8ibMQSyS>0mJzhFFDKmKv5CrZmP(h8pH2jD3u? ztTn7DOr?xPS~aY-OoduCOrR*MGIPl+E=Vj%&PXj*NCYPx1(2sR^YapmDi!kc6cQEE zGs{x*6bdp^lT#J)(-cw?OA_^Nam2?bC+6hD$NOnA-C|BpExE;>kyxBqQc|SJc8fVX zwel7#IDl?(f~a_qrdw>;<%vb<#kW{MLbtfUAqbYi3?rzcz)HkH-WLId2@?k+7b6QJ z7b6=Z2crNZ2O}F}kuU=TgP$hLE%x~Ml>FrQ_#zGl1_p3gf~Am*1_g5wC_Ha**yMt< Sn;j^$i$TH6!p+9a!3F>n5DV)7 diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-39.pyc deleted file mode 100644 index 21140b24e3ba1680b590f4f1c625943bf02f587c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 23967 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 Y92oy*;Q-Uj0!0E60$xJ(4D}550HeU1G5`Po diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-39.pyc deleted file mode 100644 index f557c13f250ce06d9f6999e7130794cb7779b710..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 530 zcmYe~<>g{vU|^UdaWHi|69dCz5C<8vF)%PVFfcF_moYFfq%fo~<}gGtq%gTK#HK_s zrZA^6iZetpr81{7H8ZBNG&7_!+AyTDrZQx)H8Z*}#M(u%r?RIqWiu6frLr&JNM%Z4 z5ocJ)SY(jOp30fR+{~E5*vcfy5XA-3k;*Q~0HRY^Q@O+$Y#0g+3VBi(gBdj0UV>cY zr^$Say|gGNCo{?T7E5MIUg9nG<c!3kl+=<co`TE*z4)@!yp;SRy<3cWRdUDzMX80Q zsl_G5dIgEe*@@|?#d@0Dx0s77i*K<*MQ#Z|^roi7!$i2^<1=#$@{3C1<8QI$<R>TQ z6yIXW$t*6p#h#m=Qks)me2Y0ZKjjuzaY<rPNpX2*NyaVaoYcHqe5H8>MX70-6{#ul zx%nw88HxlM7$C&2MrW&-(Bjmh;+WK&l+2<S|GZR}qRg^X1zm+uKhH4NpkU7s$6y6d zKNo*L*I-Y_m|$05*WeJ>AO*9SfB>JEL=)Yd{PfJ?lFaOw)V#77pUk9~;>?m%U8t*z xV+t}0^q~Qv5A(M^OjfU;@)m~;#QAoNpjhQ&U|`^2<zVDs<YVSz6k`-%1OScUok{=z diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-39.pyc deleted file mode 100644 index 76ee71a4f84d66ee3c41b423d37b513e35f86327..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 19872 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 Sk30{*Ks`f|Ks^Hp8Up|_Z8`D) diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-39.pyc deleted file mode 100644 index 3b6879372aaf03a33d9916feb4d0ccdda39369b8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4267 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 diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-39.pyc deleted file mode 100644 index fb9e8d36fb22c87b967f26a81413e07e8b8ecbc6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4488 zcmYe~<>g{vU|^UdaWHi+Hv_|C5C<8vFfcGUFfcF_yD%^?q%cG=q%fv1<uK+lMKLil zq%fzj<S^&5M6u+uMzJz7xHF`%rm(dzq_Cy3HZw=Dxih4&r*O0|q;RCNH#0|Zq;Li^ zXmVBga}}i)mZlb$6zdh26qP2Iloq8HbJbx2E-shEl0*fBB88HS#1e&q{PNTyg&>$2 zTrWWm)?~cJ?O&9VT9lgNl9^ocl97RdL6hkgyKiDaL1te1Ek57UlEkE(R46|gqz4%@ z!#tYAz`&5o5XG3n5XF?j7{#0-4)SITV-yR-b5X1iPerk%aHepzFhsGZaHsIJFhp^r z@TTy!Fhp^t@TUm0Fhp^s2&M?NFhp^u2&ag&FhudBh^C0OFhudDFa<McO5755PApFK z%qvdKE6yy*EK3DBJMkJb1B0VNa$<3+ZYDxXAt50pGr1%oK{qEeJ5?b+DJwO(M30M0 zK|w*mGq)foH8(Y{q*x&_Cr2SSwIm}yrC1>`FGV50Ahjs5Br`v+SRp?RtT-V7H5d{S z6cURS%2RW4Ks3k>^<ssDgyj5!%7g?x1;?D?e6YTPqWrSVlvI#h4k+~FGfPr)ixU!{ zZg9-WQOHiMELKP?N>xa$C`e5%Nlj5G$yZ291;t)wUV5>fLP!Rf1Bq{iqSV~f+@#c^ zVug~7RInW&Pb=i7f%pnJiNz%#6Jchgmgs<el#q~Fl3JvZnO9trn3tTYnUJ6Z)|-$3 zvR(tkR{*QYEk@!LAtXV;0#;B2_5nx{*nslPoE(MZ{JfIH%sfc&!{Y_yj$%CpkNon~ zveY6Sg~HO*qRPy?bg+Y<T8hDjl%y7yfFv@D!A2+`#h{fHB(^{?mYkWQV5@*7_BAxY z#z56Xt2-tqrxui`$12z=s3#T_<YXp;V^cq?I6qGvRcWHLvui*INGUe83JS^!Aw{K- za0VHllUZD%k(`;LsbFiXfMgL&9oTTU{33<aibPQQ(oslA$Vg30Ni8alRtNbxHLpZB zH7_|oB{MHwJvJdh0UUrusU@XFd7u~s8&H;*Q<@5j(nN)X1a;^9yb_Q$SD3bh1cjp1 z;)49V;#38Q;W`RMsp*MDDLJXdkPyvJQ^?3K2N?)ep^%rDo2pQrSgep=l$oBHmza}N zsZd;!UzC~xO^cq86qKBw2Prr5i$IRoD=kP#EJ;mB&`|*Ss<1RMC$pqdAvr&{Ah9U3 zI6n{UV5AHKO3CS&WvO}K=!X<M8Hr`73aKEy3JD2%;EVuDK*c&B2Z9YqO3g?t%girQ z$ShVU%}Ys5%gh5g3>4&k$xKM)4XC&Qm95^OvQ>+LfuV$<nW2Uup0S28g`t$8NF<Y? zma&E*i>Zb&jWLs<hG_|7A0s0}3PUi%N=83T<|2?`x7gyrUcbc#@tr2~EtcZcoU~gk zDTyVCx7f1F6N}P|S27gwGB7awYIe4Y2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK z4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-24N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySez zDb6fO)h$R&&Q45EEsiP3EYOcHOU+BkFVcq<@%oTh02T3i1(mlr;^Q;(GE3s)L4Gdg z0EGx62O|d~3uBcGmK>o6Q=SY8Fpz2x2C+eb=L`xwF$M;P8pax?G^QGcEQT7!1&j+B zY`_6k#LmFLu#%|=WXmm9aCB)h7lG=#Tg=(1mA6>I=@T3{5Q2|^f#DW+e0*_g38-|4 zk2e5W019aa<|=vY&V#E(iC&N%kSoD16au*r?lwt=6h=vgU<OSlzao&5A_0giLGCI7 zDTTNN6lFy)2c^RtWD0i>BQ6KQ)#7##$VNn9*&+f9?3N-?1_nryfw%<bh?LYENT^s4 zb_85)GN>K~#Tf{L*dQ;1Lq!DCpkPd4YGD951r%#849$$e44TY-D4IYTK)4uWD>$+l zV)<g2Y8h*pY8b;97#RwgK)C`O*<c52GT&m-Gq}Y8s!vit@ywl@SWu9ff;F}|ZPHWo zQY#9I>}(hq7(RnsS*4FXra?7Ne7v4bPJVJ?PO+UHT&E^9iLrrgC|=13PGexVKnQRM zf>M4-YEgW=HOM2N1j2wj&4U%91Oq7SK$^f|2TCg?pm1XZg&5fDnoPHtb5irbiM>b; zOANBd$LFNx#mCzrSuc&<r(ks$wu2%8Y&-6ltJ3oUwNF4H1xhN#8k#x^Nu?zU<(VZJ z;MNH^6M`ZJT&n7!*a0#hl&irJ4e~(^L#!AqqHCB^7$h0en4l33N+(R<?BfRxVol~E z2~g(c09ycxbhhl&%Cf{9uq=cC#X^xZ0|Nut6Cj&dnArYT8DR?purZKE4xR{S1$z=} zXmcZ(;0OwFHc--HVq@m`i#_8asmI8;Ah&`Y4JwaH7-|?x7@L`jL`s-y7@HYu8S_|5 zn1dNgSZWv+ur6e1W-MW;VT7=<nSvQ0se|nnS7tG+*;E8Fun6R$TYP@`CGZwxYRWAZ zP#dsF72J3RC*xbJ`6U^tMUWsw6iRII@u`LJ@tz>Bfy!3~MlMD!CKjeDDQv+BQH&DX zp!5uiaj?HYQ3FZO3z$GYfVr9(>_|wOmIbA0P_jUG3Ja*U8U%6(D1R_8R!LxU0!R^t z13=*bb^xeEEMX{NtYLsS0FkYjZ!s5_6cuTJY*zsh*qp!-A77MOP!t~@isTF&^%+E= zCZnGwAE-72wP)hvZ*j%P=jNxB=A_2Q-{Ogn2emPvGVJm3Df!9q@kRU~+d+A+2viCd ziG#TEAVLvDfTFAjRH+tegSfgN0vufk0u;*N00o&;3^Ig+kwuD&jf0hg845W#I5{AJ zj?qB^g%v0b7lR5)lnxSiJ3|^HxRb<*rIW-1?j|utv9~j@Fhp?#GidVO;_}JQ&n_(h z^?0fzL1borUSd(DLJn9M*1th*F@Yi%lwd%(7?jy-7;6~f8A=#Sm}(fBnHDfFWPr4f zAPJu377Hi<Z?P7a7Niyx8G*tB<Zn$TaI!8k2GzQZw>abDlXDV_i{s-V$qF1sAayaI zm<0Qok&UrR7~x<<lLVB6K_LRdAU4Q_;M4>vo>M@rHwH0CMPJ2h1NEA^YO%VVCL`E- zYz0RVDB==8c7se~K(`r^cyJdGAm>A>Q&2l{AuRi^WCA5MP}Yu*zr~!MT7s>P2PZ2~ zv=@V|X08%L@id}c0g3^TpFtSJ289yX-^jMtFu`pvG6xkWkd_y?g>#ENB{eOvG^Yd- z=HL_x(pzN7z`&4!<as_M7o?|_fHDoEpC)IK9w;{TK?JBoEHVVKK#>LxJ+ME(M&06t z#%^+IP7W-F!M1_gQQ+1UIAKJBtOP|G2O|p;9}5RF2P;?{WEIHlTinU{IXS7x;I1^Z x<qhsRlt4;SR*?Om;uKO$fYTb-8Uz9I-YpIrNFKKXg&Mf=%fimXB)}}-1pvq=J)i&p diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-39.pyc deleted file mode 100644 index ce754ef04535db9472a6f2b5c333a31161c226e5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 22645 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 Ih;j%509wJEbN~PV diff --git a/env/Lib/site-packages/pip/_vendor/requests/__version__.py b/env/Lib/site-packages/pip/_vendor/requests/__version__.py index 1267488d..5063c3f8 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/__version__.py +++ b/env/Lib/site-packages/pip/_vendor/requests/__version__.py @@ -2,13 +2,13 @@ # |( |- |.| | | |- `-. | `-. # ' ' `-' `-`.`-' `-' `-' ' `-' -__title__ = 'requests' -__description__ = 'Python HTTP for Humans.' -__url__ = 'https://requests.readthedocs.io' -__version__ = '2.25.1' -__build__ = 0x022501 -__author__ = 'Kenneth Reitz' -__author_email__ = 'me@kennethreitz.org' -__license__ = 'Apache 2.0' -__copyright__ = 'Copyright 2020 Kenneth Reitz' -__cake__ = u'\u2728 \U0001f370 \u2728' +__title__ = "requests" +__description__ = "Python HTTP for Humans." +__url__ = "https://requests.readthedocs.io" +__version__ = "2.31.0" +__build__ = 0x023100 +__author__ = "Kenneth Reitz" +__author_email__ = "me@kennethreitz.org" +__license__ = "Apache 2.0" +__copyright__ = "Copyright Kenneth Reitz" +__cake__ = "\u2728 \U0001f370 \u2728" diff --git a/env/Lib/site-packages/pip/_vendor/requests/_internal_utils.py b/env/Lib/site-packages/pip/_vendor/requests/_internal_utils.py index 759d9a56..f2cf635e 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/_internal_utils.py +++ b/env/Lib/site-packages/pip/_vendor/requests/_internal_utils.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests._internal_utils ~~~~~~~~~~~~~~ @@ -7,11 +5,24 @@ requests._internal_utils Provides utility functions that are consumed internally by Requests which depend on extremely few external helpers (such as compat) """ +import re + +from .compat import builtin_str + +_VALID_HEADER_NAME_RE_BYTE = re.compile(rb"^[^:\s][^:\r\n]*$") +_VALID_HEADER_NAME_RE_STR = re.compile(r"^[^:\s][^:\r\n]*$") +_VALID_HEADER_VALUE_RE_BYTE = re.compile(rb"^\S[^\r\n]*$|^$") +_VALID_HEADER_VALUE_RE_STR = re.compile(r"^\S[^\r\n]*$|^$") -from .compat import is_py2, builtin_str, str +_HEADER_VALIDATORS_STR = (_VALID_HEADER_NAME_RE_STR, _VALID_HEADER_VALUE_RE_STR) +_HEADER_VALIDATORS_BYTE = (_VALID_HEADER_NAME_RE_BYTE, _VALID_HEADER_VALUE_RE_BYTE) +HEADER_VALIDATORS = { + bytes: _HEADER_VALIDATORS_BYTE, + str: _HEADER_VALIDATORS_STR, +} -def to_native_string(string, encoding='ascii'): +def to_native_string(string, encoding="ascii"): """Given a string object, regardless of type, returns a representation of that string in the native string type, encoding and decoding where necessary. This assumes ASCII unless told otherwise. @@ -19,10 +30,7 @@ def to_native_string(string, encoding='ascii'): if isinstance(string, builtin_str): out = string else: - if is_py2: - out = string.encode(encoding) - else: - out = string.decode(encoding) + out = string.decode(encoding) return out @@ -36,7 +44,7 @@ def unicode_is_ascii(u_string): """ assert isinstance(u_string, str) try: - u_string.encode('ascii') + u_string.encode("ascii") return True except UnicodeEncodeError: return False diff --git a/env/Lib/site-packages/pip/_vendor/requests/adapters.py b/env/Lib/site-packages/pip/_vendor/requests/adapters.py index c30e7c92..10c17679 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/adapters.py +++ b/env/Lib/site-packages/pip/_vendor/requests/adapters.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.adapters ~~~~~~~~~~~~~~~~~ @@ -9,57 +7,75 @@ and maintain connections. """ import os.path -import socket +import socket # noqa: F401 -from pip._vendor.urllib3.poolmanager import PoolManager, proxy_from_url -from pip._vendor.urllib3.response import HTTPResponse -from pip._vendor.urllib3.util import parse_url -from pip._vendor.urllib3.util import Timeout as TimeoutSauce -from pip._vendor.urllib3.util.retry import Retry -from pip._vendor.urllib3.exceptions import ClosedPoolError -from pip._vendor.urllib3.exceptions import ConnectTimeoutError +from pip._vendor.urllib3.exceptions import ClosedPoolError, ConnectTimeoutError from pip._vendor.urllib3.exceptions import HTTPError as _HTTPError -from pip._vendor.urllib3.exceptions import MaxRetryError -from pip._vendor.urllib3.exceptions import NewConnectionError +from pip._vendor.urllib3.exceptions import InvalidHeader as _InvalidHeader +from pip._vendor.urllib3.exceptions import ( + LocationValueError, + MaxRetryError, + NewConnectionError, + ProtocolError, +) from pip._vendor.urllib3.exceptions import ProxyError as _ProxyError -from pip._vendor.urllib3.exceptions import ProtocolError -from pip._vendor.urllib3.exceptions import ReadTimeoutError +from pip._vendor.urllib3.exceptions import ReadTimeoutError, ResponseError from pip._vendor.urllib3.exceptions import SSLError as _SSLError -from pip._vendor.urllib3.exceptions import ResponseError -from pip._vendor.urllib3.exceptions import LocationValueError +from pip._vendor.urllib3.poolmanager import PoolManager, proxy_from_url +from pip._vendor.urllib3.util import Timeout as TimeoutSauce +from pip._vendor.urllib3.util import parse_url +from pip._vendor.urllib3.util.retry import Retry +from .auth import _basic_auth_str +from .compat import basestring, urlparse +from .cookies import extract_cookies_to_jar +from .exceptions import ( + ConnectionError, + ConnectTimeout, + InvalidHeader, + InvalidProxyURL, + InvalidSchema, + InvalidURL, + ProxyError, + ReadTimeout, + RetryError, + SSLError, +) from .models import Response -from .compat import urlparse, basestring -from .utils import (DEFAULT_CA_BUNDLE_PATH, extract_zipped_paths, - get_encoding_from_headers, prepend_scheme_if_needed, - get_auth_from_url, urldefragauth, select_proxy) from .structures import CaseInsensitiveDict -from .cookies import extract_cookies_to_jar -from .exceptions import (ConnectionError, ConnectTimeout, ReadTimeout, SSLError, - ProxyError, RetryError, InvalidSchema, InvalidProxyURL, - InvalidURL) -from .auth import _basic_auth_str +from .utils import ( + DEFAULT_CA_BUNDLE_PATH, + extract_zipped_paths, + get_auth_from_url, + get_encoding_from_headers, + prepend_scheme_if_needed, + select_proxy, + urldefragauth, +) try: from pip._vendor.urllib3.contrib.socks import SOCKSProxyManager except ImportError: + def SOCKSProxyManager(*args, **kwargs): raise InvalidSchema("Missing dependencies for SOCKS support.") + DEFAULT_POOLBLOCK = False DEFAULT_POOLSIZE = 10 DEFAULT_RETRIES = 0 DEFAULT_POOL_TIMEOUT = None -class BaseAdapter(object): +class BaseAdapter: """The Base Transport Adapter""" def __init__(self): - super(BaseAdapter, self).__init__() + super().__init__() - def send(self, request, stream=False, timeout=None, verify=True, - cert=None, proxies=None): + def send( + self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None + ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest <PreparedRequest>` being sent. @@ -107,12 +123,22 @@ class HTTPAdapter(BaseAdapter): >>> a = requests.adapters.HTTPAdapter(max_retries=3) >>> s.mount('http://', a) """ - __attrs__ = ['max_retries', 'config', '_pool_connections', '_pool_maxsize', - '_pool_block'] - def __init__(self, pool_connections=DEFAULT_POOLSIZE, - pool_maxsize=DEFAULT_POOLSIZE, max_retries=DEFAULT_RETRIES, - pool_block=DEFAULT_POOLBLOCK): + __attrs__ = [ + "max_retries", + "config", + "_pool_connections", + "_pool_maxsize", + "_pool_block", + ] + + def __init__( + self, + pool_connections=DEFAULT_POOLSIZE, + pool_maxsize=DEFAULT_POOLSIZE, + max_retries=DEFAULT_RETRIES, + pool_block=DEFAULT_POOLBLOCK, + ): if max_retries == DEFAULT_RETRIES: self.max_retries = Retry(0, read=False) else: @@ -120,7 +146,7 @@ class HTTPAdapter(BaseAdapter): self.config = {} self.proxy_manager = {} - super(HTTPAdapter, self).__init__() + super().__init__() self._pool_connections = pool_connections self._pool_maxsize = pool_maxsize @@ -140,10 +166,13 @@ class HTTPAdapter(BaseAdapter): for attr, value in state.items(): setattr(self, attr, value) - self.init_poolmanager(self._pool_connections, self._pool_maxsize, - block=self._pool_block) + self.init_poolmanager( + self._pool_connections, self._pool_maxsize, block=self._pool_block + ) - def init_poolmanager(self, connections, maxsize, block=DEFAULT_POOLBLOCK, **pool_kwargs): + def init_poolmanager( + self, connections, maxsize, block=DEFAULT_POOLBLOCK, **pool_kwargs + ): """Initializes a urllib3 PoolManager. This method should not be called from user code, and is only @@ -160,8 +189,12 @@ class HTTPAdapter(BaseAdapter): self._pool_maxsize = maxsize self._pool_block = block - self.poolmanager = PoolManager(num_pools=connections, maxsize=maxsize, - block=block, strict=True, **pool_kwargs) + self.poolmanager = PoolManager( + num_pools=connections, + maxsize=maxsize, + block=block, + **pool_kwargs, + ) def proxy_manager_for(self, proxy, **proxy_kwargs): """Return urllib3 ProxyManager for the given proxy. @@ -177,7 +210,7 @@ class HTTPAdapter(BaseAdapter): """ if proxy in self.proxy_manager: manager = self.proxy_manager[proxy] - elif proxy.lower().startswith('socks'): + elif proxy.lower().startswith("socks"): username, password = get_auth_from_url(proxy) manager = self.proxy_manager[proxy] = SOCKSProxyManager( proxy, @@ -186,7 +219,7 @@ class HTTPAdapter(BaseAdapter): num_pools=self._pool_connections, maxsize=self._pool_maxsize, block=self._pool_block, - **proxy_kwargs + **proxy_kwargs, ) else: proxy_headers = self.proxy_headers(proxy) @@ -196,7 +229,8 @@ class HTTPAdapter(BaseAdapter): num_pools=self._pool_connections, maxsize=self._pool_maxsize, block=self._pool_block, - **proxy_kwargs) + **proxy_kwargs, + ) return manager @@ -212,7 +246,7 @@ class HTTPAdapter(BaseAdapter): to a CA bundle to use :param cert: The SSL certificate to verify. """ - if url.lower().startswith('https') and verify: + if url.lower().startswith("https") and verify: cert_loc = None @@ -224,17 +258,19 @@ class HTTPAdapter(BaseAdapter): cert_loc = extract_zipped_paths(DEFAULT_CA_BUNDLE_PATH) if not cert_loc or not os.path.exists(cert_loc): - raise IOError("Could not find a suitable TLS CA certificate bundle, " - "invalid path: {}".format(cert_loc)) + raise OSError( + f"Could not find a suitable TLS CA certificate bundle, " + f"invalid path: {cert_loc}" + ) - conn.cert_reqs = 'CERT_REQUIRED' + conn.cert_reqs = "CERT_REQUIRED" if not os.path.isdir(cert_loc): conn.ca_certs = cert_loc else: conn.ca_cert_dir = cert_loc else: - conn.cert_reqs = 'CERT_NONE' + conn.cert_reqs = "CERT_NONE" conn.ca_certs = None conn.ca_cert_dir = None @@ -246,11 +282,14 @@ class HTTPAdapter(BaseAdapter): conn.cert_file = cert conn.key_file = None if conn.cert_file and not os.path.exists(conn.cert_file): - raise IOError("Could not find the TLS certificate file, " - "invalid path: {}".format(conn.cert_file)) + raise OSError( + f"Could not find the TLS certificate file, " + f"invalid path: {conn.cert_file}" + ) if conn.key_file and not os.path.exists(conn.key_file): - raise IOError("Could not find the TLS key file, " - "invalid path: {}".format(conn.key_file)) + raise OSError( + f"Could not find the TLS key file, invalid path: {conn.key_file}" + ) def build_response(self, req, resp): """Builds a :class:`Response <requests.Response>` object from a urllib3 @@ -265,10 +304,10 @@ class HTTPAdapter(BaseAdapter): response = Response() # Fallback to None if there's no status_code, for whatever reason. - response.status_code = getattr(resp, 'status', None) + response.status_code = getattr(resp, "status", None) # Make headers case-insensitive. - response.headers = CaseInsensitiveDict(getattr(resp, 'headers', {})) + response.headers = CaseInsensitiveDict(getattr(resp, "headers", {})) # Set encoding. response.encoding = get_encoding_from_headers(response.headers) @@ -276,7 +315,7 @@ class HTTPAdapter(BaseAdapter): response.reason = response.raw.reason if isinstance(req.url, bytes): - response.url = req.url.decode('utf-8') + response.url = req.url.decode("utf-8") else: response.url = req.url @@ -301,11 +340,13 @@ class HTTPAdapter(BaseAdapter): proxy = select_proxy(url, proxies) if proxy: - proxy = prepend_scheme_if_needed(proxy, 'http') + proxy = prepend_scheme_if_needed(proxy, "http") proxy_url = parse_url(proxy) if not proxy_url.host: - raise InvalidProxyURL("Please check proxy URL. It is malformed" - " and could be missing the host.") + raise InvalidProxyURL( + "Please check proxy URL. It is malformed " + "and could be missing the host." + ) proxy_manager = self.proxy_manager_for(proxy) conn = proxy_manager.connection_from_url(url) else: @@ -343,11 +384,11 @@ class HTTPAdapter(BaseAdapter): proxy = select_proxy(request.url, proxies) scheme = urlparse(request.url).scheme - is_proxied_http_request = (proxy and scheme != 'https') + is_proxied_http_request = proxy and scheme != "https" using_socks_proxy = False if proxy: proxy_scheme = urlparse(proxy).scheme.lower() - using_socks_proxy = proxy_scheme.startswith('socks') + using_socks_proxy = proxy_scheme.startswith("socks") url = request.path_url if is_proxied_http_request and not using_socks_proxy: @@ -386,12 +427,13 @@ class HTTPAdapter(BaseAdapter): username, password = get_auth_from_url(proxy) if username: - headers['Proxy-Authorization'] = _basic_auth_str(username, - password) + headers["Proxy-Authorization"] = _basic_auth_str(username, password) return headers - def send(self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None): + def send( + self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None + ): """Sends PreparedRequest object. Returns Response object. :param request: The :class:`PreparedRequest <PreparedRequest>` being sent. @@ -415,86 +457,47 @@ class HTTPAdapter(BaseAdapter): self.cert_verify(conn, request.url, verify, cert) url = self.request_url(request, proxies) - self.add_headers(request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies) + self.add_headers( + request, + stream=stream, + timeout=timeout, + verify=verify, + cert=cert, + proxies=proxies, + ) - chunked = not (request.body is None or 'Content-Length' in request.headers) + chunked = not (request.body is None or "Content-Length" in request.headers) if isinstance(timeout, tuple): try: connect, read = timeout timeout = TimeoutSauce(connect=connect, read=read) - except ValueError as e: - # this may raise a string formatting error. - err = ("Invalid timeout {}. Pass a (connect, read) " - "timeout tuple, or a single float to set " - "both timeouts to the same value".format(timeout)) - raise ValueError(err) + except ValueError: + raise ValueError( + f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, " + f"or a single float to set both timeouts to the same value." + ) elif isinstance(timeout, TimeoutSauce): pass else: timeout = TimeoutSauce(connect=timeout, read=timeout) try: - if not chunked: - resp = conn.urlopen( - method=request.method, - url=url, - body=request.body, - headers=request.headers, - redirect=False, - assert_same_host=False, - preload_content=False, - decode_content=False, - retries=self.max_retries, - timeout=timeout - ) + resp = conn.urlopen( + method=request.method, + url=url, + body=request.body, + headers=request.headers, + redirect=False, + assert_same_host=False, + preload_content=False, + decode_content=False, + retries=self.max_retries, + timeout=timeout, + chunked=chunked, + ) - # Send the request. - else: - if hasattr(conn, 'proxy_pool'): - conn = conn.proxy_pool - - low_conn = conn._get_conn(timeout=DEFAULT_POOL_TIMEOUT) - - try: - low_conn.putrequest(request.method, - url, - skip_accept_encoding=True) - - for header, value in request.headers.items(): - low_conn.putheader(header, value) - - low_conn.endheaders() - - for i in request.body: - low_conn.send(hex(len(i))[2:].encode('utf-8')) - low_conn.send(b'\r\n') - low_conn.send(i) - low_conn.send(b'\r\n') - low_conn.send(b'0\r\n\r\n') - - # Receive the response from the server - try: - # For Python 2.7, use buffering of HTTP responses - r = low_conn.getresponse(buffering=True) - except TypeError: - # For compatibility with Python 3.3+ - r = low_conn.getresponse() - - resp = HTTPResponse.from_httplib( - r, - pool=conn, - connection=low_conn, - preload_content=False, - decode_content=False - ) - except: - # If we hit any problems here, clean up the connection. - # Then, reraise so that we can handle the actual exception. - low_conn.close() - raise - - except (ProtocolError, socket.error) as err: + except (ProtocolError, OSError) as err: raise ConnectionError(err, request=request) except MaxRetryError as e: @@ -527,6 +530,8 @@ class HTTPAdapter(BaseAdapter): raise SSLError(e, request=request) elif isinstance(e, ReadTimeoutError): raise ReadTimeout(e, request=request) + elif isinstance(e, _InvalidHeader): + raise InvalidHeader(e, request=request) else: raise diff --git a/env/Lib/site-packages/pip/_vendor/requests/api.py b/env/Lib/site-packages/pip/_vendor/requests/api.py index e978e203..cd0b3eea 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/api.py +++ b/env/Lib/site-packages/pip/_vendor/requests/api.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.api ~~~~~~~~~~~~ @@ -72,8 +70,7 @@ def get(url, params=None, **kwargs): :rtype: requests.Response """ - kwargs.setdefault('allow_redirects', True) - return request('get', url, params=params, **kwargs) + return request("get", url, params=params, **kwargs) def options(url, **kwargs): @@ -85,8 +82,7 @@ def options(url, **kwargs): :rtype: requests.Response """ - kwargs.setdefault('allow_redirects', True) - return request('options', url, **kwargs) + return request("options", url, **kwargs) def head(url, **kwargs): @@ -100,8 +96,8 @@ def head(url, **kwargs): :rtype: requests.Response """ - kwargs.setdefault('allow_redirects', False) - return request('head', url, **kwargs) + kwargs.setdefault("allow_redirects", False) + return request("head", url, **kwargs) def post(url, data=None, json=None, **kwargs): @@ -110,13 +106,13 @@ def post(url, data=None, json=None, **kwargs): :param url: URL for the new :class:`Request` object. :param data: (optional) Dictionary, list of tuples, bytes, or file-like object to send in the body of the :class:`Request`. - :param json: (optional) json data to send in the body of the :class:`Request`. + :param json: (optional) A JSON serializable Python object to send in the body of the :class:`Request`. :param \*\*kwargs: Optional arguments that ``request`` takes. :return: :class:`Response <Response>` object :rtype: requests.Response """ - return request('post', url, data=data, json=json, **kwargs) + return request("post", url, data=data, json=json, **kwargs) def put(url, data=None, **kwargs): @@ -125,13 +121,13 @@ def put(url, data=None, **kwargs): :param url: URL for the new :class:`Request` object. :param data: (optional) Dictionary, list of tuples, bytes, or file-like object to send in the body of the :class:`Request`. - :param json: (optional) json data to send in the body of the :class:`Request`. + :param json: (optional) A JSON serializable Python object to send in the body of the :class:`Request`. :param \*\*kwargs: Optional arguments that ``request`` takes. :return: :class:`Response <Response>` object :rtype: requests.Response """ - return request('put', url, data=data, **kwargs) + return request("put", url, data=data, **kwargs) def patch(url, data=None, **kwargs): @@ -140,13 +136,13 @@ def patch(url, data=None, **kwargs): :param url: URL for the new :class:`Request` object. :param data: (optional) Dictionary, list of tuples, bytes, or file-like object to send in the body of the :class:`Request`. - :param json: (optional) json data to send in the body of the :class:`Request`. + :param json: (optional) A JSON serializable Python object to send in the body of the :class:`Request`. :param \*\*kwargs: Optional arguments that ``request`` takes. :return: :class:`Response <Response>` object :rtype: requests.Response """ - return request('patch', url, data=data, **kwargs) + return request("patch", url, data=data, **kwargs) def delete(url, **kwargs): @@ -158,4 +154,4 @@ def delete(url, **kwargs): :rtype: requests.Response """ - return request('delete', url, **kwargs) + return request("delete", url, **kwargs) diff --git a/env/Lib/site-packages/pip/_vendor/requests/auth.py b/env/Lib/site-packages/pip/_vendor/requests/auth.py index eeface39..9733686d 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/auth.py +++ b/env/Lib/site-packages/pip/_vendor/requests/auth.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.auth ~~~~~~~~~~~~~ @@ -7,22 +5,21 @@ requests.auth This module contains the authentication handlers for Requests. """ +import hashlib import os import re -import time -import hashlib import threading +import time import warnings - from base64 import b64encode -from .compat import urlparse, str, basestring -from .cookies import extract_cookies_to_jar from ._internal_utils import to_native_string +from .compat import basestring, str, urlparse +from .cookies import extract_cookies_to_jar from .utils import parse_dict_header -CONTENT_TYPE_FORM_URLENCODED = 'application/x-www-form-urlencoded' -CONTENT_TYPE_MULTI_PART = 'multipart/form-data' +CONTENT_TYPE_FORM_URLENCODED = "application/x-www-form-urlencoded" +CONTENT_TYPE_MULTI_PART = "multipart/form-data" def _basic_auth_str(username, password): @@ -57,23 +54,23 @@ def _basic_auth_str(username, password): # -- End Removal -- if isinstance(username, str): - username = username.encode('latin1') + username = username.encode("latin1") if isinstance(password, str): - password = password.encode('latin1') + password = password.encode("latin1") - authstr = 'Basic ' + to_native_string( - b64encode(b':'.join((username, password))).strip() + authstr = "Basic " + to_native_string( + b64encode(b":".join((username, password))).strip() ) return authstr -class AuthBase(object): +class AuthBase: """Base class that all auth implementations derive from""" def __call__(self, r): - raise NotImplementedError('Auth hooks must be callable.') + raise NotImplementedError("Auth hooks must be callable.") class HTTPBasicAuth(AuthBase): @@ -84,16 +81,18 @@ class HTTPBasicAuth(AuthBase): self.password = password def __eq__(self, other): - return all([ - self.username == getattr(other, 'username', None), - self.password == getattr(other, 'password', None) - ]) + return all( + [ + self.username == getattr(other, "username", None), + self.password == getattr(other, "password", None), + ] + ) def __ne__(self, other): return not self == other def __call__(self, r): - r.headers['Authorization'] = _basic_auth_str(self.username, self.password) + r.headers["Authorization"] = _basic_auth_str(self.username, self.password) return r @@ -101,7 +100,7 @@ class HTTPProxyAuth(HTTPBasicAuth): """Attaches HTTP Proxy Authentication to a given Request object.""" def __call__(self, r): - r.headers['Proxy-Authorization'] = _basic_auth_str(self.username, self.password) + r.headers["Proxy-Authorization"] = _basic_auth_str(self.username, self.password) return r @@ -116,9 +115,9 @@ class HTTPDigestAuth(AuthBase): def init_per_thread_state(self): # Ensure state is initialized just once per-thread - if not hasattr(self._thread_local, 'init'): + if not hasattr(self._thread_local, "init"): self._thread_local.init = True - self._thread_local.last_nonce = '' + self._thread_local.last_nonce = "" self._thread_local.nonce_count = 0 self._thread_local.chal = {} self._thread_local.pos = None @@ -129,44 +128,52 @@ class HTTPDigestAuth(AuthBase): :rtype: str """ - realm = self._thread_local.chal['realm'] - nonce = self._thread_local.chal['nonce'] - qop = self._thread_local.chal.get('qop') - algorithm = self._thread_local.chal.get('algorithm') - opaque = self._thread_local.chal.get('opaque') + realm = self._thread_local.chal["realm"] + nonce = self._thread_local.chal["nonce"] + qop = self._thread_local.chal.get("qop") + algorithm = self._thread_local.chal.get("algorithm") + opaque = self._thread_local.chal.get("opaque") hash_utf8 = None if algorithm is None: - _algorithm = 'MD5' + _algorithm = "MD5" else: _algorithm = algorithm.upper() # lambdas assume digest modules are imported at the top level - if _algorithm == 'MD5' or _algorithm == 'MD5-SESS': + if _algorithm == "MD5" or _algorithm == "MD5-SESS": + def md5_utf8(x): if isinstance(x, str): - x = x.encode('utf-8') + x = x.encode("utf-8") return hashlib.md5(x).hexdigest() + hash_utf8 = md5_utf8 - elif _algorithm == 'SHA': + elif _algorithm == "SHA": + def sha_utf8(x): if isinstance(x, str): - x = x.encode('utf-8') + x = x.encode("utf-8") return hashlib.sha1(x).hexdigest() + hash_utf8 = sha_utf8 - elif _algorithm == 'SHA-256': + elif _algorithm == "SHA-256": + def sha256_utf8(x): if isinstance(x, str): - x = x.encode('utf-8') + x = x.encode("utf-8") return hashlib.sha256(x).hexdigest() + hash_utf8 = sha256_utf8 - elif _algorithm == 'SHA-512': + elif _algorithm == "SHA-512": + def sha512_utf8(x): if isinstance(x, str): - x = x.encode('utf-8') + x = x.encode("utf-8") return hashlib.sha512(x).hexdigest() + hash_utf8 = sha512_utf8 - KD = lambda s, d: hash_utf8("%s:%s" % (s, d)) + KD = lambda s, d: hash_utf8(f"{s}:{d}") # noqa:E731 if hash_utf8 is None: return None @@ -177,10 +184,10 @@ class HTTPDigestAuth(AuthBase): #: path is request-uri defined in RFC 2616 which should not be empty path = p_parsed.path or "/" if p_parsed.query: - path += '?' + p_parsed.query + path += f"?{p_parsed.query}" - A1 = '%s:%s:%s' % (self.username, realm, self.password) - A2 = '%s:%s' % (method, path) + A1 = f"{self.username}:{realm}:{self.password}" + A2 = f"{method}:{path}" HA1 = hash_utf8(A1) HA2 = hash_utf8(A2) @@ -189,22 +196,20 @@ class HTTPDigestAuth(AuthBase): self._thread_local.nonce_count += 1 else: self._thread_local.nonce_count = 1 - ncvalue = '%08x' % self._thread_local.nonce_count - s = str(self._thread_local.nonce_count).encode('utf-8') - s += nonce.encode('utf-8') - s += time.ctime().encode('utf-8') + ncvalue = f"{self._thread_local.nonce_count:08x}" + s = str(self._thread_local.nonce_count).encode("utf-8") + s += nonce.encode("utf-8") + s += time.ctime().encode("utf-8") s += os.urandom(8) - cnonce = (hashlib.sha1(s).hexdigest()[:16]) - if _algorithm == 'MD5-SESS': - HA1 = hash_utf8('%s:%s:%s' % (HA1, nonce, cnonce)) + cnonce = hashlib.sha1(s).hexdigest()[:16] + if _algorithm == "MD5-SESS": + HA1 = hash_utf8(f"{HA1}:{nonce}:{cnonce}") if not qop: - respdig = KD(HA1, "%s:%s" % (nonce, HA2)) - elif qop == 'auth' or 'auth' in qop.split(','): - noncebit = "%s:%s:%s:%s:%s" % ( - nonce, ncvalue, cnonce, 'auth', HA2 - ) + respdig = KD(HA1, f"{nonce}:{HA2}") + elif qop == "auth" or "auth" in qop.split(","): + noncebit = f"{nonce}:{ncvalue}:{cnonce}:auth:{HA2}" respdig = KD(HA1, noncebit) else: # XXX handle auth-int. @@ -213,18 +218,20 @@ class HTTPDigestAuth(AuthBase): self._thread_local.last_nonce = nonce # XXX should the partial digests be encoded too? - base = 'username="%s", realm="%s", nonce="%s", uri="%s", ' \ - 'response="%s"' % (self.username, realm, nonce, path, respdig) + base = ( + f'username="{self.username}", realm="{realm}", nonce="{nonce}", ' + f'uri="{path}", response="{respdig}"' + ) if opaque: - base += ', opaque="%s"' % opaque + base += f', opaque="{opaque}"' if algorithm: - base += ', algorithm="%s"' % algorithm + base += f', algorithm="{algorithm}"' if entdig: - base += ', digest="%s"' % entdig + base += f', digest="{entdig}"' if qop: - base += ', qop="auth", nc=%s, cnonce="%s"' % (ncvalue, cnonce) + base += f', qop="auth", nc={ncvalue}, cnonce="{cnonce}"' - return 'Digest %s' % (base) + return f"Digest {base}" def handle_redirect(self, r, **kwargs): """Reset num_401_calls counter on redirects.""" @@ -248,13 +255,13 @@ class HTTPDigestAuth(AuthBase): # Rewind the file position indicator of the body to where # it was to resend the request. r.request.body.seek(self._thread_local.pos) - s_auth = r.headers.get('www-authenticate', '') + s_auth = r.headers.get("www-authenticate", "") - if 'digest' in s_auth.lower() and self._thread_local.num_401_calls < 2: + if "digest" in s_auth.lower() and self._thread_local.num_401_calls < 2: self._thread_local.num_401_calls += 1 - pat = re.compile(r'digest ', flags=re.IGNORECASE) - self._thread_local.chal = parse_dict_header(pat.sub('', s_auth, count=1)) + pat = re.compile(r"digest ", flags=re.IGNORECASE) + self._thread_local.chal = parse_dict_header(pat.sub("", s_auth, count=1)) # Consume content and release the original connection # to allow our new request to reuse the same one. @@ -264,8 +271,9 @@ class HTTPDigestAuth(AuthBase): extract_cookies_to_jar(prep._cookies, r.request, r.raw) prep.prepare_cookies(prep._cookies) - prep.headers['Authorization'] = self.build_digest_header( - prep.method, prep.url) + prep.headers["Authorization"] = self.build_digest_header( + prep.method, prep.url + ) _r = r.connection.send(prep, **kwargs) _r.history.append(r) _r.request = prep @@ -280,7 +288,7 @@ class HTTPDigestAuth(AuthBase): self.init_per_thread_state() # If we have a saved nonce, skip the 401 if self._thread_local.last_nonce: - r.headers['Authorization'] = self.build_digest_header(r.method, r.url) + r.headers["Authorization"] = self.build_digest_header(r.method, r.url) try: self._thread_local.pos = r.body.tell() except AttributeError: @@ -289,17 +297,19 @@ class HTTPDigestAuth(AuthBase): # file position of the previous body. Ensure it's set to # None. self._thread_local.pos = None - r.register_hook('response', self.handle_401) - r.register_hook('response', self.handle_redirect) + r.register_hook("response", self.handle_401) + r.register_hook("response", self.handle_redirect) self._thread_local.num_401_calls = 1 return r def __eq__(self, other): - return all([ - self.username == getattr(other, 'username', None), - self.password == getattr(other, 'password', None) - ]) + return all( + [ + self.username == getattr(other, "username", None), + self.password == getattr(other, "password", None), + ] + ) def __ne__(self, other): return not self == other diff --git a/env/Lib/site-packages/pip/_vendor/requests/certs.py b/env/Lib/site-packages/pip/_vendor/requests/certs.py index 06a594e5..38696a1f 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/certs.py +++ b/env/Lib/site-packages/pip/_vendor/requests/certs.py @@ -1,5 +1,4 @@ #!/usr/bin/env python -# -*- coding: utf-8 -*- """ requests.certs @@ -12,7 +11,14 @@ If you are packaging Requests, e.g., for a Linux distribution or a managed environment, you can change the definition of where() to return a separately packaged CA bundle. """ -from pip._vendor.certifi import where -if __name__ == '__main__': +import os + +if "_PIP_STANDALONE_CERT" not in os.environ: + from pip._vendor.certifi import where +else: + def where(): + return os.environ["_PIP_STANDALONE_CERT"] + +if __name__ == "__main__": print(where()) diff --git a/env/Lib/site-packages/pip/_vendor/requests/compat.py b/env/Lib/site-packages/pip/_vendor/requests/compat.py index 9e293716..9ab2bb48 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/compat.py +++ b/env/Lib/site-packages/pip/_vendor/requests/compat.py @@ -1,11 +1,10 @@ -# -*- coding: utf-8 -*- - """ requests.compat ~~~~~~~~~~~~~~~ -This module handles import compatibility issues between Python 2 and -Python 3. +This module previously handled import compatibility issues +between Python 2 and Python 3. It remains for backwards +compatibility until the next major version. """ from pip._vendor import chardet @@ -20,57 +19,49 @@ import sys _ver = sys.version_info #: Python 2.x? -is_py2 = (_ver[0] == 2) +is_py2 = _ver[0] == 2 #: Python 3.x? -is_py3 = (_ver[0] == 3) +is_py3 = _ver[0] == 3 # Note: We've patched out simplejson support in pip because it prevents # upgrading simplejson on Windows. -# try: -# import simplejson as json -# except (ImportError, SyntaxError): -# # simplejson does not support Python 3.2, it throws a SyntaxError -# # because of u'...' Unicode literals. import json +from json import JSONDecodeError -# --------- -# Specifics -# --------- - -if is_py2: - from urllib import ( - quote, unquote, quote_plus, unquote_plus, urlencode, getproxies, - proxy_bypass, proxy_bypass_environment, getproxies_environment) - from urlparse import urlparse, urlunparse, urljoin, urlsplit, urldefrag - from urllib2 import parse_http_list - import cookielib - from Cookie import Morsel - from StringIO import StringIO - # Keep OrderedDict for backwards compatibility. - from collections import Callable, Mapping, MutableMapping, OrderedDict - - - builtin_str = str - bytes = str - str = unicode - basestring = basestring - numeric_types = (int, long, float) - integer_types = (int, long) +# Keep OrderedDict for backwards compatibility. +from collections import OrderedDict +from collections.abc import Callable, Mapping, MutableMapping +from http import cookiejar as cookielib +from http.cookies import Morsel +from io import StringIO -elif is_py3: - from urllib.parse import urlparse, urlunparse, urljoin, urlsplit, urlencode, quote, unquote, quote_plus, unquote_plus, urldefrag - from urllib.request import parse_http_list, getproxies, proxy_bypass, proxy_bypass_environment, getproxies_environment - from http import cookiejar as cookielib - from http.cookies import Morsel - from io import StringIO - # Keep OrderedDict for backwards compatibility. - from collections import OrderedDict - from collections.abc import Callable, Mapping, MutableMapping +# -------------- +# Legacy Imports +# -------------- +from urllib.parse import ( + quote, + quote_plus, + unquote, + unquote_plus, + urldefrag, + urlencode, + urljoin, + urlparse, + urlsplit, + urlunparse, +) +from urllib.request import ( + getproxies, + getproxies_environment, + parse_http_list, + proxy_bypass, + proxy_bypass_environment, +) - builtin_str = str - str = str - bytes = bytes - basestring = (str, bytes) - numeric_types = (int, float) - integer_types = (int,) +builtin_str = str +str = str +bytes = bytes +basestring = (str, bytes) +numeric_types = (int, float) +integer_types = (int,) diff --git a/env/Lib/site-packages/pip/_vendor/requests/cookies.py b/env/Lib/site-packages/pip/_vendor/requests/cookies.py index 56fccd9c..bf54ab23 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/cookies.py +++ b/env/Lib/site-packages/pip/_vendor/requests/cookies.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.cookies ~~~~~~~~~~~~~~~~ @@ -9,12 +7,12 @@ Compatibility code to be able to use `cookielib.CookieJar` with requests. requests.utils imports from here, so be careful with imports. """ +import calendar import copy import time -import calendar from ._internal_utils import to_native_string -from .compat import cookielib, urlparse, urlunparse, Morsel, MutableMapping +from .compat import Morsel, MutableMapping, cookielib, urlparse, urlunparse try: import threading @@ -22,7 +20,7 @@ except ImportError: import dummy_threading as threading -class MockRequest(object): +class MockRequest: """Wraps a `requests.Request` to mimic a `urllib2.Request`. The code in `cookielib.CookieJar` expects this interface in order to correctly @@ -51,16 +49,22 @@ class MockRequest(object): def get_full_url(self): # Only return the response's URL if the user hadn't set the Host # header - if not self._r.headers.get('Host'): + if not self._r.headers.get("Host"): return self._r.url # If they did set it, retrieve it and reconstruct the expected domain - host = to_native_string(self._r.headers['Host'], encoding='utf-8') + host = to_native_string(self._r.headers["Host"], encoding="utf-8") parsed = urlparse(self._r.url) # Reconstruct the URL as we expect it - return urlunparse([ - parsed.scheme, host, parsed.path, parsed.params, parsed.query, - parsed.fragment - ]) + return urlunparse( + [ + parsed.scheme, + host, + parsed.path, + parsed.params, + parsed.query, + parsed.fragment, + ] + ) def is_unverifiable(self): return True @@ -73,7 +77,9 @@ class MockRequest(object): def add_header(self, key, val): """cookielib has no legitimate use for this method; add it back if you find one.""" - raise NotImplementedError("Cookie headers should be added with add_unredirected_header()") + raise NotImplementedError( + "Cookie headers should be added with add_unredirected_header()" + ) def add_unredirected_header(self, name, value): self._new_headers[name] = value @@ -94,7 +100,7 @@ class MockRequest(object): return self.get_host() -class MockResponse(object): +class MockResponse: """Wraps a `httplib.HTTPMessage` to mimic a `urllib.addinfourl`. ...what? Basically, expose the parsed HTTP headers from the server response @@ -122,8 +128,7 @@ def extract_cookies_to_jar(jar, request, response): :param request: our own requests.Request object :param response: urllib3.HTTPResponse object """ - if not (hasattr(response, '_original_response') and - response._original_response): + if not (hasattr(response, "_original_response") and response._original_response): return # the _original_response field is the wrapped httplib.HTTPResponse object, req = MockRequest(request) @@ -140,7 +145,7 @@ def get_cookie_header(jar, request): """ r = MockRequest(request) jar.add_cookie_header(r) - return r.get_new_headers().get('Cookie') + return r.get_new_headers().get("Cookie") def remove_cookie_by_name(cookiejar, name, domain=None, path=None): @@ -205,7 +210,9 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping): """ # support client code that unsets cookies by assignment of a None value: if value is None: - remove_cookie_by_name(self, name, domain=kwargs.get('domain'), path=kwargs.get('path')) + remove_cookie_by_name( + self, name, domain=kwargs.get("domain"), path=kwargs.get("path") + ) return if isinstance(value, Morsel): @@ -305,16 +312,15 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping): """ dictionary = {} for cookie in iter(self): - if ( - (domain is None or cookie.domain == domain) and - (path is None or cookie.path == path) + if (domain is None or cookie.domain == domain) and ( + path is None or cookie.path == path ): dictionary[cookie.name] = cookie.value return dictionary def __contains__(self, name): try: - return super(RequestsCookieJar, self).__contains__(name) + return super().__contains__(name) except CookieConflictError: return True @@ -341,9 +347,13 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping): remove_cookie_by_name(self, name) def set_cookie(self, cookie, *args, **kwargs): - if hasattr(cookie.value, 'startswith') and cookie.value.startswith('"') and cookie.value.endswith('"'): - cookie.value = cookie.value.replace('\\"', '') - return super(RequestsCookieJar, self).set_cookie(cookie, *args, **kwargs) + if ( + hasattr(cookie.value, "startswith") + and cookie.value.startswith('"') + and cookie.value.endswith('"') + ): + cookie.value = cookie.value.replace('\\"', "") + return super().set_cookie(cookie, *args, **kwargs) def update(self, other): """Updates this jar with cookies from another CookieJar or dict-like""" @@ -351,7 +361,7 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping): for cookie in other: self.set_cookie(copy.copy(cookie)) else: - super(RequestsCookieJar, self).update(other) + super().update(other) def _find(self, name, domain=None, path=None): """Requests uses this method internally to get cookie values. @@ -371,7 +381,7 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping): if path is None or cookie.path == path: return cookie.value - raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path)) + raise KeyError(f"name={name!r}, domain={domain!r}, path={path!r}") def _find_no_duplicates(self, name, domain=None, path=None): """Both ``__get_item__`` and ``get`` call this function: it's never @@ -390,25 +400,29 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping): if cookie.name == name: if domain is None or cookie.domain == domain: if path is None or cookie.path == path: - if toReturn is not None: # if there are multiple cookies that meet passed in criteria - raise CookieConflictError('There are multiple cookies with name, %r' % (name)) - toReturn = cookie.value # we will eventually return this as long as no cookie conflict + if toReturn is not None: + # if there are multiple cookies that meet passed in criteria + raise CookieConflictError( + f"There are multiple cookies with name, {name!r}" + ) + # we will eventually return this as long as no cookie conflict + toReturn = cookie.value if toReturn: return toReturn - raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path)) + raise KeyError(f"name={name!r}, domain={domain!r}, path={path!r}") def __getstate__(self): """Unlike a normal CookieJar, this class is pickleable.""" state = self.__dict__.copy() # remove the unpickleable RLock object - state.pop('_cookies_lock') + state.pop("_cookies_lock") return state def __setstate__(self, state): """Unlike a normal CookieJar, this class is pickleable.""" self.__dict__.update(state) - if '_cookies_lock' not in self.__dict__: + if "_cookies_lock" not in self.__dict__: self._cookies_lock = threading.RLock() def copy(self): @@ -427,7 +441,7 @@ def _copy_cookie_jar(jar): if jar is None: return None - if hasattr(jar, 'copy'): + if hasattr(jar, "copy"): # We're dealing with an instance of RequestsCookieJar return jar.copy() # We're dealing with a generic CookieJar instance @@ -445,31 +459,32 @@ def create_cookie(name, value, **kwargs): and sent on every request (this is sometimes called a "supercookie"). """ result = { - 'version': 0, - 'name': name, - 'value': value, - 'port': None, - 'domain': '', - 'path': '/', - 'secure': False, - 'expires': None, - 'discard': True, - 'comment': None, - 'comment_url': None, - 'rest': {'HttpOnly': None}, - 'rfc2109': False, + "version": 0, + "name": name, + "value": value, + "port": None, + "domain": "", + "path": "/", + "secure": False, + "expires": None, + "discard": True, + "comment": None, + "comment_url": None, + "rest": {"HttpOnly": None}, + "rfc2109": False, } badargs = set(kwargs) - set(result) if badargs: - err = 'create_cookie() got unexpected keyword arguments: %s' - raise TypeError(err % list(badargs)) + raise TypeError( + f"create_cookie() got unexpected keyword arguments: {list(badargs)}" + ) result.update(kwargs) - result['port_specified'] = bool(result['port']) - result['domain_specified'] = bool(result['domain']) - result['domain_initial_dot'] = result['domain'].startswith('.') - result['path_specified'] = bool(result['path']) + result["port_specified"] = bool(result["port"]) + result["domain_specified"] = bool(result["domain"]) + result["domain_initial_dot"] = result["domain"].startswith(".") + result["path_specified"] = bool(result["path"]) return cookielib.Cookie(**result) @@ -478,30 +493,28 @@ def morsel_to_cookie(morsel): """Convert a Morsel object into a Cookie containing the one k/v pair.""" expires = None - if morsel['max-age']: + if morsel["max-age"]: try: - expires = int(time.time() + int(morsel['max-age'])) + expires = int(time.time() + int(morsel["max-age"])) except ValueError: - raise TypeError('max-age: %s must be integer' % morsel['max-age']) - elif morsel['expires']: - time_template = '%a, %d-%b-%Y %H:%M:%S GMT' - expires = calendar.timegm( - time.strptime(morsel['expires'], time_template) - ) + raise TypeError(f"max-age: {morsel['max-age']} must be integer") + elif morsel["expires"]: + time_template = "%a, %d-%b-%Y %H:%M:%S GMT" + expires = calendar.timegm(time.strptime(morsel["expires"], time_template)) return create_cookie( - comment=morsel['comment'], - comment_url=bool(morsel['comment']), + comment=morsel["comment"], + comment_url=bool(morsel["comment"]), discard=False, - domain=morsel['domain'], + domain=morsel["domain"], expires=expires, name=morsel.key, - path=morsel['path'], + path=morsel["path"], port=None, - rest={'HttpOnly': morsel['httponly']}, + rest={"HttpOnly": morsel["httponly"]}, rfc2109=False, - secure=bool(morsel['secure']), + secure=bool(morsel["secure"]), value=morsel.value, - version=morsel['version'] or 0, + version=morsel["version"] or 0, ) @@ -534,11 +547,10 @@ def merge_cookies(cookiejar, cookies): :rtype: CookieJar """ if not isinstance(cookiejar, cookielib.CookieJar): - raise ValueError('You can only merge into CookieJar') + raise ValueError("You can only merge into CookieJar") if isinstance(cookies, dict): - cookiejar = cookiejar_from_dict( - cookies, cookiejar=cookiejar, overwrite=False) + cookiejar = cookiejar_from_dict(cookies, cookiejar=cookiejar, overwrite=False) elif isinstance(cookies, cookielib.CookieJar): try: cookiejar.update(cookies) diff --git a/env/Lib/site-packages/pip/_vendor/requests/exceptions.py b/env/Lib/site-packages/pip/_vendor/requests/exceptions.py index 9ef9e6e9..168d0739 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/exceptions.py +++ b/env/Lib/site-packages/pip/_vendor/requests/exceptions.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.exceptions ~~~~~~~~~~~~~~~~~~~ @@ -8,6 +6,8 @@ This module contains the set of Requests' exceptions. """ from pip._vendor.urllib3.exceptions import HTTPError as BaseHTTPError +from .compat import JSONDecodeError as CompatJSONDecodeError + class RequestException(IOError): """There was an ambiguous exception that occurred while handling your @@ -16,13 +16,30 @@ class RequestException(IOError): def __init__(self, *args, **kwargs): """Initialize RequestException with `request` and `response` objects.""" - response = kwargs.pop('response', None) + response = kwargs.pop("response", None) self.response = response - self.request = kwargs.pop('request', None) - if (response is not None and not self.request and - hasattr(response, 'request')): + self.request = kwargs.pop("request", None) + if response is not None and not self.request and hasattr(response, "request"): self.request = self.response.request - super(RequestException, self).__init__(*args, **kwargs) + super().__init__(*args, **kwargs) + + +class InvalidJSONError(RequestException): + """A JSON error occurred.""" + + +class JSONDecodeError(InvalidJSONError, CompatJSONDecodeError): + """Couldn't decode the text into json""" + + def __init__(self, *args, **kwargs): + """ + Construct the JSONDecodeError instance first with all + args. Then use it's args to construct the IOError so that + the json specific args aren't used as IOError specific args + and the error message from JSONDecodeError is preserved. + """ + CompatJSONDecodeError.__init__(self, *args) + InvalidJSONError.__init__(self, *self.args, **kwargs) class HTTPError(RequestException): @@ -70,11 +87,11 @@ class TooManyRedirects(RequestException): class MissingSchema(RequestException, ValueError): - """The URL schema (e.g. http or https) is missing.""" + """The URL scheme (e.g. http or https) is missing.""" class InvalidSchema(RequestException, ValueError): - """See defaults.py for valid schemas.""" + """The URL scheme provided is either invalid or unsupported.""" class InvalidURL(RequestException, ValueError): @@ -108,6 +125,7 @@ class RetryError(RequestException): class UnrewindableBodyError(RequestException): """Requests encountered an error when trying to rewind a body.""" + # Warnings diff --git a/env/Lib/site-packages/pip/_vendor/requests/help.py b/env/Lib/site-packages/pip/_vendor/requests/help.py index 3c3072ba..2d292c2f 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/help.py +++ b/env/Lib/site-packages/pip/_vendor/requests/help.py @@ -1,17 +1,22 @@ """Module containing bug report helper(s).""" -from __future__ import print_function import json import platform -import sys import ssl +import sys from pip._vendor import idna from pip._vendor import urllib3 -from pip._vendor import chardet from . import __version__ as requests_version +charset_normalizer = None + +try: + from pip._vendor import chardet +except ImportError: + chardet = None + try: from pip._vendor.urllib3.contrib import pyopenssl except ImportError: @@ -19,16 +24,16 @@ except ImportError: OpenSSL = None cryptography = None else: - import OpenSSL import cryptography + import OpenSSL def _implementation(): """Return a dict with the Python implementation and version. Provide both the name and the version of the Python implementation - currently running. For example, on CPython 2.7.5 it will return - {'name': 'CPython', 'version': '2.7.5'}. + currently running. For example, on CPython 3.10.3 it will return + {'name': 'CPython', 'version': '3.10.3'}. This function works best on CPython and PyPy: in particular, it probably doesn't work for Jython or IronPython. Future investigation should be done @@ -36,76 +41,83 @@ def _implementation(): """ implementation = platform.python_implementation() - if implementation == 'CPython': + if implementation == "CPython": implementation_version = platform.python_version() - elif implementation == 'PyPy': - implementation_version = '%s.%s.%s' % (sys.pypy_version_info.major, - sys.pypy_version_info.minor, - sys.pypy_version_info.micro) - if sys.pypy_version_info.releaselevel != 'final': - implementation_version = ''.join([ - implementation_version, sys.pypy_version_info.releaselevel - ]) - elif implementation == 'Jython': + elif implementation == "PyPy": + implementation_version = "{}.{}.{}".format( + sys.pypy_version_info.major, + sys.pypy_version_info.minor, + sys.pypy_version_info.micro, + ) + if sys.pypy_version_info.releaselevel != "final": + implementation_version = "".join( + [implementation_version, sys.pypy_version_info.releaselevel] + ) + elif implementation == "Jython": implementation_version = platform.python_version() # Complete Guess - elif implementation == 'IronPython': + elif implementation == "IronPython": implementation_version = platform.python_version() # Complete Guess else: - implementation_version = 'Unknown' + implementation_version = "Unknown" - return {'name': implementation, 'version': implementation_version} + return {"name": implementation, "version": implementation_version} def info(): """Generate information for a bug report.""" try: platform_info = { - 'system': platform.system(), - 'release': platform.release(), + "system": platform.system(), + "release": platform.release(), } - except IOError: + except OSError: platform_info = { - 'system': 'Unknown', - 'release': 'Unknown', + "system": "Unknown", + "release": "Unknown", } implementation_info = _implementation() - urllib3_info = {'version': urllib3.__version__} - chardet_info = {'version': chardet.__version__} + urllib3_info = {"version": urllib3.__version__} + charset_normalizer_info = {"version": None} + chardet_info = {"version": None} + if charset_normalizer: + charset_normalizer_info = {"version": charset_normalizer.__version__} + if chardet: + chardet_info = {"version": chardet.__version__} pyopenssl_info = { - 'version': None, - 'openssl_version': '', + "version": None, + "openssl_version": "", } if OpenSSL: pyopenssl_info = { - 'version': OpenSSL.__version__, - 'openssl_version': '%x' % OpenSSL.SSL.OPENSSL_VERSION_NUMBER, + "version": OpenSSL.__version__, + "openssl_version": f"{OpenSSL.SSL.OPENSSL_VERSION_NUMBER:x}", } cryptography_info = { - 'version': getattr(cryptography, '__version__', ''), + "version": getattr(cryptography, "__version__", ""), } idna_info = { - 'version': getattr(idna, '__version__', ''), + "version": getattr(idna, "__version__", ""), } system_ssl = ssl.OPENSSL_VERSION_NUMBER - system_ssl_info = { - 'version': '%x' % system_ssl if system_ssl is not None else '' - } + system_ssl_info = {"version": f"{system_ssl:x}" if system_ssl is not None else ""} return { - 'platform': platform_info, - 'implementation': implementation_info, - 'system_ssl': system_ssl_info, - 'using_pyopenssl': pyopenssl is not None, - 'pyOpenSSL': pyopenssl_info, - 'urllib3': urllib3_info, - 'chardet': chardet_info, - 'cryptography': cryptography_info, - 'idna': idna_info, - 'requests': { - 'version': requests_version, + "platform": platform_info, + "implementation": implementation_info, + "system_ssl": system_ssl_info, + "using_pyopenssl": pyopenssl is not None, + "using_charset_normalizer": chardet is None, + "pyOpenSSL": pyopenssl_info, + "urllib3": urllib3_info, + "chardet": chardet_info, + "charset_normalizer": charset_normalizer_info, + "cryptography": cryptography_info, + "idna": idna_info, + "requests": { + "version": requests_version, }, } @@ -115,5 +127,5 @@ def main(): print(json.dumps(info(), sort_keys=True, indent=2)) -if __name__ == '__main__': +if __name__ == "__main__": main() diff --git a/env/Lib/site-packages/pip/_vendor/requests/hooks.py b/env/Lib/site-packages/pip/_vendor/requests/hooks.py index 7a51f212..d181ba2e 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/hooks.py +++ b/env/Lib/site-packages/pip/_vendor/requests/hooks.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.hooks ~~~~~~~~~~~~~~ @@ -11,12 +9,13 @@ Available hooks: ``response``: The response generated from a Request. """ -HOOKS = ['response'] +HOOKS = ["response"] def default_hooks(): return {event: [] for event in HOOKS} + # TODO: response is the only one @@ -25,7 +24,7 @@ def dispatch_hook(key, hooks, hook_data, **kwargs): hooks = hooks or {} hooks = hooks.get(key) if hooks: - if hasattr(hooks, '__call__'): + if hasattr(hooks, "__call__"): hooks = [hooks] for hook in hooks: _hook_data = hook(hook_data, **kwargs) diff --git a/env/Lib/site-packages/pip/_vendor/requests/models.py b/env/Lib/site-packages/pip/_vendor/requests/models.py index b0ce2950..76e6f199 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/models.py +++ b/env/Lib/site-packages/pip/_vendor/requests/models.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.models ~~~~~~~~~~~~~~~ @@ -8,46 +6,72 @@ This module contains the primary objects that power Requests. """ import datetime -import sys # Import encoding now, to avoid implicit import later. # Implicit import within threads may cause LookupError when standard library is in a ZIP, # such as in Embedded Python. See https://github.com/psf/requests/issues/3578. -import encodings.idna +import encodings.idna # noqa: F401 +from io import UnsupportedOperation +from pip._vendor.urllib3.exceptions import ( + DecodeError, + LocationParseError, + ProtocolError, + ReadTimeoutError, + SSLError, +) from pip._vendor.urllib3.fields import RequestField from pip._vendor.urllib3.filepost import encode_multipart_formdata from pip._vendor.urllib3.util import parse_url -from pip._vendor.urllib3.exceptions import ( - DecodeError, ReadTimeoutError, ProtocolError, LocationParseError) -from io import UnsupportedOperation -from .hooks import default_hooks -from .structures import CaseInsensitiveDict - -from .auth import HTTPBasicAuth -from .cookies import cookiejar_from_dict, get_cookie_header, _copy_cookie_jar -from .exceptions import ( - HTTPError, MissingSchema, InvalidURL, ChunkedEncodingError, - ContentDecodingError, ConnectionError, StreamConsumedError) from ._internal_utils import to_native_string, unicode_is_ascii -from .utils import ( - guess_filename, get_auth_from_url, requote_uri, - stream_decode_response_unicode, to_key_val_list, parse_header_links, - iter_slices, guess_json_utf, super_len, check_header_validity) +from .auth import HTTPBasicAuth from .compat import ( - Callable, Mapping, - cookielib, urlunparse, urlsplit, urlencode, str, bytes, - is_py2, chardet, builtin_str, basestring) + Callable, + JSONDecodeError, + Mapping, + basestring, + builtin_str, + chardet, + cookielib, +) from .compat import json as complexjson +from .compat import urlencode, urlsplit, urlunparse +from .cookies import _copy_cookie_jar, cookiejar_from_dict, get_cookie_header +from .exceptions import ( + ChunkedEncodingError, + ConnectionError, + ContentDecodingError, + HTTPError, + InvalidJSONError, + InvalidURL, +) +from .exceptions import JSONDecodeError as RequestsJSONDecodeError +from .exceptions import MissingSchema +from .exceptions import SSLError as RequestsSSLError +from .exceptions import StreamConsumedError +from .hooks import default_hooks from .status_codes import codes +from .structures import CaseInsensitiveDict +from .utils import ( + check_header_validity, + get_auth_from_url, + guess_filename, + guess_json_utf, + iter_slices, + parse_header_links, + requote_uri, + stream_decode_response_unicode, + super_len, + to_key_val_list, +) #: The set of HTTP status codes that indicate an automatically #: processable redirect. REDIRECT_STATI = ( - codes.moved, # 301 - codes.found, # 302 - codes.other, # 303 + codes.moved, # 301 + codes.found, # 302 + codes.other, # 303 codes.temporary_redirect, # 307 codes.permanent_redirect, # 308 ) @@ -57,7 +81,7 @@ CONTENT_CHUNK_SIZE = 10 * 1024 ITER_CHUNK_SIZE = 512 -class RequestEncodingMixin(object): +class RequestEncodingMixin: @property def path_url(self): """Build the path URL to use.""" @@ -68,16 +92,16 @@ class RequestEncodingMixin(object): path = p.path if not path: - path = '/' + path = "/" url.append(path) query = p.query if query: - url.append('?') + url.append("?") url.append(query) - return ''.join(url) + return "".join(url) @staticmethod def _encode_params(data): @@ -90,18 +114,21 @@ class RequestEncodingMixin(object): if isinstance(data, (str, bytes)): return data - elif hasattr(data, 'read'): + elif hasattr(data, "read"): return data - elif hasattr(data, '__iter__'): + elif hasattr(data, "__iter__"): result = [] for k, vs in to_key_val_list(data): - if isinstance(vs, basestring) or not hasattr(vs, '__iter__'): + if isinstance(vs, basestring) or not hasattr(vs, "__iter__"): vs = [vs] for v in vs: if v is not None: result.append( - (k.encode('utf-8') if isinstance(k, str) else k, - v.encode('utf-8') if isinstance(v, str) else v)) + ( + k.encode("utf-8") if isinstance(k, str) else k, + v.encode("utf-8") if isinstance(v, str) else v, + ) + ) return urlencode(result, doseq=True) else: return data @@ -116,7 +143,7 @@ class RequestEncodingMixin(object): The tuples may be 2-tuples (filename, fileobj), 3-tuples (filename, fileobj, contentype) or 4-tuples (filename, fileobj, contentype, custom_headers). """ - if (not files): + if not files: raise ValueError("Files must be provided.") elif isinstance(data, basestring): raise ValueError("Data must not be a string.") @@ -126,7 +153,7 @@ class RequestEncodingMixin(object): files = to_key_val_list(files or {}) for field, val in fields: - if isinstance(val, basestring) or not hasattr(val, '__iter__'): + if isinstance(val, basestring) or not hasattr(val, "__iter__"): val = [val] for v in val: if v is not None: @@ -135,8 +162,13 @@ class RequestEncodingMixin(object): v = str(v) new_fields.append( - (field.decode('utf-8') if isinstance(field, bytes) else field, - v.encode('utf-8') if isinstance(v, str) else v)) + ( + field.decode("utf-8") + if isinstance(field, bytes) + else field, + v.encode("utf-8") if isinstance(v, str) else v, + ) + ) for (k, v) in files: # support for explicit filename @@ -155,7 +187,7 @@ class RequestEncodingMixin(object): if isinstance(fp, (str, bytes, bytearray)): fdata = fp - elif hasattr(fp, 'read'): + elif hasattr(fp, "read"): fdata = fp.read() elif fp is None: continue @@ -171,16 +203,16 @@ class RequestEncodingMixin(object): return body, content_type -class RequestHooksMixin(object): +class RequestHooksMixin: def register_hook(self, event, hook): """Properly register a hook.""" if event not in self.hooks: - raise ValueError('Unsupported event specified, with event name "%s"' % (event)) + raise ValueError(f'Unsupported event specified, with event name "{event}"') if isinstance(hook, Callable): self.hooks[event].append(hook) - elif hasattr(hook, '__iter__'): + elif hasattr(hook, "__iter__"): self.hooks[event].extend(h for h in hook if isinstance(h, Callable)) def deregister_hook(self, event, hook): @@ -223,9 +255,19 @@ class Request(RequestHooksMixin): <PreparedRequest [GET]> """ - def __init__(self, - method=None, url=None, headers=None, files=None, data=None, - params=None, auth=None, cookies=None, hooks=None, json=None): + def __init__( + self, + method=None, + url=None, + headers=None, + files=None, + data=None, + params=None, + auth=None, + cookies=None, + hooks=None, + json=None, + ): # Default empty dicts for dict params. data = [] if data is None else data @@ -249,7 +291,7 @@ class Request(RequestHooksMixin): self.cookies = cookies def __repr__(self): - return '<Request [%s]>' % (self.method) + return f"<Request [{self.method}]>" def prepare(self): """Constructs a :class:`PreparedRequest <PreparedRequest>` for transmission and returns it.""" @@ -307,9 +349,19 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): #: integer denoting starting position of a readable file-like body. self._body_position = None - def prepare(self, - method=None, url=None, headers=None, files=None, data=None, - params=None, auth=None, cookies=None, hooks=None, json=None): + def prepare( + self, + method=None, + url=None, + headers=None, + files=None, + data=None, + params=None, + auth=None, + cookies=None, + hooks=None, + json=None, + ): """Prepares the entire request with the given parameters.""" self.prepare_method(method) @@ -326,7 +378,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): self.prepare_hooks(hooks) def __repr__(self): - return '<PreparedRequest [%s]>' % (self.method) + return f"<PreparedRequest [{self.method}]>" def copy(self): p = PreparedRequest() @@ -350,7 +402,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): from pip._vendor import idna try: - host = idna.encode(host, uts46=True).decode('utf-8') + host = idna.encode(host, uts46=True).decode("utf-8") except idna.IDNAError: raise UnicodeError return host @@ -363,9 +415,9 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): #: on python 3.x. #: https://github.com/psf/requests/pull/2238 if isinstance(url, bytes): - url = url.decode('utf8') + url = url.decode("utf8") else: - url = unicode(url) if is_py2 else str(url) + url = str(url) # Remove leading whitespaces from url url = url.lstrip() @@ -373,7 +425,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): # Don't do any URL preparation for non-HTTP schemes like `mailto`, # `data` etc to work around exceptions from `url_parse`, which # handles RFC 3986 only. - if ':' in url and not url.lower().startswith('http'): + if ":" in url and not url.lower().startswith("http"): self.url = url return @@ -384,13 +436,13 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): raise InvalidURL(*e.args) if not scheme: - error = ("Invalid URL {0!r}: No schema supplied. Perhaps you meant http://{0}?") - error = error.format(to_native_string(url, 'utf8')) - - raise MissingSchema(error) + raise MissingSchema( + f"Invalid URL {url!r}: No scheme supplied. " + f"Perhaps you meant https://{url}?" + ) if not host: - raise InvalidURL("Invalid URL %r: No host supplied" % url) + raise InvalidURL(f"Invalid URL {url!r}: No host supplied") # In general, we want to try IDNA encoding the hostname if the string contains # non-ASCII characters. This allows users to automatically get the correct IDNA @@ -400,33 +452,21 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): try: host = self._get_idna_encoded_host(host) except UnicodeError: - raise InvalidURL('URL has an invalid label.') - elif host.startswith(u'*'): - raise InvalidURL('URL has an invalid label.') + raise InvalidURL("URL has an invalid label.") + elif host.startswith(("*", ".")): + raise InvalidURL("URL has an invalid label.") # Carefully reconstruct the network location - netloc = auth or '' + netloc = auth or "" if netloc: - netloc += '@' + netloc += "@" netloc += host if port: - netloc += ':' + str(port) + netloc += f":{port}" # Bare domains aren't valid URLs. if not path: - path = '/' - - if is_py2: - if isinstance(scheme, str): - scheme = scheme.encode('utf-8') - if isinstance(netloc, str): - netloc = netloc.encode('utf-8') - if isinstance(path, str): - path = path.encode('utf-8') - if isinstance(query, str): - query = query.encode('utf-8') - if isinstance(fragment, str): - fragment = fragment.encode('utf-8') + path = "/" if isinstance(params, (str, bytes)): params = to_native_string(params) @@ -434,7 +474,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): enc_params = self._encode_params(params) if enc_params: if query: - query = '%s&%s' % (query, enc_params) + query = f"{query}&{enc_params}" else: query = enc_params @@ -465,15 +505,22 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): if not data and json is not None: # urllib3 requires a bytes-like body. Python 2's json.dumps # provides this natively, but Python 3 gives a Unicode string. - content_type = 'application/json' - body = complexjson.dumps(json) + content_type = "application/json" + + try: + body = complexjson.dumps(json, allow_nan=False) + except ValueError as ve: + raise InvalidJSONError(ve, request=self) + if not isinstance(body, bytes): - body = body.encode('utf-8') + body = body.encode("utf-8") - is_stream = all([ - hasattr(data, '__iter__'), - not isinstance(data, (basestring, list, tuple, Mapping)) - ]) + is_stream = all( + [ + hasattr(data, "__iter__"), + not isinstance(data, (basestring, list, tuple, Mapping)), + ] + ) if is_stream: try: @@ -483,24 +530,26 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): body = data - if getattr(body, 'tell', None) is not None: + if getattr(body, "tell", None) is not None: # Record the current file position before reading. # This will allow us to rewind a file in the event # of a redirect. try: self._body_position = body.tell() - except (IOError, OSError): + except OSError: # This differentiates from None, allowing us to catch # a failed `tell()` later when trying to rewind the body self._body_position = object() if files: - raise NotImplementedError('Streamed bodies and files are mutually exclusive.') + raise NotImplementedError( + "Streamed bodies and files are mutually exclusive." + ) if length: - self.headers['Content-Length'] = builtin_str(length) + self.headers["Content-Length"] = builtin_str(length) else: - self.headers['Transfer-Encoding'] = 'chunked' + self.headers["Transfer-Encoding"] = "chunked" else: # Multi-part file uploads. if files: @@ -508,16 +557,16 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): else: if data: body = self._encode_params(data) - if isinstance(data, basestring) or hasattr(data, 'read'): + if isinstance(data, basestring) or hasattr(data, "read"): content_type = None else: - content_type = 'application/x-www-form-urlencoded' + content_type = "application/x-www-form-urlencoded" self.prepare_content_length(body) # Add content-type if it wasn't explicitly provided. - if content_type and ('content-type' not in self.headers): - self.headers['Content-Type'] = content_type + if content_type and ("content-type" not in self.headers): + self.headers["Content-Type"] = content_type self.body = body @@ -528,13 +577,16 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): if length: # If length exists, set it. Otherwise, we fallback # to Transfer-Encoding: chunked. - self.headers['Content-Length'] = builtin_str(length) - elif self.method not in ('GET', 'HEAD') and self.headers.get('Content-Length') is None: + self.headers["Content-Length"] = builtin_str(length) + elif ( + self.method not in ("GET", "HEAD") + and self.headers.get("Content-Length") is None + ): # Set Content-Length to 0 for methods that can have a body # but don't provide one. (i.e. not GET or HEAD) - self.headers['Content-Length'] = '0' + self.headers["Content-Length"] = "0" - def prepare_auth(self, auth, url=''): + def prepare_auth(self, auth, url=""): """Prepares the given HTTP auth data.""" # If no Auth is explicitly provided, extract it from the URL first. @@ -574,7 +626,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): cookie_header = get_cookie_header(self._cookies, self) if cookie_header is not None: - self.headers['Cookie'] = cookie_header + self.headers["Cookie"] = cookie_header def prepare_hooks(self, hooks): """Prepares the given hooks.""" @@ -586,14 +638,22 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin): self.register_hook(event, hooks[event]) -class Response(object): +class Response: """The :class:`Response <Response>` object, which contains a server's response to an HTTP request. """ __attrs__ = [ - '_content', 'status_code', 'headers', 'url', 'history', - 'encoding', 'reason', 'cookies', 'elapsed', 'request' + "_content", + "status_code", + "headers", + "url", + "history", + "encoding", + "reason", + "cookies", + "elapsed", + "request", ] def __init__(self): @@ -662,11 +722,11 @@ class Response(object): setattr(self, name, value) # pickled objects do not have .raw - setattr(self, '_content_consumed', True) - setattr(self, 'raw', None) + setattr(self, "_content_consumed", True) + setattr(self, "raw", None) def __repr__(self): - return '<Response [%s]>' % (self.status_code) + return f"<Response [{self.status_code}]>" def __bool__(self): """Returns True if :attr:`status_code` is less than 400. @@ -712,12 +772,15 @@ class Response(object): """True if this Response is a well-formed HTTP redirect that could have been processed automatically (by :meth:`Session.resolve_redirects`). """ - return ('location' in self.headers and self.status_code in REDIRECT_STATI) + return "location" in self.headers and self.status_code in REDIRECT_STATI @property def is_permanent_redirect(self): """True if this Response one of the permanent versions of redirect.""" - return ('location' in self.headers and self.status_code in (codes.moved_permanently, codes.permanent_redirect)) + return "location" in self.headers and self.status_code in ( + codes.moved_permanently, + codes.permanent_redirect, + ) @property def next(self): @@ -726,8 +789,8 @@ class Response(object): @property def apparent_encoding(self): - """The apparent encoding, provided by the chardet library.""" - return chardet.detect(self.content)['encoding'] + """The apparent encoding, provided by the charset_normalizer or chardet libraries.""" + return chardet.detect(self.content)["encoding"] def iter_content(self, chunk_size=1, decode_unicode=False): """Iterates over the response data. When stream=True is set on the @@ -748,16 +811,17 @@ class Response(object): def generate(): # Special case for urllib3. - if hasattr(self.raw, 'stream'): + if hasattr(self.raw, "stream"): try: - for chunk in self.raw.stream(chunk_size, decode_content=True): - yield chunk + yield from self.raw.stream(chunk_size, decode_content=True) except ProtocolError as e: raise ChunkedEncodingError(e) except DecodeError as e: raise ContentDecodingError(e) except ReadTimeoutError as e: raise ConnectionError(e) + except SSLError as e: + raise RequestsSSLError(e) else: # Standard file-like object. while True: @@ -771,7 +835,9 @@ class Response(object): if self._content_consumed and isinstance(self._content, bool): raise StreamConsumedError() elif chunk_size is not None and not isinstance(chunk_size, int): - raise TypeError("chunk_size must be an int, it is instead a %s." % type(chunk_size)) + raise TypeError( + f"chunk_size must be an int, it is instead a {type(chunk_size)}." + ) # simulate reading small chunks of the content reused_chunks = iter_slices(self._content, chunk_size) @@ -784,7 +850,9 @@ class Response(object): return chunks - def iter_lines(self, chunk_size=ITER_CHUNK_SIZE, decode_unicode=False, delimiter=None): + def iter_lines( + self, chunk_size=ITER_CHUNK_SIZE, decode_unicode=False, delimiter=None + ): """Iterates over the response data, one line at a time. When stream=True is set on the request, this avoids reading the content at once into memory for large responses. @@ -794,7 +862,9 @@ class Response(object): pending = None - for chunk in self.iter_content(chunk_size=chunk_size, decode_unicode=decode_unicode): + for chunk in self.iter_content( + chunk_size=chunk_size, decode_unicode=decode_unicode + ): if pending is not None: chunk = pending + chunk @@ -809,8 +879,7 @@ class Response(object): else: pending = None - for line in lines: - yield line + yield from lines if pending is not None: yield pending @@ -822,13 +891,12 @@ class Response(object): if self._content is False: # Read the contents. if self._content_consumed: - raise RuntimeError( - 'The content for this response was already consumed') + raise RuntimeError("The content for this response was already consumed") if self.status_code == 0 or self.raw is None: self._content = None else: - self._content = b''.join(self.iter_content(CONTENT_CHUNK_SIZE)) or b'' + self._content = b"".join(self.iter_content(CONTENT_CHUNK_SIZE)) or b"" self._content_consumed = True # don't need to release the connection; that's been handled by urllib3 @@ -840,7 +908,7 @@ class Response(object): """Content of the response, in unicode. If Response.encoding is None, encoding will be guessed using - ``chardet``. + ``charset_normalizer`` or ``chardet``. The encoding of the response content is determined based solely on HTTP headers, following RFC 2616 to the letter. If you can take advantage of @@ -853,7 +921,7 @@ class Response(object): encoding = self.encoding if not self.content: - return str('') + return "" # Fallback to auto-detected encoding. if self.encoding is None: @@ -861,7 +929,7 @@ class Response(object): # Decode unicode from given encoding. try: - content = str(self.content, encoding, errors='replace') + content = str(self.content, encoding, errors="replace") except (LookupError, TypeError): # A LookupError is raised if the encoding was not found which could # indicate a misspelling or similar mistake. @@ -869,7 +937,7 @@ class Response(object): # A TypeError can be raised if encoding is None # # So we try blindly encoding. - content = str(self.content, errors='replace') + content = str(self.content, errors="replace") return content @@ -877,67 +945,77 @@ class Response(object): r"""Returns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. - :raises ValueError: If the response body does not contain valid json. + :raises requests.exceptions.JSONDecodeError: If the response body does not + contain valid json. """ if not self.encoding and self.content and len(self.content) > 3: # No encoding set. JSON RFC 4627 section 3 states we should expect # UTF-8, -16 or -32. Detect which one to use; If the detection or - # decoding fails, fall back to `self.text` (using chardet to make + # decoding fails, fall back to `self.text` (using charset_normalizer to make # a best guess). encoding = guess_json_utf(self.content) if encoding is not None: try: - return complexjson.loads( - self.content.decode(encoding), **kwargs - ) + return complexjson.loads(self.content.decode(encoding), **kwargs) except UnicodeDecodeError: # Wrong UTF codec detected; usually because it's not UTF-8 # but some other 8-bit codec. This is an RFC violation, # and the server didn't bother to tell us what codec *was* # used. pass - return complexjson.loads(self.text, **kwargs) + except JSONDecodeError as e: + raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) + + try: + return complexjson.loads(self.text, **kwargs) + except JSONDecodeError as e: + # Catch JSON-related errors and raise as requests.JSONDecodeError + # This aliases json.JSONDecodeError and simplejson.JSONDecodeError + raise RequestsJSONDecodeError(e.msg, e.doc, e.pos) @property def links(self): """Returns the parsed header links of the response, if any.""" - header = self.headers.get('link') + header = self.headers.get("link") - # l = MultiDict() - l = {} + resolved_links = {} if header: links = parse_header_links(header) for link in links: - key = link.get('rel') or link.get('url') - l[key] = link + key = link.get("rel") or link.get("url") + resolved_links[key] = link - return l + return resolved_links def raise_for_status(self): """Raises :class:`HTTPError`, if one occurred.""" - http_error_msg = '' + http_error_msg = "" if isinstance(self.reason, bytes): # We attempt to decode utf-8 first because some servers # choose to localize their reason strings. If the string # isn't utf-8, we fall back to iso-8859-1 for all other # encodings. (See PR #3538) try: - reason = self.reason.decode('utf-8') + reason = self.reason.decode("utf-8") except UnicodeDecodeError: - reason = self.reason.decode('iso-8859-1') + reason = self.reason.decode("iso-8859-1") else: reason = self.reason if 400 <= self.status_code < 500: - http_error_msg = u'%s Client Error: %s for url: %s' % (self.status_code, reason, self.url) + http_error_msg = ( + f"{self.status_code} Client Error: {reason} for url: {self.url}" + ) elif 500 <= self.status_code < 600: - http_error_msg = u'%s Server Error: %s for url: %s' % (self.status_code, reason, self.url) + http_error_msg = ( + f"{self.status_code} Server Error: {reason} for url: {self.url}" + ) if http_error_msg: raise HTTPError(http_error_msg, response=self) @@ -951,6 +1029,6 @@ class Response(object): if not self._content_consumed: self.raw.close() - release_conn = getattr(self.raw, 'release_conn', None) + release_conn = getattr(self.raw, "release_conn", None) if release_conn is not None: release_conn() diff --git a/env/Lib/site-packages/pip/_vendor/requests/sessions.py b/env/Lib/site-packages/pip/_vendor/requests/sessions.py index 45ab8a5d..dbcf2a7b 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/sessions.py +++ b/env/Lib/site-packages/pip/_vendor/requests/sessions.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.sessions ~~~~~~~~~~~~~~~~~ @@ -10,39 +8,52 @@ requests (cookies, auth, proxies). import os import sys import time -from datetime import timedelta from collections import OrderedDict +from datetime import timedelta +from ._internal_utils import to_native_string +from .adapters import HTTPAdapter from .auth import _basic_auth_str -from .compat import cookielib, is_py3, urljoin, urlparse, Mapping +from .compat import Mapping, cookielib, urljoin, urlparse from .cookies import ( - cookiejar_from_dict, extract_cookies_to_jar, RequestsCookieJar, merge_cookies) -from .models import Request, PreparedRequest, DEFAULT_REDIRECT_LIMIT -from .hooks import default_hooks, dispatch_hook -from ._internal_utils import to_native_string -from .utils import to_key_val_list, default_headers, DEFAULT_PORTS + RequestsCookieJar, + cookiejar_from_dict, + extract_cookies_to_jar, + merge_cookies, +) from .exceptions import ( - TooManyRedirects, InvalidSchema, ChunkedEncodingError, ContentDecodingError) - -from .structures import CaseInsensitiveDict -from .adapters import HTTPAdapter - -from .utils import ( - requote_uri, get_environ_proxies, get_netrc_auth, should_bypass_proxies, - get_auth_from_url, rewind_body + ChunkedEncodingError, + ContentDecodingError, + InvalidSchema, + TooManyRedirects, ) - -from .status_codes import codes +from .hooks import default_hooks, dispatch_hook # formerly defined here, reexposed here for backward compatibility -from .models import REDIRECT_STATI +from .models import ( # noqa: F401 + DEFAULT_REDIRECT_LIMIT, + REDIRECT_STATI, + PreparedRequest, + Request, +) +from .status_codes import codes +from .structures import CaseInsensitiveDict +from .utils import ( # noqa: F401 + DEFAULT_PORTS, + default_headers, + get_auth_from_url, + get_environ_proxies, + get_netrc_auth, + requote_uri, + resolve_proxies, + rewind_body, + should_bypass_proxies, + to_key_val_list, +) # Preferred clock, based on which one is more accurate on a given system. -if sys.platform == 'win32': - try: # Python 3.4+ - preferred_clock = time.perf_counter - except AttributeError: # Earlier than Python 3. - preferred_clock = time.clock +if sys.platform == "win32": + preferred_clock = time.perf_counter else: preferred_clock = time.time @@ -61,8 +72,7 @@ def merge_setting(request_setting, session_setting, dict_class=OrderedDict): # Bypass if not a dictionary (e.g. verify) if not ( - isinstance(session_setting, Mapping) and - isinstance(request_setting, Mapping) + isinstance(session_setting, Mapping) and isinstance(request_setting, Mapping) ): return request_setting @@ -84,17 +94,16 @@ def merge_hooks(request_hooks, session_hooks, dict_class=OrderedDict): This is necessary because when request_hooks == {'response': []}, the merge breaks Session hooks entirely. """ - if session_hooks is None or session_hooks.get('response') == []: + if session_hooks is None or session_hooks.get("response") == []: return request_hooks - if request_hooks is None or request_hooks.get('response') == []: + if request_hooks is None or request_hooks.get("response") == []: return session_hooks return merge_setting(request_hooks, session_hooks, dict_class) -class SessionRedirectMixin(object): - +class SessionRedirectMixin: def get_redirect_target(self, resp): """Receives a Response. Returns a redirect URI or ``None``""" # Due to the nature of how requests processes redirects this method will @@ -104,16 +113,15 @@ class SessionRedirectMixin(object): # to cache the redirect location onto the response object as a private # attribute. if resp.is_redirect: - location = resp.headers['location'] + location = resp.headers["location"] # Currently the underlying http module on py3 decode headers # in latin1, but empirical evidence suggests that latin1 is very # rarely used with non-ASCII characters in HTTP headers. # It is more likely to get UTF8 header rather than latin1. # This causes incorrect handling of UTF8 encoded location headers. # To solve this, we re-encode the location in latin1. - if is_py3: - location = location.encode('latin1') - return to_native_string(location, 'utf8') + location = location.encode("latin1") + return to_native_string(location, "utf8") return None def should_strip_auth(self, old_url, new_url): @@ -126,23 +134,40 @@ class SessionRedirectMixin(object): # ports. This isn't specified by RFC 7235, but is kept to avoid # breaking backwards compatibility with older versions of requests # that allowed any redirects on the same host. - if (old_parsed.scheme == 'http' and old_parsed.port in (80, None) - and new_parsed.scheme == 'https' and new_parsed.port in (443, None)): + if ( + old_parsed.scheme == "http" + and old_parsed.port in (80, None) + and new_parsed.scheme == "https" + and new_parsed.port in (443, None) + ): return False # Handle default port usage corresponding to scheme. changed_port = old_parsed.port != new_parsed.port changed_scheme = old_parsed.scheme != new_parsed.scheme default_port = (DEFAULT_PORTS.get(old_parsed.scheme, None), None) - if (not changed_scheme and old_parsed.port in default_port - and new_parsed.port in default_port): + if ( + not changed_scheme + and old_parsed.port in default_port + and new_parsed.port in default_port + ): return False # Standard case: root URI must match return changed_port or changed_scheme - def resolve_redirects(self, resp, req, stream=False, timeout=None, - verify=True, cert=None, proxies=None, yield_requests=False, **adapter_kwargs): + def resolve_redirects( + self, + resp, + req, + stream=False, + timeout=None, + verify=True, + cert=None, + proxies=None, + yield_requests=False, + **adapter_kwargs, + ): """Receives a Response. Returns a generator of Responses or Requests.""" hist = [] # keep track of history @@ -163,19 +188,21 @@ class SessionRedirectMixin(object): resp.raw.read(decode_content=False) if len(resp.history) >= self.max_redirects: - raise TooManyRedirects('Exceeded {} redirects.'.format(self.max_redirects), response=resp) + raise TooManyRedirects( + f"Exceeded {self.max_redirects} redirects.", response=resp + ) # Release the connection back into the pool. resp.close() # Handle redirection without scheme (see: RFC 1808 Section 4) - if url.startswith('//'): + if url.startswith("//"): parsed_rurl = urlparse(resp.url) - url = ':'.join([to_native_string(parsed_rurl.scheme), url]) + url = ":".join([to_native_string(parsed_rurl.scheme), url]) # Normalize url case and attach previous fragment if needed (RFC 7231 7.1.2) parsed = urlparse(url) - if parsed.fragment == '' and previous_fragment: + if parsed.fragment == "" and previous_fragment: parsed = parsed._replace(fragment=previous_fragment) elif parsed.fragment: previous_fragment = parsed.fragment @@ -194,15 +221,18 @@ class SessionRedirectMixin(object): self.rebuild_method(prepared_request, resp) # https://github.com/psf/requests/issues/1084 - if resp.status_code not in (codes.temporary_redirect, codes.permanent_redirect): + if resp.status_code not in ( + codes.temporary_redirect, + codes.permanent_redirect, + ): # https://github.com/psf/requests/issues/3490 - purged_headers = ('Content-Length', 'Content-Type', 'Transfer-Encoding') + purged_headers = ("Content-Length", "Content-Type", "Transfer-Encoding") for header in purged_headers: prepared_request.headers.pop(header, None) prepared_request.body = None headers = prepared_request.headers - headers.pop('Cookie', None) + headers.pop("Cookie", None) # Extract any cookies sent on the response to the cookiejar # in the new request. Because we've mutated our copied prepared @@ -218,9 +248,8 @@ class SessionRedirectMixin(object): # A failed tell() sets `_body_position` to `object()`. This non-None # value ensures `rewindable` will be True, allowing us to raise an # UnrewindableBodyError, instead of hanging the connection. - rewindable = ( - prepared_request._body_position is not None and - ('Content-Length' in headers or 'Transfer-Encoding' in headers) + rewindable = prepared_request._body_position is not None and ( + "Content-Length" in headers or "Transfer-Encoding" in headers ) # Attempt to rewind consumed file-like object. @@ -242,7 +271,7 @@ class SessionRedirectMixin(object): cert=cert, proxies=proxies, allow_redirects=False, - **adapter_kwargs + **adapter_kwargs, ) extract_cookies_to_jar(self.cookies, prepared_request, resp.raw) @@ -259,17 +288,18 @@ class SessionRedirectMixin(object): headers = prepared_request.headers url = prepared_request.url - if 'Authorization' in headers and self.should_strip_auth(response.request.url, url): + if "Authorization" in headers and self.should_strip_auth( + response.request.url, url + ): # If we get redirected to a new host, we should strip out any # authentication headers. - del headers['Authorization'] + del headers["Authorization"] # .netrc might have more auth for us on our new host. new_auth = get_netrc_auth(url) if self.trust_env else None if new_auth is not None: prepared_request.prepare_auth(new_auth) - def rebuild_proxies(self, prepared_request, proxies): """This method re-evaluates the proxy configuration by considering the environment variables. If we are redirected to a URL covered by @@ -282,32 +312,22 @@ class SessionRedirectMixin(object): :rtype: dict """ - proxies = proxies if proxies is not None else {} headers = prepared_request.headers - url = prepared_request.url - scheme = urlparse(url).scheme - new_proxies = proxies.copy() - no_proxy = proxies.get('no_proxy') + scheme = urlparse(prepared_request.url).scheme + new_proxies = resolve_proxies(prepared_request, proxies, self.trust_env) - bypass_proxy = should_bypass_proxies(url, no_proxy=no_proxy) - if self.trust_env and not bypass_proxy: - environ_proxies = get_environ_proxies(url, no_proxy=no_proxy) - - proxy = environ_proxies.get(scheme, environ_proxies.get('all')) - - if proxy: - new_proxies.setdefault(scheme, proxy) - - if 'Proxy-Authorization' in headers: - del headers['Proxy-Authorization'] + if "Proxy-Authorization" in headers: + del headers["Proxy-Authorization"] try: username, password = get_auth_from_url(new_proxies[scheme]) except KeyError: username, password = None, None - if username and password: - headers['Proxy-Authorization'] = _basic_auth_str(username, password) + # urllib3 handles proxy authorization for us in the standard adapter. + # Avoid appending this to TLS tunneled requests where it may be leaked. + if not scheme.startswith('https') and username and password: + headers["Proxy-Authorization"] = _basic_auth_str(username, password) return new_proxies @@ -318,18 +338,18 @@ class SessionRedirectMixin(object): method = prepared_request.method # https://tools.ietf.org/html/rfc7231#section-6.4.4 - if response.status_code == codes.see_other and method != 'HEAD': - method = 'GET' + if response.status_code == codes.see_other and method != "HEAD": + method = "GET" # Do what the browsers do, despite standards... # First, turn 302s into GETs. - if response.status_code == codes.found and method != 'HEAD': - method = 'GET' + if response.status_code == codes.found and method != "HEAD": + method = "GET" # Second, if a POST is responded to with a 301, turn it into a GET. # This bizarre behaviour is explained in Issue 1704. - if response.status_code == codes.moved and method == 'POST': - method = 'GET' + if response.status_code == codes.moved and method == "POST": + method = "GET" prepared_request.method = method @@ -354,9 +374,18 @@ class Session(SessionRedirectMixin): """ __attrs__ = [ - 'headers', 'cookies', 'auth', 'proxies', 'hooks', 'params', 'verify', - 'cert', 'adapters', 'stream', 'trust_env', - 'max_redirects', + "headers", + "cookies", + "auth", + "proxies", + "hooks", + "params", + "verify", + "cert", + "adapters", + "stream", + "trust_env", + "max_redirects", ] def __init__(self): @@ -418,8 +447,8 @@ class Session(SessionRedirectMixin): # Default connection adapters. self.adapters = OrderedDict() - self.mount('https://', HTTPAdapter()) - self.mount('http://', HTTPAdapter()) + self.mount("https://", HTTPAdapter()) + self.mount("http://", HTTPAdapter()) def __enter__(self): return self @@ -445,7 +474,8 @@ class Session(SessionRedirectMixin): # Merge with session cookies merged_cookies = merge_cookies( - merge_cookies(RequestsCookieJar(), self.cookies), cookies) + merge_cookies(RequestsCookieJar(), self.cookies), cookies + ) # Set environment's basic authentication if not explicitly set. auth = request.auth @@ -459,7 +489,9 @@ class Session(SessionRedirectMixin): files=request.files, data=request.data, json=request.json, - headers=merge_setting(request.headers, self.headers, dict_class=CaseInsensitiveDict), + headers=merge_setting( + request.headers, self.headers, dict_class=CaseInsensitiveDict + ), params=merge_setting(request.params, self.params), auth=merge_setting(auth, self.auth), cookies=merged_cookies, @@ -467,10 +499,25 @@ class Session(SessionRedirectMixin): ) return p - def request(self, method, url, - params=None, data=None, headers=None, cookies=None, files=None, - auth=None, timeout=None, allow_redirects=True, proxies=None, - hooks=None, stream=None, verify=None, cert=None, json=None): + def request( + self, + method, + url, + params=None, + data=None, + headers=None, + cookies=None, + files=None, + auth=None, + timeout=None, + allow_redirects=True, + proxies=None, + hooks=None, + stream=None, + verify=None, + cert=None, + json=None, + ): """Constructs a :class:`Request <Request>`, prepares it and sends it. Returns :class:`Response <Response>` object. @@ -506,7 +553,7 @@ class Session(SessionRedirectMixin): ``False``, requests will accept any TLS certificate presented by the server, and will ignore hostname mismatches and/or expired certificates, which will make your application vulnerable to - man-in-the-middle (MitM) attacks. Setting verify to ``False`` + man-in-the-middle (MitM) attacks. Setting verify to ``False`` may be useful during local development or testing. :param cert: (optional) if String, path to ssl client cert file (.pem). If Tuple, ('cert', 'key') pair. @@ -535,8 +582,8 @@ class Session(SessionRedirectMixin): # Send the request. send_kwargs = { - 'timeout': timeout, - 'allow_redirects': allow_redirects, + "timeout": timeout, + "allow_redirects": allow_redirects, } send_kwargs.update(settings) resp = self.send(prep, **send_kwargs) @@ -551,8 +598,8 @@ class Session(SessionRedirectMixin): :rtype: requests.Response """ - kwargs.setdefault('allow_redirects', True) - return self.request('GET', url, **kwargs) + kwargs.setdefault("allow_redirects", True) + return self.request("GET", url, **kwargs) def options(self, url, **kwargs): r"""Sends a OPTIONS request. Returns :class:`Response` object. @@ -562,8 +609,8 @@ class Session(SessionRedirectMixin): :rtype: requests.Response """ - kwargs.setdefault('allow_redirects', True) - return self.request('OPTIONS', url, **kwargs) + kwargs.setdefault("allow_redirects", True) + return self.request("OPTIONS", url, **kwargs) def head(self, url, **kwargs): r"""Sends a HEAD request. Returns :class:`Response` object. @@ -573,8 +620,8 @@ class Session(SessionRedirectMixin): :rtype: requests.Response """ - kwargs.setdefault('allow_redirects', False) - return self.request('HEAD', url, **kwargs) + kwargs.setdefault("allow_redirects", False) + return self.request("HEAD", url, **kwargs) def post(self, url, data=None, json=None, **kwargs): r"""Sends a POST request. Returns :class:`Response` object. @@ -587,7 +634,7 @@ class Session(SessionRedirectMixin): :rtype: requests.Response """ - return self.request('POST', url, data=data, json=json, **kwargs) + return self.request("POST", url, data=data, json=json, **kwargs) def put(self, url, data=None, **kwargs): r"""Sends a PUT request. Returns :class:`Response` object. @@ -599,7 +646,7 @@ class Session(SessionRedirectMixin): :rtype: requests.Response """ - return self.request('PUT', url, data=data, **kwargs) + return self.request("PUT", url, data=data, **kwargs) def patch(self, url, data=None, **kwargs): r"""Sends a PATCH request. Returns :class:`Response` object. @@ -611,7 +658,7 @@ class Session(SessionRedirectMixin): :rtype: requests.Response """ - return self.request('PATCH', url, data=data, **kwargs) + return self.request("PATCH", url, data=data, **kwargs) def delete(self, url, **kwargs): r"""Sends a DELETE request. Returns :class:`Response` object. @@ -621,7 +668,7 @@ class Session(SessionRedirectMixin): :rtype: requests.Response """ - return self.request('DELETE', url, **kwargs) + return self.request("DELETE", url, **kwargs) def send(self, request, **kwargs): """Send a given PreparedRequest. @@ -630,19 +677,20 @@ class Session(SessionRedirectMixin): """ # Set defaults that the hooks can utilize to ensure they always have # the correct parameters to reproduce the previous request. - kwargs.setdefault('stream', self.stream) - kwargs.setdefault('verify', self.verify) - kwargs.setdefault('cert', self.cert) - kwargs.setdefault('proxies', self.proxies) + kwargs.setdefault("stream", self.stream) + kwargs.setdefault("verify", self.verify) + kwargs.setdefault("cert", self.cert) + if "proxies" not in kwargs: + kwargs["proxies"] = resolve_proxies(request, self.proxies, self.trust_env) # It's possible that users might accidentally send a Request object. # Guard against that specific failure case. if isinstance(request, Request): - raise ValueError('You can only send PreparedRequests.') + raise ValueError("You can only send PreparedRequests.") # Set up variables needed for resolve_redirects and dispatching of hooks - allow_redirects = kwargs.pop('allow_redirects', True) - stream = kwargs.get('stream') + allow_redirects = kwargs.pop("allow_redirects", True) + stream = kwargs.get("stream") hooks = request.hooks # Get the appropriate adapter to use @@ -659,7 +707,7 @@ class Session(SessionRedirectMixin): r.elapsed = timedelta(seconds=elapsed) # Response manipulation hooks - r = dispatch_hook('response', hooks, r, **kwargs) + r = dispatch_hook("response", hooks, r, **kwargs) # Persist cookies if r.history: @@ -689,7 +737,9 @@ class Session(SessionRedirectMixin): # If redirects aren't being followed, store the response on the Request for Response.next(). if not allow_redirects: try: - r._next = next(self.resolve_redirects(r, request, yield_requests=True, **kwargs)) + r._next = next( + self.resolve_redirects(r, request, yield_requests=True, **kwargs) + ) except StopIteration: pass @@ -707,16 +757,19 @@ class Session(SessionRedirectMixin): # Gather clues from the surrounding environment. if self.trust_env: # Set environment's proxies. - no_proxy = proxies.get('no_proxy') if proxies is not None else None + no_proxy = proxies.get("no_proxy") if proxies is not None else None env_proxies = get_environ_proxies(url, no_proxy=no_proxy) for (k, v) in env_proxies.items(): proxies.setdefault(k, v) - # Look for requests environment configuration and be compatible - # with cURL. + # Look for requests environment configuration + # and be compatible with cURL. if verify is True or verify is None: - verify = (os.environ.get('REQUESTS_CA_BUNDLE') or - os.environ.get('CURL_CA_BUNDLE')) + verify = ( + os.environ.get("REQUESTS_CA_BUNDLE") + or os.environ.get("CURL_CA_BUNDLE") + or verify + ) # Merge all the kwargs. proxies = merge_setting(proxies, self.proxies) @@ -724,8 +777,7 @@ class Session(SessionRedirectMixin): verify = merge_setting(verify, self.verify) cert = merge_setting(cert, self.cert) - return {'verify': verify, 'proxies': proxies, 'stream': stream, - 'cert': cert} + return {"proxies": proxies, "stream": stream, "verify": verify, "cert": cert} def get_adapter(self, url): """ @@ -739,7 +791,7 @@ class Session(SessionRedirectMixin): return adapter # Nothing matches :-/ - raise InvalidSchema("No connection adapters were found for {!r}".format(url)) + raise InvalidSchema(f"No connection adapters were found for {url!r}") def close(self): """Closes all adapters and as such the session""" diff --git a/env/Lib/site-packages/pip/_vendor/requests/status_codes.py b/env/Lib/site-packages/pip/_vendor/requests/status_codes.py index d80a7cd4..4bd072be 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/status_codes.py +++ b/env/Lib/site-packages/pip/_vendor/requests/status_codes.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - r""" The ``codes`` object defines a mapping from common names for HTTP statuses to their numerical codes, accessible either as attributes or as dictionary @@ -23,101 +21,108 @@ the names are allowed. For example, ``codes.ok``, ``codes.OK``, and from .structures import LookupDict _codes = { - # Informational. - 100: ('continue',), - 101: ('switching_protocols',), - 102: ('processing',), - 103: ('checkpoint',), - 122: ('uri_too_long', 'request_uri_too_long'), - 200: ('ok', 'okay', 'all_ok', 'all_okay', 'all_good', '\\o/', '✓'), - 201: ('created',), - 202: ('accepted',), - 203: ('non_authoritative_info', 'non_authoritative_information'), - 204: ('no_content',), - 205: ('reset_content', 'reset'), - 206: ('partial_content', 'partial'), - 207: ('multi_status', 'multiple_status', 'multi_stati', 'multiple_stati'), - 208: ('already_reported',), - 226: ('im_used',), - + 100: ("continue",), + 101: ("switching_protocols",), + 102: ("processing",), + 103: ("checkpoint",), + 122: ("uri_too_long", "request_uri_too_long"), + 200: ("ok", "okay", "all_ok", "all_okay", "all_good", "\\o/", "✓"), + 201: ("created",), + 202: ("accepted",), + 203: ("non_authoritative_info", "non_authoritative_information"), + 204: ("no_content",), + 205: ("reset_content", "reset"), + 206: ("partial_content", "partial"), + 207: ("multi_status", "multiple_status", "multi_stati", "multiple_stati"), + 208: ("already_reported",), + 226: ("im_used",), # Redirection. - 300: ('multiple_choices',), - 301: ('moved_permanently', 'moved', '\\o-'), - 302: ('found',), - 303: ('see_other', 'other'), - 304: ('not_modified',), - 305: ('use_proxy',), - 306: ('switch_proxy',), - 307: ('temporary_redirect', 'temporary_moved', 'temporary'), - 308: ('permanent_redirect', - 'resume_incomplete', 'resume',), # These 2 to be removed in 3.0 - + 300: ("multiple_choices",), + 301: ("moved_permanently", "moved", "\\o-"), + 302: ("found",), + 303: ("see_other", "other"), + 304: ("not_modified",), + 305: ("use_proxy",), + 306: ("switch_proxy",), + 307: ("temporary_redirect", "temporary_moved", "temporary"), + 308: ( + "permanent_redirect", + "resume_incomplete", + "resume", + ), # "resume" and "resume_incomplete" to be removed in 3.0 # Client Error. - 400: ('bad_request', 'bad'), - 401: ('unauthorized',), - 402: ('payment_required', 'payment'), - 403: ('forbidden',), - 404: ('not_found', '-o-'), - 405: ('method_not_allowed', 'not_allowed'), - 406: ('not_acceptable',), - 407: ('proxy_authentication_required', 'proxy_auth', 'proxy_authentication'), - 408: ('request_timeout', 'timeout'), - 409: ('conflict',), - 410: ('gone',), - 411: ('length_required',), - 412: ('precondition_failed', 'precondition'), - 413: ('request_entity_too_large',), - 414: ('request_uri_too_large',), - 415: ('unsupported_media_type', 'unsupported_media', 'media_type'), - 416: ('requested_range_not_satisfiable', 'requested_range', 'range_not_satisfiable'), - 417: ('expectation_failed',), - 418: ('im_a_teapot', 'teapot', 'i_am_a_teapot'), - 421: ('misdirected_request',), - 422: ('unprocessable_entity', 'unprocessable'), - 423: ('locked',), - 424: ('failed_dependency', 'dependency'), - 425: ('unordered_collection', 'unordered'), - 426: ('upgrade_required', 'upgrade'), - 428: ('precondition_required', 'precondition'), - 429: ('too_many_requests', 'too_many'), - 431: ('header_fields_too_large', 'fields_too_large'), - 444: ('no_response', 'none'), - 449: ('retry_with', 'retry'), - 450: ('blocked_by_windows_parental_controls', 'parental_controls'), - 451: ('unavailable_for_legal_reasons', 'legal_reasons'), - 499: ('client_closed_request',), - + 400: ("bad_request", "bad"), + 401: ("unauthorized",), + 402: ("payment_required", "payment"), + 403: ("forbidden",), + 404: ("not_found", "-o-"), + 405: ("method_not_allowed", "not_allowed"), + 406: ("not_acceptable",), + 407: ("proxy_authentication_required", "proxy_auth", "proxy_authentication"), + 408: ("request_timeout", "timeout"), + 409: ("conflict",), + 410: ("gone",), + 411: ("length_required",), + 412: ("precondition_failed", "precondition"), + 413: ("request_entity_too_large",), + 414: ("request_uri_too_large",), + 415: ("unsupported_media_type", "unsupported_media", "media_type"), + 416: ( + "requested_range_not_satisfiable", + "requested_range", + "range_not_satisfiable", + ), + 417: ("expectation_failed",), + 418: ("im_a_teapot", "teapot", "i_am_a_teapot"), + 421: ("misdirected_request",), + 422: ("unprocessable_entity", "unprocessable"), + 423: ("locked",), + 424: ("failed_dependency", "dependency"), + 425: ("unordered_collection", "unordered"), + 426: ("upgrade_required", "upgrade"), + 428: ("precondition_required", "precondition"), + 429: ("too_many_requests", "too_many"), + 431: ("header_fields_too_large", "fields_too_large"), + 444: ("no_response", "none"), + 449: ("retry_with", "retry"), + 450: ("blocked_by_windows_parental_controls", "parental_controls"), + 451: ("unavailable_for_legal_reasons", "legal_reasons"), + 499: ("client_closed_request",), # Server Error. - 500: ('internal_server_error', 'server_error', '/o\\', '✗'), - 501: ('not_implemented',), - 502: ('bad_gateway',), - 503: ('service_unavailable', 'unavailable'), - 504: ('gateway_timeout',), - 505: ('http_version_not_supported', 'http_version'), - 506: ('variant_also_negotiates',), - 507: ('insufficient_storage',), - 509: ('bandwidth_limit_exceeded', 'bandwidth'), - 510: ('not_extended',), - 511: ('network_authentication_required', 'network_auth', 'network_authentication'), + 500: ("internal_server_error", "server_error", "/o\\", "✗"), + 501: ("not_implemented",), + 502: ("bad_gateway",), + 503: ("service_unavailable", "unavailable"), + 504: ("gateway_timeout",), + 505: ("http_version_not_supported", "http_version"), + 506: ("variant_also_negotiates",), + 507: ("insufficient_storage",), + 509: ("bandwidth_limit_exceeded", "bandwidth"), + 510: ("not_extended",), + 511: ("network_authentication_required", "network_auth", "network_authentication"), } -codes = LookupDict(name='status_codes') +codes = LookupDict(name="status_codes") + def _init(): for code, titles in _codes.items(): for title in titles: setattr(codes, title, code) - if not title.startswith(('\\', '/')): + if not title.startswith(("\\", "/")): setattr(codes, title.upper(), code) def doc(code): - names = ', '.join('``%s``' % n for n in _codes[code]) - return '* %d: %s' % (code, names) + names = ", ".join(f"``{n}``" for n in _codes[code]) + return "* %d: %s" % (code, names) global __doc__ - __doc__ = (__doc__ + '\n' + - '\n'.join(doc(code) for code in sorted(_codes)) - if __doc__ is not None else None) + __doc__ = ( + __doc__ + "\n" + "\n".join(doc(code) for code in sorted(_codes)) + if __doc__ is not None + else None + ) + _init() diff --git a/env/Lib/site-packages/pip/_vendor/requests/structures.py b/env/Lib/site-packages/pip/_vendor/requests/structures.py index 8ee0ba7a..188e13e4 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/structures.py +++ b/env/Lib/site-packages/pip/_vendor/requests/structures.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.structures ~~~~~~~~~~~~~~~~~~~ @@ -64,11 +62,7 @@ class CaseInsensitiveDict(MutableMapping): def lower_items(self): """Like iteritems(), but with all lowercase keys.""" - return ( - (lowerkey, keyval[1]) - for (lowerkey, keyval) - in self._store.items() - ) + return ((lowerkey, keyval[1]) for (lowerkey, keyval) in self._store.items()) def __eq__(self, other): if isinstance(other, Mapping): @@ -91,10 +85,10 @@ class LookupDict(dict): def __init__(self, name=None): self.name = name - super(LookupDict, self).__init__() + super().__init__() def __repr__(self): - return '<lookup \'%s\'>' % (self.name) + return f"<lookup '{self.name}'>" def __getitem__(self, key): # We allow fall-through here, so values default to None diff --git a/env/Lib/site-packages/pip/_vendor/requests/utils.py b/env/Lib/site-packages/pip/_vendor/requests/utils.py index db67938e..36607eda 100644 --- a/env/Lib/site-packages/pip/_vendor/requests/utils.py +++ b/env/Lib/site-packages/pip/_vendor/requests/utils.py @@ -1,5 +1,3 @@ -# -*- coding: utf-8 -*- - """ requests.utils ~~~~~~~~~~~~~~ @@ -21,49 +19,76 @@ import warnings import zipfile from collections import OrderedDict -from .__version__ import __version__ +from pip._vendor.urllib3.util import make_headers, parse_url + from . import certs +from .__version__ import __version__ + # to_native_string is unused here, but imported here for backwards compatibility -from ._internal_utils import to_native_string +from ._internal_utils import ( # noqa: F401 + _HEADER_VALIDATORS_BYTE, + _HEADER_VALIDATORS_STR, + HEADER_VALIDATORS, + to_native_string, +) +from .compat import ( + Mapping, + basestring, + bytes, + getproxies, + getproxies_environment, + integer_types, +) from .compat import parse_http_list as _parse_list_header from .compat import ( - quote, urlparse, bytes, str, unquote, getproxies, - proxy_bypass, urlunparse, basestring, integer_types, is_py3, - proxy_bypass_environment, getproxies_environment, Mapping) + proxy_bypass, + proxy_bypass_environment, + quote, + str, + unquote, + urlparse, + urlunparse, +) from .cookies import cookiejar_from_dict -from .structures import CaseInsensitiveDict from .exceptions import ( - InvalidURL, InvalidHeader, FileModeWarning, UnrewindableBodyError) + FileModeWarning, + InvalidHeader, + InvalidURL, + UnrewindableBodyError, +) +from .structures import CaseInsensitiveDict -NETRC_FILES = ('.netrc', '_netrc') +NETRC_FILES = (".netrc", "_netrc") DEFAULT_CA_BUNDLE_PATH = certs.where() -DEFAULT_PORTS = {'http': 80, 'https': 443} +DEFAULT_PORTS = {"http": 80, "https": 443} + +# Ensure that ', ' is used to preserve previous delimiter behavior. +DEFAULT_ACCEPT_ENCODING = ", ".join( + re.split(r",\s*", make_headers(accept_encoding=True)["accept-encoding"]) +) -if sys.platform == 'win32': +if sys.platform == "win32": # provide a proxy_bypass version on Windows without DNS lookups def proxy_bypass_registry(host): try: - if is_py3: - import winreg - else: - import _winreg as winreg + import winreg except ImportError: return False try: - internetSettings = winreg.OpenKey(winreg.HKEY_CURRENT_USER, - r'Software\Microsoft\Windows\CurrentVersion\Internet Settings') + internetSettings = winreg.OpenKey( + winreg.HKEY_CURRENT_USER, + r"Software\Microsoft\Windows\CurrentVersion\Internet Settings", + ) # ProxyEnable could be REG_SZ or REG_DWORD, normalizing it - proxyEnable = int(winreg.QueryValueEx(internetSettings, - 'ProxyEnable')[0]) + proxyEnable = int(winreg.QueryValueEx(internetSettings, "ProxyEnable")[0]) # ProxyOverride is almost always a string - proxyOverride = winreg.QueryValueEx(internetSettings, - 'ProxyOverride')[0] - except OSError: + proxyOverride = winreg.QueryValueEx(internetSettings, "ProxyOverride")[0] + except (OSError, ValueError): return False if not proxyEnable or not proxyOverride: return False @@ -71,15 +96,15 @@ if sys.platform == 'win32': # make a check value list from the registry entry: replace the # '<local>' string by the localhost entry and the corresponding # canonical entry. - proxyOverride = proxyOverride.split(';') + proxyOverride = proxyOverride.split(";") # now check if we match one of the registry values. for test in proxyOverride: - if test == '<local>': - if '.' not in host: + if test == "<local>": + if "." not in host: return True - test = test.replace(".", r"\.") # mask dots - test = test.replace("*", r".*") # change glob sequence - test = test.replace("?", r".") # change glob char + test = test.replace(".", r"\.") # mask dots + test = test.replace("*", r".*") # change glob sequence + test = test.replace("?", r".") # change glob char if re.match(test, host, re.I): return True return False @@ -99,7 +124,7 @@ if sys.platform == 'win32': def dict_to_sequence(d): """Returns an internal sequence dictionary update.""" - if hasattr(d, 'items'): + if hasattr(d, "items"): d = d.items() return d @@ -109,37 +134,42 @@ def super_len(o): total_length = None current_position = 0 - if hasattr(o, '__len__'): + if hasattr(o, "__len__"): total_length = len(o) - elif hasattr(o, 'len'): + elif hasattr(o, "len"): total_length = o.len - elif hasattr(o, 'fileno'): + elif hasattr(o, "fileno"): try: fileno = o.fileno() - except io.UnsupportedOperation: + except (io.UnsupportedOperation, AttributeError): + # AttributeError is a surprising exception, seeing as how we've just checked + # that `hasattr(o, 'fileno')`. It happens for objects obtained via + # `Tarfile.extractfile()`, per issue 5229. pass else: total_length = os.fstat(fileno).st_size # Having used fstat to determine the file length, we need to # confirm that this file was opened up in binary mode. - if 'b' not in o.mode: - warnings.warn(( - "Requests has determined the content-length for this " - "request using the binary size of the file: however, the " - "file has been opened in text mode (i.e. without the 'b' " - "flag in the mode). This may lead to an incorrect " - "content-length. In Requests 3.0, support will be removed " - "for files in text mode."), - FileModeWarning + if "b" not in o.mode: + warnings.warn( + ( + "Requests has determined the content-length for this " + "request using the binary size of the file: however, the " + "file has been opened in text mode (i.e. without the 'b' " + "flag in the mode). This may lead to an incorrect " + "content-length. In Requests 3.0, support will be removed " + "for files in text mode." + ), + FileModeWarning, ) - if hasattr(o, 'tell'): + if hasattr(o, "tell"): try: current_position = o.tell() - except (OSError, IOError): + except OSError: # This can happen in some weird situations, such as when the file # is actually a special file descriptor like stdin. In this # instance, we don't know what the length is, so set it to zero and @@ -147,8 +177,8 @@ def super_len(o): if total_length is not None: current_position = total_length else: - if hasattr(o, 'seek') and total_length is None: - # StringIO and BytesIO have seek but no useable fileno + if hasattr(o, "seek") and total_length is None: + # StringIO and BytesIO have seek but no usable fileno try: # seek to end of file o.seek(0, 2) @@ -157,7 +187,7 @@ def super_len(o): # seek back to current position to support # partially read file-like objects o.seek(current_position or 0) - except (OSError, IOError): + except OSError: total_length = 0 if total_length is None: @@ -169,14 +199,14 @@ def super_len(o): def get_netrc_auth(url, raise_errors=False): """Returns the Requests tuple auth for a given url from netrc.""" - netrc_file = os.environ.get('NETRC') + netrc_file = os.environ.get("NETRC") if netrc_file is not None: netrc_locations = (netrc_file,) else: - netrc_locations = ('~/{}'.format(f) for f in NETRC_FILES) + netrc_locations = (f"~/{f}" for f in NETRC_FILES) try: - from netrc import netrc, NetrcParseError + from netrc import NetrcParseError, netrc netrc_path = None @@ -201,18 +231,18 @@ def get_netrc_auth(url, raise_errors=False): # Strip port numbers from netloc. This weird `if...encode`` dance is # used for Python 3.2, which doesn't support unicode literals. - splitstr = b':' + splitstr = b":" if isinstance(url, str): - splitstr = splitstr.decode('ascii') + splitstr = splitstr.decode("ascii") host = ri.netloc.split(splitstr)[0] try: _netrc = netrc(netrc_path).authenticators(host) if _netrc: # Return with login / password - login_i = (0 if _netrc[0] else 1) + login_i = 0 if _netrc[0] else 1 return (_netrc[login_i], _netrc[2]) - except (NetrcParseError, IOError): + except (NetrcParseError, OSError): # If there was a parsing error or a permissions issue reading the file, # we'll just skip netrc auth unless explicitly asked to raise errors. if raise_errors: @@ -225,9 +255,8 @@ def get_netrc_auth(url, raise_errors=False): def guess_filename(obj): """Tries to guess the filename of the given object.""" - name = getattr(obj, 'name', None) - if (name and isinstance(name, basestring) and name[0] != '<' and - name[-1] != '>'): + name = getattr(obj, "name", None) + if name and isinstance(name, basestring) and name[0] != "<" and name[-1] != ">": return os.path.basename(name) @@ -245,7 +274,11 @@ def extract_zipped_paths(path): archive, member = os.path.split(path) while archive and not os.path.exists(archive): archive, prefix = os.path.split(archive) - member = '/'.join([prefix, member]) + if not prefix: + # If we don't check for an empty prefix after the split (in other words, archive remains unchanged after the split), + # we _can_ end up in an infinite loop on a rare corner case affecting a small number of users + break + member = "/".join([prefix, member]) if not zipfile.is_zipfile(archive): return path @@ -256,13 +289,27 @@ def extract_zipped_paths(path): # we have a valid zip archive and a valid member of that archive tmp = tempfile.gettempdir() - extracted_path = os.path.join(tmp, *member.split('/')) + extracted_path = os.path.join(tmp, member.split("/")[-1]) if not os.path.exists(extracted_path): - extracted_path = zip_file.extract(member, path=tmp) - + # use read + write to avoid the creating nested folders, we only want the file, avoids mkdir racing condition + with atomic_open(extracted_path) as file_handler: + file_handler.write(zip_file.read(member)) return extracted_path +@contextlib.contextmanager +def atomic_open(filename): + """Write a file to the disk in an atomic fashion""" + tmp_descriptor, tmp_name = tempfile.mkstemp(dir=os.path.dirname(filename)) + try: + with os.fdopen(tmp_descriptor, "wb") as tmp_handler: + yield tmp_handler + os.replace(tmp_name, filename) + except BaseException: + os.remove(tmp_name) + raise + + def from_key_val_list(value): """Take an object and test to see if it can be represented as a dictionary. Unless it can not be represented as such, return an @@ -285,7 +332,7 @@ def from_key_val_list(value): return None if isinstance(value, (str, bytes, bool, int)): - raise ValueError('cannot encode objects that are not 2-tuples') + raise ValueError("cannot encode objects that are not 2-tuples") return OrderedDict(value) @@ -311,7 +358,7 @@ def to_key_val_list(value): return None if isinstance(value, (str, bytes, bool, int)): - raise ValueError('cannot encode objects that are not 2-tuples') + raise ValueError("cannot encode objects that are not 2-tuples") if isinstance(value, Mapping): value = value.items() @@ -376,10 +423,10 @@ def parse_dict_header(value): """ result = {} for item in _parse_list_header(value): - if '=' not in item: + if "=" not in item: result[item] = None continue - name, value = item.split('=', 1) + name, value = item.split("=", 1) if value[:1] == value[-1:] == '"': value = unquote_header_value(value[1:-1]) result[name] = value @@ -407,8 +454,8 @@ def unquote_header_value(value, is_filename=False): # replace sequence below on a UNC path has the effect of turning # the leading double slash into a single slash and then # _fix_ie_filename() doesn't work correctly. See #458. - if not is_filename or value[:2] != '\\\\': - return value.replace('\\\\', '\\').replace('\\"', '"') + if not is_filename or value[:2] != "\\\\": + return value.replace("\\\\", "\\").replace('\\"', '"') return value @@ -443,19 +490,24 @@ def get_encodings_from_content(content): :param content: bytestring to extract encodings from. """ - warnings.warn(( - 'In requests 3.0, get_encodings_from_content will be removed. For ' - 'more information, please see the discussion on issue #2266. (This' - ' warning should only appear once.)'), - DeprecationWarning) + warnings.warn( + ( + "In requests 3.0, get_encodings_from_content will be removed. For " + "more information, please see the discussion on issue #2266. (This" + " warning should only appear once.)" + ), + DeprecationWarning, + ) charset_re = re.compile(r'<meta.*?charset=["\']*(.+?)["\'>]', flags=re.I) pragma_re = re.compile(r'<meta.*?content=["\']*;?charset=(.+?)["\'>]', flags=re.I) xml_re = re.compile(r'^<\?xml.*?encoding=["\']*(.+?)["\'>]') - return (charset_re.findall(content) + - pragma_re.findall(content) + - xml_re.findall(content)) + return ( + charset_re.findall(content) + + pragma_re.findall(content) + + xml_re.findall(content) + ) def _parse_content_type_header(header): @@ -466,7 +518,7 @@ def _parse_content_type_header(header): parameters """ - tokens = header.split(';') + tokens = header.split(";") content_type, params = tokens[0].strip(), tokens[1:] params_dict = {} items_to_strip = "\"' " @@ -478,7 +530,7 @@ def _parse_content_type_header(header): index_of_equals = param.find("=") if index_of_equals != -1: key = param[:index_of_equals].strip(items_to_strip) - value = param[index_of_equals + 1:].strip(items_to_strip) + value = param[index_of_equals + 1 :].strip(items_to_strip) params_dict[key.lower()] = value return content_type, params_dict @@ -490,38 +542,37 @@ def get_encoding_from_headers(headers): :rtype: str """ - content_type = headers.get('content-type') + content_type = headers.get("content-type") if not content_type: return None content_type, params = _parse_content_type_header(content_type) - if 'charset' in params: - return params['charset'].strip("'\"") + if "charset" in params: + return params["charset"].strip("'\"") - if 'text' in content_type: - return 'ISO-8859-1' + if "text" in content_type: + return "ISO-8859-1" - if 'application/json' in content_type: + if "application/json" in content_type: # Assume UTF-8 based on RFC 4627: https://www.ietf.org/rfc/rfc4627.txt since the charset was unset - return 'utf-8' + return "utf-8" def stream_decode_response_unicode(iterator, r): - """Stream decodes a iterator.""" + """Stream decodes an iterator.""" if r.encoding is None: - for item in iterator: - yield item + yield from iterator return - decoder = codecs.getincrementaldecoder(r.encoding)(errors='replace') + decoder = codecs.getincrementaldecoder(r.encoding)(errors="replace") for chunk in iterator: rv = decoder.decode(chunk) if rv: yield rv - rv = decoder.decode(b'', final=True) + rv = decoder.decode(b"", final=True) if rv: yield rv @@ -532,7 +583,7 @@ def iter_slices(string, slice_length): if slice_length is None or slice_length <= 0: slice_length = len(string) while pos < len(string): - yield string[pos:pos + slice_length] + yield string[pos : pos + slice_length] pos += slice_length @@ -548,11 +599,14 @@ def get_unicode_from_response(r): :rtype: str """ - warnings.warn(( - 'In requests 3.0, get_unicode_from_response will be removed. For ' - 'more information, please see the discussion on issue #2266. (This' - ' warning should only appear once.)'), - DeprecationWarning) + warnings.warn( + ( + "In requests 3.0, get_unicode_from_response will be removed. For " + "more information, please see the discussion on issue #2266. (This" + " warning should only appear once.)" + ), + DeprecationWarning, + ) tried_encodings = [] @@ -567,14 +621,15 @@ def get_unicode_from_response(r): # Fall back: try: - return str(r.content, encoding, errors='replace') + return str(r.content, encoding, errors="replace") except TypeError: return r.content # The unreserved URI characters (RFC 3986) UNRESERVED_SET = frozenset( - "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" + "0123456789-._~") + "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" + "0123456789-._~" +) def unquote_unreserved(uri): @@ -583,22 +638,22 @@ def unquote_unreserved(uri): :rtype: str """ - parts = uri.split('%') + parts = uri.split("%") for i in range(1, len(parts)): h = parts[i][0:2] if len(h) == 2 and h.isalnum(): try: c = chr(int(h, 16)) except ValueError: - raise InvalidURL("Invalid percent-escape sequence: '%s'" % h) + raise InvalidURL(f"Invalid percent-escape sequence: '{h}'") if c in UNRESERVED_SET: parts[i] = c + parts[i][2:] else: - parts[i] = '%' + parts[i] + parts[i] = f"%{parts[i]}" else: - parts[i] = '%' + parts[i] - return ''.join(parts) + parts[i] = f"%{parts[i]}" + return "".join(parts) def requote_uri(uri): @@ -631,10 +686,10 @@ def address_in_network(ip, net): :rtype: bool """ - ipaddr = struct.unpack('=L', socket.inet_aton(ip))[0] - netaddr, bits = net.split('/') - netmask = struct.unpack('=L', socket.inet_aton(dotted_netmask(int(bits))))[0] - network = struct.unpack('=L', socket.inet_aton(netaddr))[0] & netmask + ipaddr = struct.unpack("=L", socket.inet_aton(ip))[0] + netaddr, bits = net.split("/") + netmask = struct.unpack("=L", socket.inet_aton(dotted_netmask(int(bits))))[0] + network = struct.unpack("=L", socket.inet_aton(netaddr))[0] & netmask return (ipaddr & netmask) == (network & netmask) @@ -645,8 +700,8 @@ def dotted_netmask(mask): :rtype: str """ - bits = 0xffffffff ^ (1 << 32 - mask) - 1 - return socket.inet_ntoa(struct.pack('>I', bits)) + bits = 0xFFFFFFFF ^ (1 << 32 - mask) - 1 + return socket.inet_ntoa(struct.pack(">I", bits)) def is_ipv4_address(string_ip): @@ -655,7 +710,7 @@ def is_ipv4_address(string_ip): """ try: socket.inet_aton(string_ip) - except socket.error: + except OSError: return False return True @@ -666,9 +721,9 @@ def is_valid_cidr(string_network): :rtype: bool """ - if string_network.count('/') == 1: + if string_network.count("/") == 1: try: - mask = int(string_network.split('/')[1]) + mask = int(string_network.split("/")[1]) except ValueError: return False @@ -676,8 +731,8 @@ def is_valid_cidr(string_network): return False try: - socket.inet_aton(string_network.split('/')[0]) - except socket.error: + socket.inet_aton(string_network.split("/")[0]) + except OSError: return False else: return False @@ -714,13 +769,14 @@ def should_bypass_proxies(url, no_proxy): """ # Prioritize lowercase environment variables over uppercase # to keep a consistent behaviour with other http projects (curl, wget). - get_proxy = lambda k: os.environ.get(k) or os.environ.get(k.upper()) + def get_proxy(key): + return os.environ.get(key) or os.environ.get(key.upper()) # First check whether no_proxy is defined. If it is, check that the URL # we're getting isn't in the no_proxy list. no_proxy_arg = no_proxy if no_proxy is None: - no_proxy = get_proxy('no_proxy') + no_proxy = get_proxy("no_proxy") parsed = urlparse(url) if parsed.hostname is None: @@ -730,9 +786,7 @@ def should_bypass_proxies(url, no_proxy): if no_proxy: # We need to check whether we match here. We need to see if we match # the end of the hostname, both with and without the port. - no_proxy = ( - host for host in no_proxy.replace(' ', '').split(',') if host - ) + no_proxy = (host for host in no_proxy.replace(" ", "").split(",") if host) if is_ipv4_address(parsed.hostname): for proxy_ip in no_proxy: @@ -746,7 +800,7 @@ def should_bypass_proxies(url, no_proxy): else: host_with_port = parsed.hostname if parsed.port: - host_with_port += ':{}'.format(parsed.port) + host_with_port += f":{parsed.port}" for host in no_proxy: if parsed.hostname.endswith(host) or host_with_port.endswith(host): @@ -754,7 +808,7 @@ def should_bypass_proxies(url, no_proxy): # to apply the proxies on this URL. return True - with set_environ('no_proxy', no_proxy_arg): + with set_environ("no_proxy", no_proxy_arg): # parsed.hostname can be `None` in cases such as a file URI. try: bypass = proxy_bypass(parsed.hostname) @@ -788,13 +842,13 @@ def select_proxy(url, proxies): proxies = proxies or {} urlparts = urlparse(url) if urlparts.hostname is None: - return proxies.get(urlparts.scheme, proxies.get('all')) + return proxies.get(urlparts.scheme, proxies.get("all")) proxy_keys = [ - urlparts.scheme + '://' + urlparts.hostname, + urlparts.scheme + "://" + urlparts.hostname, urlparts.scheme, - 'all://' + urlparts.hostname, - 'all', + "all://" + urlparts.hostname, + "all", ] proxy = None for proxy_key in proxy_keys: @@ -805,25 +859,54 @@ def select_proxy(url, proxies): return proxy +def resolve_proxies(request, proxies, trust_env=True): + """This method takes proxy information from a request and configuration + input to resolve a mapping of target proxies. This will consider settings + such a NO_PROXY to strip proxy configurations. + + :param request: Request or PreparedRequest + :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs + :param trust_env: Boolean declaring whether to trust environment configs + + :rtype: dict + """ + proxies = proxies if proxies is not None else {} + url = request.url + scheme = urlparse(url).scheme + no_proxy = proxies.get("no_proxy") + new_proxies = proxies.copy() + + if trust_env and not should_bypass_proxies(url, no_proxy=no_proxy): + environ_proxies = get_environ_proxies(url, no_proxy=no_proxy) + + proxy = environ_proxies.get(scheme, environ_proxies.get("all")) + + if proxy: + new_proxies.setdefault(scheme, proxy) + return new_proxies + + def default_user_agent(name="python-requests"): """ Return a string representing the default user agent. :rtype: str """ - return '%s/%s' % (name, __version__) + return f"{name}/{__version__}" def default_headers(): """ :rtype: requests.structures.CaseInsensitiveDict """ - return CaseInsensitiveDict({ - 'User-Agent': default_user_agent(), - 'Accept-Encoding': ', '.join(('gzip', 'deflate')), - 'Accept': '*/*', - 'Connection': 'keep-alive', - }) + return CaseInsensitiveDict( + { + "User-Agent": default_user_agent(), + "Accept-Encoding": DEFAULT_ACCEPT_ENCODING, + "Accept": "*/*", + "Connection": "keep-alive", + } + ) def parse_header_links(value): @@ -836,23 +919,23 @@ def parse_header_links(value): links = [] - replace_chars = ' \'"' + replace_chars = " '\"" value = value.strip(replace_chars) if not value: return links - for val in re.split(', *<', value): + for val in re.split(", *<", value): try: - url, params = val.split(';', 1) + url, params = val.split(";", 1) except ValueError: - url, params = val, '' + url, params = val, "" - link = {'url': url.strip('<> \'"')} + link = {"url": url.strip("<> '\"")} - for param in params.split(';'): + for param in params.split(";"): try: - key, value = param.split('=') + key, value = param.split("=") except ValueError: break @@ -864,7 +947,7 @@ def parse_header_links(value): # Null bytes; no need to recreate these on each call to guess_json_utf -_null = '\x00'.encode('ascii') # encoding to ASCII for Python 3 +_null = "\x00".encode("ascii") # encoding to ASCII for Python 3 _null2 = _null * 2 _null3 = _null * 3 @@ -878,25 +961,25 @@ def guess_json_utf(data): # determine the encoding. Also detect a BOM, if present. sample = data[:4] if sample in (codecs.BOM_UTF32_LE, codecs.BOM_UTF32_BE): - return 'utf-32' # BOM included + return "utf-32" # BOM included if sample[:3] == codecs.BOM_UTF8: - return 'utf-8-sig' # BOM included, MS style (discouraged) + return "utf-8-sig" # BOM included, MS style (discouraged) if sample[:2] in (codecs.BOM_UTF16_LE, codecs.BOM_UTF16_BE): - return 'utf-16' # BOM included + return "utf-16" # BOM included nullcount = sample.count(_null) if nullcount == 0: - return 'utf-8' + return "utf-8" if nullcount == 2: - if sample[::2] == _null2: # 1st and 3rd are null - return 'utf-16-be' + if sample[::2] == _null2: # 1st and 3rd are null + return "utf-16-be" if sample[1::2] == _null2: # 2nd and 4th are null - return 'utf-16-le' + return "utf-16-le" # Did not detect 2 valid UTF-16 ascii-range characters if nullcount == 3: if sample[:3] == _null3: - return 'utf-32-be' + return "utf-32-be" if sample[1:] == _null3: - return 'utf-32-le' + return "utf-32-le" # Did not detect a valid UTF-32 ascii-range character return None @@ -907,15 +990,27 @@ def prepend_scheme_if_needed(url, new_scheme): :rtype: str """ - scheme, netloc, path, params, query, fragment = urlparse(url, new_scheme) - - # urlparse is a finicky beast, and sometimes decides that there isn't a - # netloc present. Assume that it's being over-cautious, and switch netloc - # and path if urlparse decided there was no netloc. + parsed = parse_url(url) + scheme, auth, host, port, path, query, fragment = parsed + + # A defect in urlparse determines that there isn't a netloc present in some + # urls. We previously assumed parsing was overly cautious, and swapped the + # netloc and path. Due to a lack of tests on the original defect, this is + # maintained with parse_url for backwards compatibility. + netloc = parsed.netloc if not netloc: netloc, path = path, netloc - return urlunparse((scheme, netloc, path, params, query, fragment)) + if auth: + # parse_url doesn't provide the netloc with auth + # so we'll add it ourselves. + netloc = "@".join([auth, netloc]) + if scheme is None: + scheme = new_scheme + if path is None: + path = "" + + return urlunparse((scheme, netloc, path, "", query, fragment)) def get_auth_from_url(url): @@ -929,35 +1024,39 @@ def get_auth_from_url(url): try: auth = (unquote(parsed.username), unquote(parsed.password)) except (AttributeError, TypeError): - auth = ('', '') + auth = ("", "") return auth -# Moved outside of function to avoid recompile every call -_CLEAN_HEADER_REGEX_BYTE = re.compile(b'^\\S[^\\r\\n]*$|^$') -_CLEAN_HEADER_REGEX_STR = re.compile(r'^\S[^\r\n]*$|^$') - - def check_header_validity(header): - """Verifies that header value is a string which doesn't contain - leading whitespace or return characters. This prevents unintended - header injection. + """Verifies that header parts don't contain leading whitespace + reserved characters, or return characters. :param header: tuple, in the format (name, value). """ name, value = header + _validate_header_part(header, name, 0) + _validate_header_part(header, value, 1) - if isinstance(value, bytes): - pat = _CLEAN_HEADER_REGEX_BYTE + +def _validate_header_part(header, header_part, header_validator_index): + if isinstance(header_part, str): + validator = _HEADER_VALIDATORS_STR[header_validator_index] + elif isinstance(header_part, bytes): + validator = _HEADER_VALIDATORS_BYTE[header_validator_index] else: - pat = _CLEAN_HEADER_REGEX_STR - try: - if not pat.match(value): - raise InvalidHeader("Invalid return character or leading space in header: %s" % name) - except TypeError: - raise InvalidHeader("Value for header {%s: %s} must be of type str or " - "bytes, not %s" % (name, value, type(value))) + raise InvalidHeader( + f"Header part ({header_part!r}) from {header} " + f"must be of type str or bytes, not {type(header_part)}" + ) + + if not validator.match(header_part): + header_kind = "name" if header_validator_index == 0 else "value" + raise InvalidHeader( + f"Invalid leading whitespace, reserved character(s), or return" + f"character(s) in header {header_kind}: {header_part!r}" + ) def urldefragauth(url): @@ -972,21 +1071,24 @@ def urldefragauth(url): if not netloc: netloc, path = path, netloc - netloc = netloc.rsplit('@', 1)[-1] + netloc = netloc.rsplit("@", 1)[-1] - return urlunparse((scheme, netloc, path, params, query, '')) + return urlunparse((scheme, netloc, path, params, query, "")) def rewind_body(prepared_request): """Move file pointer back to its recorded starting position so it can be read again on redirect. """ - body_seek = getattr(prepared_request.body, 'seek', None) - if body_seek is not None and isinstance(prepared_request._body_position, integer_types): + body_seek = getattr(prepared_request.body, "seek", None) + if body_seek is not None and isinstance( + prepared_request._body_position, integer_types + ): try: body_seek(prepared_request._body_position) - except (IOError, OSError): - raise UnrewindableBodyError("An error occurred when rewinding request " - "body for redirect.") + except OSError: + raise UnrewindableBodyError( + "An error occurred when rewinding request body for redirect." + ) else: raise UnrewindableBodyError("Unable to rewind request body for redirect.") diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__init__.py b/env/Lib/site-packages/pip/_vendor/resolvelib/__init__.py index 184874d4..d92acc7b 100644 --- a/env/Lib/site-packages/pip/_vendor/resolvelib/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/resolvelib/__init__.py @@ -11,7 +11,7 @@ __all__ = [ "ResolutionTooDeep", ] -__version__ = "0.7.0" +__version__ = "1.0.1" from .providers import AbstractProvider, AbstractResolver @@ -19,8 +19,8 @@ from .reporters import BaseReporter from .resolvers import ( InconsistentCandidate, RequirementsConflicted, - Resolver, ResolutionError, ResolutionImpossible, ResolutionTooDeep, + Resolver, ) diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 5a268e0cfff4e1eb6cafb28063ccd8e8d5d92873..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 634 zcmYe~<>g{vU|^UdaWGYqiGkrUh=Yuo7#J8F7#J9eeHa)R(iu`17BNOKq%cM?rZA;2 z=P>0mM=|HJM6ob3q%fth<gn(lMX`a|tU2tt98ny(oKc*)Tv1%P+)>=QJW)KkyivT2 z3@L2E44UkkT(`L6<I7TuiZk=`;^S`#I3^XB6eT8?1Qg|$Wu~MSAw+^wi}Q2JQj2c! zI3*UR2Bj9{7nP(I-4gZ8OU}<L&MYoT%`0(E%uC5kNi0dd#Q|3?7L;08npu>Zo0?Zr z?3|yMmXn!WlA3ahAFQIZBr`wHwWuh+=#~gVz%#cXzqmLvDJS)oAVM@GKi?%awV;aC zK+jyy;3Xpi1A``05h!$um_cmDA{G$ER>aD{z)-{vBG^C#2Z-PV5ukAP)8xCw9v`2W zlM^3b1Ty0mX93i+#R$W0aTY;+SPV85#E1C57{Bo=8HxlzR)L6L&CXUap~b01#WATl zDVaqv{&}e`MVV!(3c3oRex6~jLBXCOj=>6^elGrguECy;F~P3BuE8O$K?-Iu0RcWS zi6*)^`RSR(C7IbVsd;5FKAA}|#hE3kx&?{J*@@|?#W4k$1^V%2sd*{+MfydM7|O{^ o(vOeN%*!l^kJl@xyv1RYo1apelWGU@Y%wS>ICxo@1sHi40d9G*Z2$lO diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-39.pyc deleted file mode 100644 index 062c18f3b7919be73adeafc1122bddc10087f147..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6554 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 diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-39.pyc deleted file mode 100644 index a31d59288bba0543ec81a1c7891ef794f7a3dc2b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2330 zcmYe~<>g{vU|^UdaWFN6m4V?gh=Yt-7#J8F7#J9eMHm<u+!<0BQW#qpQW#Sinwg^* zQ<#DoG?|l;)q~hfFg+d&3=F9ZQH&`JQA{a}QOqe!Da<VlQ7kDeDXc9FQLHI!DeNr_ zQEVw3DV!|~QS2#PDcmg#Q5-2eDZDKVQJg7!Df}%AQCukk!3>&$w|JZqi&KMA3-XIf zQj4nWT~c#W(-TWl6_Rrji;ERX@)Zh-^2;()Qj0*0^rF<_Vud2G>dd@!g|z%4g_4X^ zg`(8r{G77XBE4irkXxY`#0Ft!kXJ!|PGJmY&}6F8bxzF5Nlj5mN=?fzN<|n@T9TQc zr;wOjQks~PQ>jo~l2}wytmn6qL6h+oOL1yWS`jD^z{IZ>XRDad;?$zznADt<%%T|o zyi}K>%(7GkU4>9T&oI}ZV9yZ8U<FS<7k@w3U{A-GU{_z);1Jg!1+$od0H2sd6WyHr z^vvRt%<P!dys{Xd%%qs&%#u{yg2d$P#PrnSn1aj#{rIxfyp;SReW?F(GL!Tno=+_* z)+?yI#Q}C>W?nkTcf}yrF)&t%B8R9ROhqzS78)`jHnxz7L=BnL#N-TxqWsdl6ovdW zNFYPP2yAGv9v7Da6oh1?DrDxRq*f?o7AsVx7Uk<EB^IZq=)o2EfrCwxsfd|@f#DV_ zSS?rxLV(<Viw|sUW?p(c*iLp(w1Hg8z*r@X)lU$0$si-49%BHpvH9#Ikv>b!OF{Kl zW--W1e*Pf}$&gf&nTDQXKzbAsOB6~nGK(R>rKb>DoT`wJnwOH9m!1F*gv>OB%KTD= z^2EFnP|Aixr9xU}USdvWRU#<$=_wE!lFZ<cEMfx(XK_hlNh%~HK>=0-4o)73^^ic~ zMG8zwl)yw*MN}fuM-57N{(~e9a9|XdCMTyB7pIlx<W%aRM12tl0|NuPOW7c90F_3t zL@bQOjl@KBVlN{D1Jr@#8L4>+i7B8sP)JnBOD$I@N-ZqSEK1Ey%_~vJ%qz)9#AI2j zLUK`NNorAMB2u!pDo89!%th8_1&$z)p`hqW%t4j|#c5KiLSjKdPG)Kfh?ka`Q<7Q) zkAF~R0R>lLSz=~RVp2}3LULkWN@hx8W=U!>BCkMgEl4a%%`1Ue2vt`CDy<SrV3rmu zBqShtDIq~2u~;Dy#k!Q#g4Dc})V$<M9fkZN1;6~fRE5km41Jl!3Lu$$Xxh%tFF`Q{ z$&zA)g2dwD)D(rxJcYEP{9J{EgdkYy3oWKJG!qgKzJW$RB)#6^Ml$La8^nv~$w3Gd zyr5D55nJL&$yXjFX<(`)DiNC@r;(!6tkmQZP=%5Ri;<F4g_P1FkWf-$a&}2kVsdt7 zUOF@_uY?w3obYHt_W}>HE=45AqvkziRYW=464}`huPY$C8JeUE@=H?lN-`636pHh6 z!1)sD@*+Mg*^j*-GcPYQFI@%6ogyfK3{~K#$$g6>K0YroH#I)~7FT?HZhlH>4v5VY zA75CSm;;qzkB?8uPmYf-Vg=a-D#wdBK`c<KqzF_J6$ya2f*=B1ULgoj$yEd@z(Kee zq>O`+g^7cigN=iogPDVigBdLAr^$4SEk6kqZD2l9_=C*?8FP!n2I4+DkXfHWH3R_M ChG;DS diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-39.pyc deleted file mode 100644 index 9d6f161cfb869ef1558152154011fdc9211bdc48..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15225 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 diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-39.pyc deleted file mode 100644 index 6025f29b6d2f876eeabfd334189507ebaadc5546..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6948 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 WsCFp^iE}XVFbg;dNeajahyeh564Uem diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index f0977531d64d31c96761d816b28b8dd3c8bad8a0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 229 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>T<S< z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk zFVZhcEzZv=OU=nl(ofFMEl4cUkB`sH%PfhH*DI*J#bJ}1pHiBWY6o)TXOLe2C+t3? diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-39.pyc deleted file mode 100644 index 9f522103d7206be983e670eef634e210c2f0c811..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 403 zcmYe~<>g{vU|^UdaWHib0|Ucj5C<7^FfcGUFfcF_yD%^?q%fo~rZYt`REeZ8r7-6( z<}yVw<uXSxGctrT<SDT*q_R}nF*1N4Se_LjAIXr%WWbQZ63n2<dW+pRv7jI`FZ~ur zaB5*`YF={cOOTbCOht?g3=Bm~3=9l@nrye&<Kq)^a^mA}@h9i!<fJB-Waj4;>m?>7 zBb43Z_RKBFFDh{@D#|aq#f_wHB|{O&>0sj5L}#m*(Bjmh;+WK&l+2<S|GZR}qRg^X z1zm+uKhH4NpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>AO*9SfB>JEL=)Yd{PfJ?lFaOw z)V#77pUk9~;>?m%-GapA?8Nlc;+TTW0{!^1)V!4ZBK@M&;{2Sl)SS#D{p9@Ig2WPi lBzMIpCMD|?RNmsS$<0qG%}KQbdAS(mR1PL4MiE9HMgV7BY~TO@ diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/providers.py b/env/Lib/site-packages/pip/_vendor/resolvelib/providers.py index 4822d166..e99d87ee 100644 --- a/env/Lib/site-packages/pip/_vendor/resolvelib/providers.py +++ b/env/Lib/site-packages/pip/_vendor/resolvelib/providers.py @@ -1,5 +1,5 @@ class AbstractProvider(object): - """Delegate class to provide requirement interface for the resolver.""" + """Delegate class to provide the required interface for the resolver.""" def identify(self, requirement_or_candidate): """Given a requirement, return an identifier for it. @@ -9,7 +9,14 @@ class AbstractProvider(object): """ raise NotImplementedError - def get_preference(self, identifier, resolutions, candidates, information): + def get_preference( + self, + identifier, + resolutions, + candidates, + information, + backtrack_causes, + ): """Produce a sort key for given requirement based on preference. The preference is defined as "I think this requirement should be @@ -17,23 +24,25 @@ class AbstractProvider(object): this group of arguments is. :param identifier: An identifier as returned by ``identify()``. This - identifies the dependency matches of which should be returned. + identifies the dependency matches which should be returned. :param resolutions: Mapping of candidates currently pinned by the - resolver. Each key is an identifier, and the value a candidate. + resolver. Each key is an identifier, and the value is a candidate. The candidate may conflict with requirements from ``information``. :param candidates: Mapping of each dependency's possible candidates. Each value is an iterator of candidates. :param information: Mapping of requirement information of each package. Each value is an iterator of *requirement information*. + :param backtrack_causes: Sequence of requirement information that were + the requirements that caused the resolver to most recently backtrack. A *requirement information* instance is a named tuple with two members: * ``requirement`` specifies a requirement contributing to the current list of candidates. - * ``parent`` specifies the candidate that provides (dependend on) the + * ``parent`` specifies the candidate that provides (depended on) the requirement, or ``None`` to indicate a root requirement. - The preference could depend on a various of issues, including (not + The preference could depend on various issues, including (not necessarily in this order): * Is this package pinned in the current resolution result? @@ -52,7 +61,7 @@ class AbstractProvider(object): raise NotImplementedError def find_matches(self, identifier, requirements, incompatibilities): - """Find all possible candidates that satisfy given constraints. + """Find all possible candidates that satisfy the given constraints. :param identifier: An identifier as returned by ``identify()``. This identifies the dependency matches of which should be returned. @@ -83,7 +92,7 @@ class AbstractProvider(object): def is_satisfied_by(self, requirement, candidate): """Whether the given requirement can be satisfied by a candidate. - The candidate is guarenteed to have been generated from the + The candidate is guaranteed to have been generated from the requirement. A boolean should be returned to indicate whether ``candidate`` is a diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/reporters.py b/env/Lib/site-packages/pip/_vendor/resolvelib/reporters.py index 563489e1..688b5e10 100644 --- a/env/Lib/site-packages/pip/_vendor/resolvelib/reporters.py +++ b/env/Lib/site-packages/pip/_vendor/resolvelib/reporters.py @@ -30,7 +30,13 @@ class BaseReporter(object): requirements passed in from ``Resolver.resolve()``. """ - def backtracking(self, candidate): + def resolving_conflicts(self, causes): + """Called when starting to attempt requirement conflict resolution. + + :param causes: The information on the collision that caused the backtracking. + """ + + def rejecting_candidate(self, criterion, candidate): """Called when rejecting a candidate during backtracking.""" def pinning(self, candidate): diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py b/env/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py index 99ee1051..2c3d0e30 100644 --- a/env/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py +++ b/env/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py @@ -1,10 +1,10 @@ import collections +import itertools import operator from .providers import AbstractResolver from .structs import DirectedGraph, IteratorMapping, build_iter_view - RequirementInformation = collections.namedtuple( "RequirementInformation", ["requirement", "parent"] ) @@ -99,7 +99,7 @@ class ResolutionTooDeep(ResolutionError): # Resolution state in a round. -State = collections.namedtuple("State", "mapping criteria") +State = collections.namedtuple("State", "mapping criteria backtrack_causes") class Resolution(object): @@ -131,14 +131,15 @@ class Resolution(object): state = State( mapping=base.mapping.copy(), criteria=base.criteria.copy(), + backtrack_causes=base.backtrack_causes[:], ) self._states.append(state) - def _merge_into_criterion(self, requirement, parent): + def _add_to_criteria(self, criteria, requirement, parent): self._r.adding_requirement(requirement=requirement, parent=parent) identifier = self._p.identify(requirement_or_candidate=requirement) - criterion = self.state.criteria.get(identifier) + criterion = criteria.get(identifier) if criterion: incompatibilities = list(criterion.incompatibilities) else: @@ -147,12 +148,12 @@ class Resolution(object): matches = self._p.find_matches( identifier=identifier, requirements=IteratorMapping( - self.state.criteria, + criteria, operator.methodcaller("iter_requirement"), {identifier: [requirement]}, ), incompatibilities=IteratorMapping( - self.state.criteria, + criteria, operator.attrgetter("incompatibilities"), {identifier: incompatibilities}, ), @@ -171,7 +172,32 @@ class Resolution(object): ) if not criterion.candidates: raise RequirementsConflicted(criterion) - return identifier, criterion + criteria[identifier] = criterion + + def _remove_information_from_criteria(self, criteria, parents): + """Remove information from parents of criteria. + + Concretely, removes all values from each criterion's ``information`` + field that have one of ``parents`` as provider of the requirement. + + :param criteria: The criteria to update. + :param parents: Identifiers for which to remove information from all criteria. + """ + if not parents: + return + for key, criterion in criteria.items(): + criteria[key] = Criterion( + criterion.candidates, + [ + information + for information in criterion.information + if ( + information.parent is None + or self._p.identify(information.parent) not in parents + ) + ], + criterion.incompatibilities, + ) def _get_preference(self, name): return self._p.get_preference( @@ -185,6 +211,7 @@ class Resolution(object): self.state.criteria, operator.attrgetter("information"), ), + backtrack_causes=self.state.backtrack_causes, ) def _is_current_pin_satisfying(self, name, criterion): @@ -197,11 +224,10 @@ class Resolution(object): for r in criterion.iter_requirement() ) - def _get_criteria_to_update(self, candidate): - criteria = {} - for r in self._p.get_dependencies(candidate=candidate): - name, crit = self._merge_into_criterion(r, parent=candidate) - criteria[name] = crit + def _get_updated_criteria(self, candidate): + criteria = self.state.criteria.copy() + for requirement in self._p.get_dependencies(candidate=candidate): + self._add_to_criteria(criteria, requirement, parent=candidate) return criteria def _attempt_to_pin_criterion(self, name): @@ -210,8 +236,9 @@ class Resolution(object): causes = [] for candidate in criterion.candidates: try: - criteria = self._get_criteria_to_update(candidate) + criteria = self._get_updated_criteria(candidate) except RequirementsConflicted as e: + self._r.rejecting_candidate(e.criterion, candidate) causes.append(e.criterion) continue @@ -226,12 +253,13 @@ class Resolution(object): if not satisfied: raise InconsistentCandidate(candidate, criterion) + self._r.pinning(candidate=candidate) + self.state.criteria.update(criteria) + # Put newly-pinned candidate at the end. This is essential because # backtracking looks at this mapping to get the last pin. - self._r.pinning(candidate=candidate) self.state.mapping.pop(name, None) self.state.mapping[name] = candidate - self.state.criteria.update(criteria) return [] @@ -239,8 +267,8 @@ class Resolution(object): # end, signal for backtracking. return causes - def _backtrack(self): - """Perform backtracking. + def _backjump(self, causes): + """Perform backjumping. When we enter here, the stack is like this:: @@ -256,22 +284,46 @@ class Resolution(object): Each iteration of the loop will: - 1. Discard Z. - 2. Discard Y but remember its incompatibility information gathered + 1. Identify Z. The incompatibility is not always caused by the latest + state. For example, given three requirements A, B and C, with + dependencies A1, B1 and C1, where A1 and B1 are incompatible: the + last state might be related to C, so we want to discard the + previous state. + 2. Discard Z. + 3. Discard Y but remember its incompatibility information gathered previously, and the failure we're dealing with right now. - 3. Push a new state Y' based on X, and apply the incompatibility + 4. Push a new state Y' based on X, and apply the incompatibility information from Y to Y'. - 4a. If this causes Y' to conflict, we need to backtrack again. Make Y' + 5a. If this causes Y' to conflict, we need to backtrack again. Make Y' the new Z and go back to step 2. - 4b. If the incompatibilities apply cleanly, end backtracking. + 5b. If the incompatibilities apply cleanly, end backtracking. """ + incompatible_reqs = itertools.chain( + (c.parent for c in causes if c.parent is not None), + (c.requirement for c in causes), + ) + incompatible_deps = {self._p.identify(r) for r in incompatible_reqs} while len(self._states) >= 3: # Remove the state that triggered backtracking. del self._states[-1] - # Retrieve the last candidate pin and known incompatibilities. - broken_state = self._states.pop() - name, candidate = broken_state.mapping.popitem() + # Ensure to backtrack to a state that caused the incompatibility + incompatible_state = False + while not incompatible_state: + # Retrieve the last candidate pin and known incompatibilities. + try: + broken_state = self._states.pop() + name, candidate = broken_state.mapping.popitem() + except (IndexError, KeyError): + raise ResolutionImpossible(causes) + current_dependencies = { + self._p.identify(d) + for d in self._p.get_dependencies(candidate) + } + incompatible_state = not current_dependencies.isdisjoint( + incompatible_deps + ) + incompatibilities_from_broken = [ (k, list(v.incompatibilities)) for k, v in broken_state.criteria.items() @@ -280,8 +332,6 @@ class Resolution(object): # Also mark the newly known incompatibility. incompatibilities_from_broken.append((name, [candidate])) - self._r.backtracking(candidate=candidate) - # Create a new state from the last known-to-work one, and apply # the previously gathered incompatibility information. def _patch_criteria(): @@ -335,13 +385,18 @@ class Resolution(object): self._r.starting() # Initialize the root state. - self._states = [State(mapping=collections.OrderedDict(), criteria={})] + self._states = [ + State( + mapping=collections.OrderedDict(), + criteria={}, + backtrack_causes=[], + ) + ] for r in requirements: try: - name, crit = self._merge_into_criterion(r, parent=None) + self._add_to_criteria(self.state.criteria, r, parent=None) except RequirementsConflicted as e: raise ResolutionImpossible(e.criterion.information) - self.state.criteria[name] = crit # The root state is saved as a sentinel so the first ever pin can have # something to backtrack to if it fails. The root state is basically @@ -362,20 +417,38 @@ class Resolution(object): self._r.ending(state=self.state) return self.state + # keep track of satisfied names to calculate diff after pinning + satisfied_names = set(self.state.criteria.keys()) - set( + unsatisfied_names + ) + # Choose the most preferred unpinned criterion to try. name = min(unsatisfied_names, key=self._get_preference) failure_causes = self._attempt_to_pin_criterion(name) if failure_causes: - # Backtrack if pinning fails. The backtrack process puts us in + causes = [i for c in failure_causes for i in c.information] + # Backjump if pinning fails. The backjump process puts us in # an unpinned state, so we can work on it in the next round. - success = self._backtrack() + self._r.resolving_conflicts(causes=causes) + success = self._backjump(causes) + self.state.backtrack_causes[:] = causes # Dead ends everywhere. Give up. if not success: - causes = [i for c in failure_causes for i in c.information] - raise ResolutionImpossible(causes) + raise ResolutionImpossible(self.state.backtrack_causes) else: + # discard as information sources any invalidated names + # (unsatisfied names that were previously satisfied) + newly_unsatisfied_names = { + key + for key, criterion in self.state.criteria.items() + if key in satisfied_names + and not self._is_current_pin_satisfying(key, criterion) + } + self._remove_information_from_criteria( + self.state.criteria, newly_unsatisfied_names + ) # Pinning was successful. Push a new state to do another pin. self._push_new_state() diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/structs.py b/env/Lib/site-packages/pip/_vendor/resolvelib/structs.py index e1e7aa42..359a34f6 100644 --- a/env/Lib/site-packages/pip/_vendor/resolvelib/structs.py +++ b/env/Lib/site-packages/pip/_vendor/resolvelib/structs.py @@ -75,6 +75,18 @@ class IteratorMapping(collections_abc.Mapping): self._accessor = accessor self._appends = appends or {} + def __repr__(self): + return "IteratorMapping({!r}, {!r}, {!r})".format( + self._mapping, + self._accessor, + self._appends, + ) + + def __bool__(self): + return bool(self._mapping or self._appends) + + __nonzero__ = __bool__ # XXX: Python 2. + def __contains__(self, key): return key in self._mapping or key in self._appends @@ -90,7 +102,7 @@ class IteratorMapping(collections_abc.Mapping): return itertools.chain(self._mapping, more) def __len__(self): - more = len(k for k in self._appends if k not in self._mapping) + more = sum(1 for k in self._appends if k not in self._mapping) return len(self._mapping) + more @@ -105,13 +117,14 @@ class _FactoryIterableView(object): def __init__(self, factory): self._factory = factory + self._iterable = None def __repr__(self): - return "{}({})".format(type(self).__name__, list(self._factory())) + return "{}({})".format(type(self).__name__, list(self)) def __bool__(self): try: - next(self._factory()) + next(iter(self)) except StopIteration: return False return True @@ -119,7 +132,11 @@ class _FactoryIterableView(object): __nonzero__ = __bool__ # XXX: Python 2. def __iter__(self): - return self._factory() + iterable = ( + self._factory() if self._iterable is None else self._iterable + ) + self._iterable, current = itertools.tee(iterable) + return current class _SequenceIterableView(object): diff --git a/env/Lib/site-packages/pip/_vendor/six.py b/env/Lib/site-packages/pip/_vendor/six.py index 83f69783..4e15675d 100644 --- a/env/Lib/site-packages/pip/_vendor/six.py +++ b/env/Lib/site-packages/pip/_vendor/six.py @@ -29,7 +29,7 @@ import sys import types __author__ = "Benjamin Peterson <benjamin@python.org>" -__version__ = "1.15.0" +__version__ = "1.16.0" # Useful for very coarse version differentiation. @@ -71,6 +71,11 @@ else: MAXSIZE = int((1 << 63) - 1) del X +if PY34: + from importlib.util import spec_from_loader +else: + spec_from_loader = None + def _add_doc(func, doc): """Add documentation to a function.""" @@ -186,6 +191,11 @@ class _SixMetaPathImporter(object): return self return None + def find_spec(self, fullname, path, target=None): + if fullname in self.known_modules: + return spec_from_loader(fullname, self) + return None + def __get_module(self, fullname): try: return self.known_modules[fullname] @@ -223,6 +233,12 @@ class _SixMetaPathImporter(object): return None get_source = get_code # same as get_code + def create_module(self, spec): + return self.load_module(spec.name) + + def exec_module(self, module): + pass + _importer = _SixMetaPathImporter(__name__) diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__init__.py b/env/Lib/site-packages/pip/_vendor/tenacity/__init__.py index 42e9d894..4f1603ad 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/__init__.py @@ -1,4 +1,3 @@ -# -*- coding: utf-8 -*- # Copyright 2016-2018 Julien Danjou # Copyright 2017 Elisey Zanko # Copyright 2016 Étienne Bersac @@ -17,29 +16,16 @@ # See the License for the specific language governing permissions and # limitations under the License. -try: - from inspect import iscoroutinefunction -except ImportError: - iscoroutinefunction = None - -# Replace a conditional import with a hard-coded None so that pip does -# not attempt to use tornado even if it is present in the environment. -# If tornado is non-None, tenacity will attempt to execute some code -# that is sensitive to the version of tornado, which could break pip -# if an old version is found. -tornado = None +import functools import sys import threading +import time import typing as t import warnings -from abc import ABCMeta, abstractmethod +from abc import ABC, abstractmethod from concurrent import futures - - -from pip._vendor import six - -from pip._vendor.tenacity import _utils +from inspect import iscoroutinefunction # Import all built-in retry strategies for easier usage. from .retry import retry_base # noqa @@ -48,6 +34,8 @@ from .retry import retry_always # noqa from .retry import retry_any # noqa from .retry import retry_if_exception # noqa from .retry import retry_if_exception_type # noqa +from .retry import retry_if_exception_cause_type # noqa +from .retry import retry_if_not_exception_type # noqa from .retry import retry_if_not_result # noqa from .retry import retry_if_result # noqa from .retry import retry_never # noqa @@ -77,6 +65,7 @@ from .wait import wait_none # noqa from .wait import wait_random # noqa from .wait import wait_random_exponential # noqa from .wait import wait_random_exponential as wait_full_jitter # noqa +from .wait import wait_exponential_jitter # noqa # Import all built-in before strategies for easier usage. from .before import before_log # noqa @@ -90,58 +79,23 @@ from .after import after_nothing # noqa from .before_sleep import before_sleep_log # noqa from .before_sleep import before_sleep_nothing # noqa +# Replace a conditional import with a hard-coded None so that pip does +# not attempt to use tornado even if it is present in the environment. +# If tornado is non-None, tenacity will attempt to execute some code +# that is sensitive to the version of tornado, which could break pip +# if an old version is found. +tornado = None # type: ignore -WrappedFn = t.TypeVar("WrappedFn", bound=t.Callable) - - -@t.overload -def retry(fn): - # type: (WrappedFn) -> WrappedFn - """Type signature for @retry as a raw decorator.""" - pass - - -@t.overload -def retry(*dargs, **dkw): # noqa - # type: (...) -> t.Callable[[WrappedFn], WrappedFn] - """Type signature for the @retry() decorator constructor.""" - pass - - -def retry(*dargs, **dkw): # noqa - """Wrap a function with a new `Retrying` object. - - :param dargs: positional arguments passed to Retrying object - :param dkw: keyword arguments passed to the Retrying object - """ - # support both @retry and @retry() as valid syntax - if len(dargs) == 1 and callable(dargs[0]): - return retry()(dargs[0]) - else: +if t.TYPE_CHECKING: + import types - def wrap(f): - if isinstance(f, retry_base): - warnings.warn( - ( - "Got retry_base instance ({cls}) as callable argument, " - + "this will probably hang indefinitely (did you mean " - + "retry={cls}(...)?)" - ).format(cls=f.__class__.__name__) - ) - if iscoroutinefunction is not None and iscoroutinefunction(f): - r = AsyncRetrying(*dargs, **dkw) - elif ( - tornado - and hasattr(tornado.gen, "is_coroutine_function") - and tornado.gen.is_coroutine_function(f) - ): - r = TornadoRetrying(*dargs, **dkw) - else: - r = Retrying(*dargs, **dkw) + from .retry import RetryBaseT + from .stop import StopBaseT + from .wait import WaitBaseT - return r.wraps(f) - return wrap +WrappedFnReturnT = t.TypeVar("WrappedFnReturnT") +WrappedFn = t.TypeVar("WrappedFn", bound=t.Callable[..., t.Any]) class TryAgain(Exception): @@ -151,7 +105,7 @@ class TryAgain(Exception): NO_RESULT = object() -class DoAttempt(object): +class DoAttempt: pass @@ -159,25 +113,23 @@ class DoSleep(float): pass -class BaseAction(object): +class BaseAction: """Base class for representing actions to take by retry object. Concrete implementations must define: - __init__: to initialize all necessary fields - - REPR_ATTRS: class variable specifying attributes to include in repr(self) + - REPR_FIELDS: class variable specifying attributes to include in repr(self) - NAME: for identification in retry object methods and callbacks """ - REPR_FIELDS = () - NAME = None + REPR_FIELDS: t.Sequence[str] = () + NAME: t.Optional[str] = None - def __repr__(self): - state_str = ", ".join( - "%s=%r" % (field, getattr(self, field)) for field in self.REPR_FIELDS - ) - return "%s(%s)" % (type(self).__name__, state_str) + def __repr__(self) -> str: + state_str = ", ".join(f"{field}={getattr(self, field)!r}" for field in self.REPR_FIELDS) + return f"{self.__class__.__name__}({state_str})" - def __str__(self): + def __str__(self) -> str: return repr(self) @@ -185,66 +137,70 @@ class RetryAction(BaseAction): REPR_FIELDS = ("sleep",) NAME = "retry" - def __init__(self, sleep): + def __init__(self, sleep: t.SupportsFloat) -> None: self.sleep = float(sleep) _unset = object() -def _first_set(first, second): +def _first_set(first: t.Union[t.Any, object], second: t.Any) -> t.Any: return second if first is _unset else first class RetryError(Exception): """Encapsulates the last attempt instance right before giving up.""" - def __init__(self, last_attempt): + def __init__(self, last_attempt: "Future") -> None: self.last_attempt = last_attempt - super(RetryError, self).__init__(last_attempt) + super().__init__(last_attempt) - def reraise(self): + def reraise(self) -> "t.NoReturn": if self.last_attempt.failed: raise self.last_attempt.result() raise self - def __str__(self): - return "{0}[{1}]".format(self.__class__.__name__, self.last_attempt) + def __str__(self) -> str: + return f"{self.__class__.__name__}[{self.last_attempt}]" -class AttemptManager(object): +class AttemptManager: """Manage attempt context.""" - def __init__(self, retry_state): + def __init__(self, retry_state: "RetryCallState"): self.retry_state = retry_state - def __enter__(self): + def __enter__(self) -> None: pass - def __exit__(self, exc_type, exc_value, traceback): - if isinstance(exc_value, BaseException): + def __exit__( + self, + exc_type: t.Optional[t.Type[BaseException]], + exc_value: t.Optional[BaseException], + traceback: t.Optional["types.TracebackType"], + ) -> t.Optional[bool]: + if exc_type is not None and exc_value is not None: self.retry_state.set_exception((exc_type, exc_value, traceback)) return True # Swallow exception. else: # We don't have the result, actually. self.retry_state.set_result(None) + return None -class BaseRetrying(object): - __metaclass__ = ABCMeta - +class BaseRetrying(ABC): def __init__( self, - sleep=sleep, - stop=stop_never, - wait=wait_none(), - retry=retry_if_exception_type(), - before=before_nothing, - after=after_nothing, - before_sleep=None, - reraise=False, - retry_error_cls=RetryError, - retry_error_callback=None, + sleep: t.Callable[[t.Union[int, float]], None] = sleep, + stop: "StopBaseT" = stop_never, + wait: "WaitBaseT" = wait_none(), + retry: "RetryBaseT" = retry_if_exception_type(), + before: t.Callable[["RetryCallState"], None] = before_nothing, + after: t.Callable[["RetryCallState"], None] = after_nothing, + before_sleep: t.Optional[t.Callable[["RetryCallState"], None]] = None, + reraise: bool = False, + retry_error_cls: t.Type[RetryError] = RetryError, + retry_error_callback: t.Optional[t.Callable[["RetryCallState"], t.Any]] = None, ): self.sleep = sleep self.stop = stop @@ -258,23 +214,19 @@ class BaseRetrying(object): self.retry_error_cls = retry_error_cls self.retry_error_callback = retry_error_callback - # This attribute was moved to RetryCallState and is deprecated on - # Retrying objects but kept for backward compatibility. - self.fn = None - def copy( self, - sleep=_unset, - stop=_unset, - wait=_unset, - retry=_unset, - before=_unset, - after=_unset, - before_sleep=_unset, - reraise=_unset, - retry_error_cls=_unset, - retry_error_callback=_unset, - ): + sleep: t.Union[t.Callable[[t.Union[int, float]], None], object] = _unset, + stop: t.Union["StopBaseT", object] = _unset, + wait: t.Union["WaitBaseT", object] = _unset, + retry: t.Union[retry_base, object] = _unset, + before: t.Union[t.Callable[["RetryCallState"], None], object] = _unset, + after: t.Union[t.Callable[["RetryCallState"], None], object] = _unset, + before_sleep: t.Union[t.Optional[t.Callable[["RetryCallState"], None]], object] = _unset, + reraise: t.Union[bool, object] = _unset, + retry_error_cls: t.Union[t.Type[RetryError], object] = _unset, + retry_error_callback: t.Union[t.Optional[t.Callable[["RetryCallState"], t.Any]], object] = _unset, + ) -> "BaseRetrying": """Copy this object with some parameters changed if needed.""" return self.__class__( sleep=_first_set(sleep, self.sleep), @@ -286,24 +238,22 @@ class BaseRetrying(object): before_sleep=_first_set(before_sleep, self.before_sleep), reraise=_first_set(reraise, self.reraise), retry_error_cls=_first_set(retry_error_cls, self.retry_error_cls), - retry_error_callback=_first_set( - retry_error_callback, self.retry_error_callback - ), + retry_error_callback=_first_set(retry_error_callback, self.retry_error_callback), ) - def __repr__(self): - attrs = dict( - _utils.visible_attrs(self, attrs={"me": id(self)}), - __class__=self.__class__.__name__, - ) + def __repr__(self) -> str: return ( - "<%(__class__)s object at 0x%(me)x (stop=%(stop)s, " - "wait=%(wait)s, sleep=%(sleep)s, retry=%(retry)s, " - "before=%(before)s, after=%(after)s)>" - ) % (attrs) + f"<{self.__class__.__name__} object at 0x{id(self):x} (" + f"stop={self.stop}, " + f"wait={self.wait}, " + f"sleep={self.sleep}, " + f"retry={self.retry}, " + f"before={self.before}, " + f"after={self.after})>" + ) @property - def statistics(self): + def statistics(self) -> t.Dict[str, t.Any]: """Return a dictionary of runtime statistics. This dictionary will be empty when the controller has never been @@ -325,63 +275,60 @@ class BaseRetrying(object): statistics from each thread). """ try: - return self._local.statistics + return self._local.statistics # type: ignore[no-any-return] except AttributeError: - self._local.statistics = {} + self._local.statistics = t.cast(t.Dict[str, t.Any], {}) return self._local.statistics - def wraps(self, f): + def wraps(self, f: WrappedFn) -> WrappedFn: """Wrap a function for retrying. :param f: A function to wraps for retrying. """ - @_utils.wraps(f) - def wrapped_f(*args, **kw): + @functools.wraps(f) + def wrapped_f(*args: t.Any, **kw: t.Any) -> t.Any: return self(f, *args, **kw) - def retry_with(*args, **kwargs): + def retry_with(*args: t.Any, **kwargs: t.Any) -> WrappedFn: return self.copy(*args, **kwargs).wraps(f) - wrapped_f.retry = self - wrapped_f.retry_with = retry_with + wrapped_f.retry = self # type: ignore[attr-defined] + wrapped_f.retry_with = retry_with # type: ignore[attr-defined] - return wrapped_f + return wrapped_f # type: ignore[return-value] - def begin(self, fn): + def begin(self) -> None: self.statistics.clear() - self.statistics["start_time"] = _utils.now() + self.statistics["start_time"] = time.monotonic() self.statistics["attempt_number"] = 1 self.statistics["idle_for"] = 0 - self.fn = fn - def iter(self, retry_state): # noqa + def iter(self, retry_state: "RetryCallState") -> t.Union[DoAttempt, DoSleep, t.Any]: # noqa fut = retry_state.outcome if fut is None: if self.before is not None: self.before(retry_state) return DoAttempt() - is_explicit_retry = retry_state.outcome.failed and isinstance( - retry_state.outcome.exception(), TryAgain - ) - if not (is_explicit_retry or self.retry(retry_state=retry_state)): + is_explicit_retry = fut.failed and isinstance(fut.exception(), TryAgain) + if not (is_explicit_retry or self.retry(retry_state)): return fut.result() if self.after is not None: - self.after(retry_state=retry_state) + self.after(retry_state) self.statistics["delay_since_first_attempt"] = retry_state.seconds_since_start - if self.stop(retry_state=retry_state): + if self.stop(retry_state): if self.retry_error_callback: - return self.retry_error_callback(retry_state=retry_state) + return self.retry_error_callback(retry_state) retry_exc = self.retry_error_cls(fut) if self.reraise: raise retry_exc.reraise() - six.raise_from(retry_exc, fut.exception()) + raise retry_exc from fut.exception() if self.wait: - sleep = self.wait(retry_state=retry_state) + sleep = self.wait(retry_state) else: sleep = 0.0 retry_state.next_action = RetryAction(sleep) @@ -390,12 +337,12 @@ class BaseRetrying(object): self.statistics["attempt_number"] += 1 if self.before_sleep is not None: - self.before_sleep(retry_state=retry_state) + self.before_sleep(retry_state) return DoSleep(sleep) - def __iter__(self): - self.begin(None) + def __iter__(self) -> t.Generator[AttemptManager, None, None]: + self.begin() retry_state = RetryCallState(self, fn=None, args=(), kwargs={}) while True: @@ -409,23 +356,25 @@ class BaseRetrying(object): break @abstractmethod - def __call__(self, *args, **kwargs): + def __call__( + self, + fn: t.Callable[..., WrappedFnReturnT], + *args: t.Any, + **kwargs: t.Any, + ) -> WrappedFnReturnT: pass - def call(self, *args, **kwargs): - """Use ``__call__`` instead because this method is deprecated.""" - warnings.warn( - "'call()' method is deprecated. " + "Use '__call__()' instead", - DeprecationWarning, - ) - return self.__call__(*args, **kwargs) - class Retrying(BaseRetrying): """Retrying controller.""" - def __call__(self, fn, *args, **kwargs): - self.begin(fn) + def __call__( + self, + fn: t.Callable[..., WrappedFnReturnT], + *args: t.Any, + **kwargs: t.Any, + ) -> WrappedFnReturnT: + self.begin() retry_state = RetryCallState(retry_object=self, fn=fn, args=args, kwargs=kwargs) while True: @@ -434,30 +383,36 @@ class Retrying(BaseRetrying): try: result = fn(*args, **kwargs) except BaseException: # noqa: B902 - retry_state.set_exception(sys.exc_info()) + retry_state.set_exception(sys.exc_info()) # type: ignore[arg-type] else: retry_state.set_result(result) elif isinstance(do, DoSleep): retry_state.prepare_for_next_attempt() self.sleep(do) else: - return do + return do # type: ignore[no-any-return] -class Future(futures.Future): +if sys.version_info[1] >= 9: + FutureGenericT = futures.Future[t.Any] +else: + FutureGenericT = futures.Future + + +class Future(FutureGenericT): """Encapsulates a (future or past) attempted call to a target function.""" - def __init__(self, attempt_number): - super(Future, self).__init__() + def __init__(self, attempt_number: int) -> None: + super().__init__() self.attempt_number = attempt_number @property - def failed(self): + def failed(self) -> bool: """Return whether a exception is being held in this future.""" return self.exception() is not None @classmethod - def construct(cls, attempt_number, value, has_exception): + def construct(cls, attempt_number: int, value: t.Any, has_exception: bool) -> "Future": """Construct a new Future object.""" fut = cls(attempt_number) if has_exception: @@ -467,12 +422,18 @@ class Future(futures.Future): return fut -class RetryCallState(object): +class RetryCallState: """State related to a single call wrapped with Retrying.""" - def __init__(self, retry_object, fn, args, kwargs): + def __init__( + self, + retry_object: BaseRetrying, + fn: t.Optional[WrappedFn], + args: t.Any, + kwargs: t.Any, + ) -> None: #: Retry call start timestamp - self.start_time = _utils.now() + self.start_time = time.monotonic() #: Retry manager object self.retry_object = retry_object #: Function wrapped by this retry call @@ -483,43 +444,165 @@ class RetryCallState(object): self.kwargs = kwargs #: The number of the current attempt - self.attempt_number = 1 + self.attempt_number: int = 1 #: Last outcome (result or exception) produced by the function - self.outcome = None + self.outcome: t.Optional[Future] = None #: Timestamp of the last outcome - self.outcome_timestamp = None + self.outcome_timestamp: t.Optional[float] = None #: Time spent sleeping in retries - self.idle_for = 0 + self.idle_for: float = 0.0 #: Next action as decided by the retry manager - self.next_action = None + self.next_action: t.Optional[RetryAction] = None @property - def seconds_since_start(self): + def seconds_since_start(self) -> t.Optional[float]: if self.outcome_timestamp is None: return None return self.outcome_timestamp - self.start_time - def prepare_for_next_attempt(self): + def prepare_for_next_attempt(self) -> None: self.outcome = None self.outcome_timestamp = None self.attempt_number += 1 self.next_action = None - def set_result(self, val): - ts = _utils.now() + def set_result(self, val: t.Any) -> None: + ts = time.monotonic() fut = Future(self.attempt_number) fut.set_result(val) self.outcome, self.outcome_timestamp = fut, ts - def set_exception(self, exc_info): - ts = _utils.now() + def set_exception( + self, exc_info: t.Tuple[t.Type[BaseException], BaseException, "types.TracebackType| None"] + ) -> None: + ts = time.monotonic() fut = Future(self.attempt_number) - _utils.capture(fut, exc_info) + fut.set_exception(exc_info[1]) self.outcome, self.outcome_timestamp = fut, ts + def __repr__(self) -> str: + if self.outcome is None: + result = "none yet" + elif self.outcome.failed: + exception = self.outcome.exception() + result = f"failed ({exception.__class__.__name__} {exception})" + else: + result = f"returned {self.outcome.result()}" + + slept = float(round(self.idle_for, 2)) + clsname = self.__class__.__name__ + return f"<{clsname} {id(self)}: attempt #{self.attempt_number}; slept for {slept}; last result: {result}>" + + +@t.overload +def retry(func: WrappedFn) -> WrappedFn: + ... + + +@t.overload +def retry( + sleep: t.Callable[[t.Union[int, float]], None] = sleep, + stop: "StopBaseT" = stop_never, + wait: "WaitBaseT" = wait_none(), + retry: "RetryBaseT" = retry_if_exception_type(), + before: t.Callable[["RetryCallState"], None] = before_nothing, + after: t.Callable[["RetryCallState"], None] = after_nothing, + before_sleep: t.Optional[t.Callable[["RetryCallState"], None]] = None, + reraise: bool = False, + retry_error_cls: t.Type["RetryError"] = RetryError, + retry_error_callback: t.Optional[t.Callable[["RetryCallState"], t.Any]] = None, +) -> t.Callable[[WrappedFn], WrappedFn]: + ... + + +def retry(*dargs: t.Any, **dkw: t.Any) -> t.Any: + """Wrap a function with a new `Retrying` object. + + :param dargs: positional arguments passed to Retrying object + :param dkw: keyword arguments passed to the Retrying object + """ + # support both @retry and @retry() as valid syntax + if len(dargs) == 1 and callable(dargs[0]): + return retry()(dargs[0]) + else: + + def wrap(f: WrappedFn) -> WrappedFn: + if isinstance(f, retry_base): + warnings.warn( + f"Got retry_base instance ({f.__class__.__name__}) as callable argument, " + f"this will probably hang indefinitely (did you mean retry={f.__class__.__name__}(...)?)" + ) + r: "BaseRetrying" + if iscoroutinefunction(f): + r = AsyncRetrying(*dargs, **dkw) + elif tornado and hasattr(tornado.gen, "is_coroutine_function") and tornado.gen.is_coroutine_function(f): + r = TornadoRetrying(*dargs, **dkw) + else: + r = Retrying(*dargs, **dkw) + + return r.wraps(f) + + return wrap -if iscoroutinefunction: - from pip._vendor.tenacity._asyncio import AsyncRetrying + +from pip._vendor.tenacity._asyncio import AsyncRetrying # noqa:E402,I100 if tornado: from pip._vendor.tenacity.tornadoweb import TornadoRetrying + + +__all__ = [ + "retry_base", + "retry_all", + "retry_always", + "retry_any", + "retry_if_exception", + "retry_if_exception_type", + "retry_if_exception_cause_type", + "retry_if_not_exception_type", + "retry_if_not_result", + "retry_if_result", + "retry_never", + "retry_unless_exception_type", + "retry_if_exception_message", + "retry_if_not_exception_message", + "sleep", + "sleep_using_event", + "stop_after_attempt", + "stop_after_delay", + "stop_all", + "stop_any", + "stop_never", + "stop_when_event_set", + "wait_chain", + "wait_combine", + "wait_exponential", + "wait_fixed", + "wait_incrementing", + "wait_none", + "wait_random", + "wait_random_exponential", + "wait_full_jitter", + "wait_exponential_jitter", + "before_log", + "before_nothing", + "after_log", + "after_nothing", + "before_sleep_log", + "before_sleep_nothing", + "retry", + "WrappedFn", + "TryAgain", + "NO_RESULT", + "DoAttempt", + "DoSleep", + "BaseAction", + "RetryAction", + "RetryError", + "AttemptManager", + "BaseRetrying", + "Retrying", + "Future", + "RetryCallState", + "AsyncRetrying", +] diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 001b1a7fa9d35d4dfdb92f3bff67d39437251949..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14706 zcmYe~<>g{vU|^UdaWHk7BLl-@5C<7^FfcGUFfcF_yD>8`R0*Uoq%h_%<T6GvGBSiS z<cYB`q%u{iF*1N)3R4tgBtssP0YeH?6mtqg3R4bC6bqPUjba7UY*FlBnj?xMg&~DG zhclNeiYu2pikp!kg&~C{hbNaeiWkgg&Ed=CkKzZj*>VJO1)~HR8B*9&IC6w?g`<SQ zY|b2^T#+adFq<n!C|5K}6wKz%5y};d5(Be&a)fflqr|~%-W;J^i6{v$n=eNwS29Wx z%;wJ#%9V<e0<#5jgmR^$q`_>#9HCs9C>bzYC`Tw)HcA%E7S0jMm5Y)Cvqf^`a}}Z# zz--YR`CP>)MKD_|M=4i1N*T-+&r!-%iBbWxC32K<RijkFY{?v@T(u}QFk31|DOWv8 z9n6-_QOebb(g3q%ax`<bqO`zl*&NMW?I>+9TP{a4S0_pb%$Cp5%+-z31+x`$G;{T$ z^uTPz9L-$)D19(nDMvHcAj$yDR?gAPHH<PuVjF?kDmlivCQ&9}wrY-Xu4$Ahn5~v$ zmTMkm4rZ(8nB`hTS%BFZIhMIrQC48KW{zd9b(A$DLn?cgO^Q}3dzNjAb}v(uT`GH) zeTq(sZVN**W0Vk>rw8Mu=z~~MLhcMH1}TOu3@L`G4$aI_j;T(~3{lSR3@Jt_#w`pf z#;H!t%uz1x3@IilrY#I9rm3#Y%u#Oc3@K(Q<}C~<=3seucZL*;6w4Nd6w6fiX67gl zuqmD?Rw>pk3{hV03@J7#wk-@PwqQHF-5FBsQtVq8QtZLHecTyR98w%x7*asCGe`Nl zGo(1BIJYpQIH&qHGe`NkGo-krxVA8)xTf-E`8P91`MWcuxTUzaFr>JHO$bP3oWNXU zkiwASkrS936cxnCkjgxPxyUJnA;mK%I5#9JgpnbIDVRai>m?|MX)@jt&MZ#OFUl`1 z$;?YlE6qzT$;{95(`35E?&##~n_7~1i!U*$xTGjCxg<BWBqKjXlkpaNT4_mXQEIU! z<1Oam%nD7$TWs;AC7C(JFBusa7&IAgaTTSO6jjD2B^IY@GT!2Z@Dg)!G#PL4z&PcJ zl^_FPl6jSyjJJd!l9_4osTIko1t6zrGTsu$6pb&bEC3lT442BwFNrToEiTO|(PX^E z4;O|DaYKaiQp-|{G#PJ6L%5}RIjP0P2-{%hN<pNN9TK0LT3no%4zg7aE(@|1?o^nH zm5jGoi*r&_3p5#T34$5%rNx<f>G7#$sd*sh2^E**7sMx~m82HMCzh0?<`#fN1&~Bj zQgaeP0m1<h1BV=x4Gt(SusF;!!eCx`Mrt0!iumGGkbzv~iJ2ww$r*{6d7yxY@bYt$ zGV?&55CHR2D+==SQu9hO6G4#!(UF!}kqU}tL9mL<yyT+PT#%BybWmi11@rR3W^jW! zMTvPS`MIEoLgL1wnVgiGmS2<_pOX(Vgb&Kg%P+~ugcu764Tv-^goBV3fU1WCCPa}4 ziWpSwEza<w#Dap<6gQBUS(EZh^HP#Qi4v69K^VjaVP{Zv!otA7kir<upvhFF8&X-2 zs!*Jno|gzp+6rm;MG6k!XjVupR!CGRN-S4MNlnf#N-W7Q((_vhO65#xc}02*3=Cl6 zSEI94OlWaxQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vVr=N?zpKGwEV@$BC zuWN9KYmkCjOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOs%}AIa&}^RYH>_KW`TZu zS!!NNevy7jYF=V;W=W-fe0*kJW=VX!UP0w8R<MH;L0)45d6uQfkb!|A8N`HPkT}Ty z{vbt2{x`$o|B{SUXc%Z{B0R5<oS#=*QdF7@4hXQ{S2EpVO-U?DFTTZ`l3flKf)ECv z&;hw217sb@ZUz<<=P)xcFn};WNZy8lfuV$<gQ1x*g)y6{NUemigCT`UlA)QgNUema znE}QNW@u+<XG~*CVNPLb;izS*VG3qQVGU-`WUJZ&ihhMe1z16*P@Y+mp^&JMms+ln z5CkfeGV{_C6!Md@Qj<&cxVRJ)6cnrq5{nXZ6~G>_QYgqT&IFY^i8%_1Md_uWgkP*s zkXT%tnxasWuK+UxY6OY_+2vLW*{PM~`9&#M^@73^oBkqD`=$sKD=0}76kMzf3=G1c zuxSB@O$|c{V>45cLJ89X<`l*(mKugE)-1LZre4N{jEoE=>?sVTj71J5>@}b;b132H zV8~?XU|ho3$5_jlXH~*klvBc0!kNXL!raVMlmlWd;HhC)$XJw9!i%DouY?boU&FY7 zAEYjrL6gO=s@grjL;;-Cz$LswW?pegVqS8pf<|?6PI0X!D90ox=Hw(M<)p#`LPwz_ zBePhcJToUpp`a)~DKROhQXwNTFI^!sFC{e%l!#MvDit(RGE)>P^Gg+SQxo$bme_(# z)zH(^)3nzFRXNEy#kWK=i{s(dRy-`aH3e>QWfsHSQ^d)@z;KJBJh3P*GcUdP77K`V zi!Cj`C^xa>7H52Xa!z7#aeVwOj`;Yz#N5>Q_##l4-{N&FuFOk@#ndhKlKi5)#FYG7 z>=}v0i6tdPx0usY^NP$shVzF&<lu@q;4IeiqQrt?O{QCnX}1`Qii|*60bE*uGQ}+x zkZctwW>r90laY&&g^B4u6ARlPmj5j50*nG69uwC;CT6a`OsoP-d`wl4x=zm~CqFqc zr`S#pWP+b2^DX9_)Vy09umA^Vc}?abV~~9&Ai@nqfNci50c1T`Q9j6aP|{;ymtf>$ z<`YB7nP6AJ+T8*S3=F9ZQH&`JQA{a}QOw{L1oJJ9kfKV*^u)}(Dt*TsP<;-GFa=OT zPpwEzE-gt-LCT65sd)-TiJ8TzDSCdIEJdK~ev2zUJ~uz5G$%Da{uWPsd|_!~4kRjW zvB$@!<R{0+LrM~``@sa*{hkaA43k0b2SpeMV-bjt+xa{w&IgtEw>Vw$9U(QZ-%4h% zQ;NJm;p7b>!1f>ru#LV93=Ff7Yy|O1vXR{-KN!>~@GJ7eWe2EGo`+-yh>u|h$j9K$ zkOqpcK#>x~lENItn!=L8+QJaUmco|8-og;Yp28f=pviHI%PFxq)e+phOEh6*U;uFy zz&QY1*%hT06r~nJs(FP(u(D!Mfmf24ovM&j360r&<bu;VAJjA`Nma<qEyw{k5fVWq zXR$(VX>o}HI8&!uflEkT1z0s@1u_$q*)tP!GOJP*5_57C@=}vQO{=0xg|y7noRngy zmLS)Fpm@iSkf2~Is5{FNi!#B5N^wDIa%Ng(W?s4iC_`o@m6oJ}U7MMgoKu>Ts*njP zI|_<4ic@paG@<7CIr_R<f&H490`g~CW-{2l5XB`$mC!O>0n*MbR!GcCQ2=GDq{QTG zh@-%1(GP1W4XVY8b-)dZ1q|&BX^bgMDa<V#9Sm8FE)30#3mIz}Q&>uvK($*Ia}8q} zlNduVgC?tA6_btvhJkDh3=E(QT&%#rz)-^wD^bgs!cfBqsvK(=o0&kG!x$JD3Ynm- z7gp6`Th$^zP}4j;wFDF-noPHt^bBsXf<tsA<1H3YNPwMR1WL}gIBn8X^HM7citN_I z5*!O-l^Q5fK+=d_d^{*g#K$8F9JrP$Hq~Mc)nZLemRl@Y`I&jQxWRGd=IQF=5`2pV z)HVlaDNUxLP*5q!SzMA>k{VxJQUq~92q*)9oxuUKWgW;B;KGQJkCEj+2XmD$7Pp`T z6sW=kWd?9l4y3h&0aWh=Gpu9;g#-)8`9)x>P_r_qWGOBwijUs{vJ+$i17npCifv$N zO%AXpkje!gkh>#5K4JkSrlM#NKMq77Yyh)Bek%%KU|?7TvH~=?!NJJF!NSPG#K8s@ z$DONXu;%I%mKKI6R!Ae~7B{$#fkac0D9CzH6Dt|)6Hu|uz`y`vgD^O3_#kZu#%9JE zhIqylhG2%G7*Icr=@x5RPJUuZkr<c<jw>)55=(HOfa*t3mW_|!1M&{YTn5G}5hPdW z!LqlXCL4O7fx@dO9^}d-5CJw7L4ZRlfq{Wx2gqnpy60d7g;Nno47Zm+6;cgD2}3DE z5l;<cFhdR8Q{cX69;gEZ@?K_9amg*V;?(5)ycBd_amA;Bq(Pmf!ywBc{whjCZ!&{| z6qLI`bTP=i$TcA%r$@0s3tm=e!OPapz`_v44k>)Wf#q6MlwVY3=bD$CSWsM=lL#)f zGEx<C5{pYf1sSL#h-gg}Wu|A8C_s8S3h9|;pwh0iKo28OKyCx!VkuBz0g7XW62=my z8ir=31<W<zmLVd}S#I%wY=d<>Z?P7a7NiyxrGugd6hF``TLfybuVgH;28n}X3*_-4 zkcv~FumbfQ7#P_YtAr6AgC_#qxfJX|hAf6G#v-8_hAf5!ObZ#B7;6}skWwWx*zQ|w zX^ELRsVTSEAU$~O8M!DG+@3fGauO)*Ffej3axqp3Avp@F1j9`rAAoa*5VXv$VaQ_4 zVya=tVqORuA7S#V;;1&LjjlGVjn!l+vH}GJI5a@b7O)esIjIO#8e9fB2a=jloDvTz z0psIwlq;aHEy@L112W?lFSL1@oSKt^(g?}|DFMd@DAJCD>;e^j9E>bXJS-fn;Hbo1 zykIsOQkYv9Fw<@dM=*mX=Pf>HBgr>0FEKr}s7f5dfG5`E{JfIXiW1C33GzNTctM3< z4LDK46X8n6ThP%MaJ>Laa)ls|fzuk80DBP>D7Qdf1ewRcSS60?9^6R|R5^g{2gNho zW=Ii$txn*Kk5A15jmN~_MY2u;!#b#<WRS6-0s(|UY*0rHY#+$kB@8u8CE$))4MP?< z6V@=*FsCttI%%L98!XC_!T{!jngL9HA)2g3=AfE|7gQ0s!bZP}K!I|Lw>Y%~F-CQZ z3&e$F3r!YqseOwhwIUfjc6Eyr#41b7DNVh_2^zIa1+`uv{)PuDs6bDx0F4?v0C^Ua zd>9zH7=;*Fn6ZQ~M5Ui5J9^0ut`0#lR8$0tx=IiMwgW+cLZb-O(YOw?2$W7am^qli zq8RBElv==z+ZjmJU@CJIODbzBTPk}qLn=ozLn>z~R|;baQz~}~V;UED6o4^`CzTfy zrg5dPrm(dzM)840?OPb4_)`T^I8(U5<G_L`+$lUQ3{gTUyeWJw3{k=<{3!x03{fH} zf+<2R3{j$~VkyEYB4D-RDWWN2Eeuf-py<;Szr_QJC2%Q|nV0V8mdp)G2T%-RgOV#a zIe;1gkmO&(1gd>&m}?l~nQB;S7~+|0SZf&KS!&p77~)xL*lQT#*=jgy7~<JWI2Ld& zWT;_?=c?hXVTk9h;i_SX=ScyH@WPX_CLg$}zQqC>`vY}tGfTj|x?60J8sio#co6Lt z4}=?E4C;G;%a>c6B^gDji7A<R>9<(Hoyl8l@emq1Zkh_Jr{a@yif@TPy7^Fn#GD*( zYSL$5U|7iwPI+KQ6jg(wz6L~qS|UZYAXXiSs0R_?LaiCZ0*zvzrA2U^@&=STBtYTE z%f^Tbxj=lDDpBMBM`U|YSc9~IFo?~|z`y_w_dHNt$dJWQ!UzieET(3r5=KxAWHEzT z%ry*IEMOLR3<b<$tzpPw1GCs_7_!*GEcP0PEDkV>qlO`i6U^eQVaVbFv$$#)vbdX> zQW$%=K%L4e3+McTO2{||q@x5Gek#t-O;rF7GNqQJ78NTbgN8j)Qxr1O6!KD2Q&Lm( zG`UC*M@=3`?F?$KkgmI^6%-$+8TA%Ra(+Q2CnEzxF{l;Fz{kSKg#nou+5R(qs}e+s z50E~T8WxoPK@~DMF0{by&k}I$n!;GZ3~HrkGNv%~f@)iqEY=j}UM5iQsD=^RC%VOy z3mTzj1$AVKi$E1#RlAL<2DC<ukJl`Qb=49}6bvd<HF8rmD-<+9Il)#HOlcPDD1Zi| zZB;cu6o?DX03c~lMgR$bleVp@2ABp3Kyr$$ss@As5(4KTTU8A(ty!#Tr^$AUB_%Vt zq=+3{SeIoMXC~#Of|^rB#kZI;Qy_5yY9qj^wGPaH26r6PK;aB(nlmsmF^Vv<{bOTg zVrKe-k<vlknD}^<&;?a)ph6oQx}ZUwDo{#f$YKm<2xeemC}FD90nLRnGGsD<T3PXo zATo=QjUkdDn85%#<eeDI!oU!eT2fk+r;w-s@>6DhULvR$oTgAznpcvUo2me+pFtzi z$;HsIQqXv52xuG+Nj-Q-FDX?4)OxK{0L?;x2Y^6LgQEPLoYW$PjKpFE@LYvLQfg`* zxH}Fqs3<W{PazyMDwJ8GkXa0}6*N$%kPp#Ol$fVbP?TDhnO|C*Q>l<yqEMWXUz(Gm zkdauHs-TfnS^_sIH?dM7FTX?+B2`+PnpT<v>b~pe7b#@sK?eLlzRLlP&q6x(;3~2h z>|D4pMWuOQ2V@p2l;)+R7L_Mf!c0ld2aR!*q^2MRgr1%PXhbnHFWt&YAtWOeVt8gA zqy#_;AuTP4%eAx=l2R4G#X)&SBEtEgz<}f867Ud*MqYjiq@(~%kmx8Rm6m{lwJ22~ zwIZ{)Bo#E?s-=~iSgEB2cR$<=5Cc-mC?utpl&7ZVDdZ+*<rgUwrRJn27N-`2hG;=! z;)n=VNGwXlZcut+Nk(c>Y6>V`ic)j)%TiMmit}L|lf-1u;0>s6lAT&vtdN>lTw0W> zP=eEYB^jxepz)>B#GIT;h+jZq3>pef$w>vr2gsk53Mu)ZC`AqKy!?_>Xjntz4@+n# z7NshHt25A06KE(BQr%(k94x*;gFFfv#rdETIkz;YB(op~<ONVAS*%c;0WuI|PH|#x zDr6iiGcO&BanLefS0ObM6k-Y~nMJ9|B{`L#fXmE-@iZac1LvC5#N-Tcn#E!o$cR*h z{PH}7vdq+Sh5R(6+z2rOoDY&gSu7be(5e9r3v7`HnXXkRPgMYAl!BuCvdolJg+v8V z`Yy>=NK8*JN=;8J0r@#q0W`>#UkVxT0;MAaMoKJcMftf3VAn$eS5pt}13yjXq9#z` z$c0c3?ne}Xhv~q5V60uI9tH*mLr|dzY6LQfF)?y6@-T8RR*9ojH3&mdI>MkfI0%C~ z!l0q~5{3ng9SjQ@+aXg$j44bl9L<ciOi(^#>WI06v4$z0sfM|RDV`ZLjikw16^%ZH z1eyv2*Aba{=}5^DI&G9@rQnDd<1Wcp01e9*gNGRrnqXmw(%uEtksv3_gBm}eA(#%v z4u*8b8iqxTL7<WwJZ}RXs{uEfG?{L(fM?m5vddR86}f;a7SQ+_SQ0v{2eQ2&H6=bR z7!;BqD;SunR8c|@q@)-zst4kNbr5n~7DEl(S&*=WI!=?Rs14*6P<5oqRMZEGe75Xz zkW-5$fF!`p3{Y19wlDxRD;ExTAavXj)|>`UY#=!h9E|ZGEt)LgYPSev5xB8i1eybY z_JJVbF%e`RNE8w%VCz9PgZ21=tOQL4FtBkj3NZ6AvoW$UL5BWNEk{XOpg;sAE0C?l zpri$=O&2gOWME_f&BK9O>RAjaj5Z7@p!N(y3bPGE3aC}dkiu%i0BU{4vw&Ldnrwcz zKv|-wBpy_^f+ziM@j<8m<MT>$lTwSolYqB4GE;I=<J0nsG+B#4nc@~}a!zVu5!mmy znDg?>i$D!<So;FRhIkec%&bYN>6v-)An$@R6C)QRAGjrl=2@^Z6wiVhZScM<Xqupg zF^d5-#hL;dYtsM?l7J@}m1-CkFhT~GKvT293?Ow`%=vaDEFjhb)`biuY|Tuy%r(r# z5uoOD4Py#pFJo~;4buXSg$$q(yDUzyNqL}#HAI#XWD2M$!=1up18TbPK*Wm<)G%c6 z7R>;W5D}361$;G33mI!cLCs&Zp@wAvKWH$iL|}nn4NDCZ$OQ|T7(u286<w)e$P$9+ ztYyt(Nnx&KEfKC^ZDy=tj2Ee4WMRk>tzk81U}A_D1vTkYSXdb(89*Y;3}AO~r?7%V zQrOHHpdw-*w@+X!(y3v{5`&n`$WS5<GBcP#lijbV0F(<P!Rt8Ui!<|*Q=y}c&<F>O z-GDkR3`NsGDRwG|05$0}C2q0jmzE^w=cYosQJ{IIqHK^fcz6KRy@xD}0nd3sazPGA z8r0vqB@7wrEQVTHT#{H+0!~AaE?NsnA-E?7?vsHc`xX~?2rV8|q8EX?aG;UbTiki6 z6(#YIc_4@r!Cg7fjFcuDq~})%@*#6tX~`|YOwbaVf}G6cOwb~nlA=o3nxE8)WJuox zoHoG(C^z0>$t+1NN&}@&P*WK+k_Z~O<6>lE;$r0b&%!Lg$ic+L$iu|L$iv9S$ioQg z1#&P7FtIW6F@bs|e2hYjLLgZtw4MmaT$HvlDCdIw2`b%+Q^38#1q_g(mlDPr(276C zOokMuUY1%=E19W=F@?F8v6iWXxrV8PrJ1S7u7njL2A*({0*kXXGZiJ&FfL#Rl>s#j z3phXtk&&TLsxYBY3Y^zj{J>dKlNp><!9`-xBv9akl7%K`(M(X-@qr5+=fs?xV9@+X z(PEGSP%IaLBONqsQUnU{TM`9DsRfBe;4&c|5;2guOK{j~G9$$YQ%XMAW(WZeYmWGM zP^iSm_kzM3G~CI+$i*bU1PWD9sldU=!-Uc6fat&oNl?!N<fLLy#Rc*ycqRdC*-EH0 zK*c}Aui)qg6EJsx8d~x3vqA0vm8uMw_Ci!(*bA}_Y%i!|3aZ*u7)zL-*_*kBF_WQ& z3AD-q+zYo3ElyQPNQjSzn3a$K9#T(DOi@TmO-?K=1~qdsi=nf8pngXRXzDXL5!AS^ zGFJ!b($G}LF0TMGTODRJNEv9cL26=(CQFe8DEcfx5i8^ZH8C?kFC4P^plBsXb_Iw4 zhX|Me2MY_x!ug;e0T<OwER0NyO#fI|&=NLCm8K;65F99VgNBN8Q%e%TbGh;H;51PL z3a27vkaeIgW|2CGr3oTH1rK=4r3jQGAQg8s$k7}HMfnA(MJ1Jx@&Z)bfs-jDSuO|Z z1;qlyBdbANupbZv$TvlxB@Hh@4H_o~1_lmB78WK(CeVZq$Wt)<l}jEZiiW>($#QTr zF>*<B2yw7;sB`c!F>*13%>y|UTvoyeP}%{H5`u<|kY{7SbFSdgY|z|l5y%bDc`8r` z1<@nbL#gvXU3pO13r=95fyWw#1q{%-jj;w)g)`MKr!e-ifa@Bj8Wzxkn_AWq<{DOT z5m8VjRKr-ql*v%T3`&HxY~c)f3M>pItd&WSZg>sL0=5!%P`w8l@r`6CoMgaI!?J+0 zh7H6o1QjZ*C0xx+MSV3a3%H?$3Qr9yM7D-Cm;qX>F#Bn;z*bN~dK*~F7hXujEdfOm zTA@-55-S14H*;}iF=X5r+(Rw}Nq|D2Xeo#VYL9BNLkbpf3j>j@LFInYGLRy0y@Qqj zK<RunC^duTdJqK-6Qd9#52FaU&;b`Xg5bgr)TD;xCO=J9^yCd5VFsB9E@6-ea9RUJ z?+TDrpmYfuR|ZEoMrr}&5m3r024zs>)Pg*BmkM1r(aaddmdXy9!E0uW;sDR#af0XY z*xbOYUaMSC=I;^}G@#w9{36ggu@X(#<VY%H^#G_Bny65cSd^Yx0`DlGCO}Yn2DuW1 zi$Q6+1T=05n!jTLCkD{;2{XL3)nqBk1cm-a5CI;32elqx%|Q?wJY)t5EpR}A6di&E z6ayn4V--KdFNlFuP{9rgBoGF%K~4e{0mY!^GAKVRWJqBwg{+mdfQ}lKXQYBUsS1e- z@FlRI;xs80l-V*;b5cMnE5NJ1AR(mZr^#3}2jprjGce#b&M}Z9K~^&`SMfrf2$=^& znQ#F$P(fh@cAy%#POo8X1~mnlizI4T7BE2S<2<e!mIaIub`47~gC=8@oHK0kB6Lw8 z#1iOmqMjyG5h!mIfii<8Ymq6)t)KwC#aafQQQ^%<1hsUaOOuNhfaFor|1D1V^2pO5 z&w$HxX3(5A4-*$-l>o#(J-8xGF05%D6k|neLB@lcez&;6WjkbDN)c$;LJ??u8xq4{ z`$1!*;2vNRC{^qS*$j#}P^REvVPfQBVPXW!V9gxhq7>8)L(Uwqq7*q}K(a*?dkRMi zXA46VM+#R8cMC%lX9`a+gC=hgsJy8%1-E5D15Ka`6_WTti=T5+!E0&2-Q$AP6v)Up zybMSNMJXulfiQ>-N(A8Obpa0^gSuPbi4$;E01f2Fvw){kSiw^%Y$+gd_7u<*2?v<u zOaV=|aDmy}psb_G><8|0fxB3mJmAh$5vZ^)ngR-D(E1bfvJ@2aMYBO=r69CP4(_=X zmn7yEK-$FfK?^5XA*CcX6Too;CgAz-CMa%1K;C5HVq$|pW+=^6B@PY|c$1Kb{0S;% zK^;<X|BMghQxFf-Pm_SJiC`+)2J$1=qu8?ETm}Y)4<L7e8p;ezT#PJ?RZ3_s!P2on zX{CV*4S1det!V@YJp-6ztYKhb$YM%i1b4BRz+&L?Op^%`DVi+caE3S&9PFTw#X3p^ zs-3=p+zP6(K^+G+P<f_~=2~10W|Vp#RBgbW42mUC!*U@*EfZ+*L>6;1BdGVffTae! zgaR~1!~{xTph-J6P&k8|zMAYvDG8MKionhX6(9&NK}RTVF_$Ig++r#z##V5E%bY(5 zk3srFRg!2PLrnc*cm?DgaFzk3HB7IRFf0IN8AfocnYo6EXwTeYPfjcVEsDqRP|*fZ zvI4E#!RjMWQOd-`z)%c{Dv*zO7^`Hk_y}Hq_z^4*L1`7zL;;5}$PT1(5EP4$au8G) zT>}LtsQn8n2RX!<7`a$E*f`k01(haaku50qG8Q?4sL)&NnR%dPg(XFxqURR3XKq1$ zQ3+(U(hlTJ&^o!I22g3hR#I62nmlDJ0k`>YF()P^7l9H|5hx07aV6*HC6^WzrRJ3s zfr_$Q+y$8hdeDXYMW8HpO9V+o54Myal90d?sGJ}Rxj+PHQnLtDlox@fHj6->DFQ8) zF9NNADiQ=K0rlvLgh4D&v2u$!FR`Eq)O;%v2Z@2FW<hO=B1sSzR9qBEgIM4mf-Hyy z?)A%oSfHWEBG8({B1I5a2}FQ95uglRqzdvpWZOtuX--ajR%S^_Y7u0Z0#pk_dKsW` zh$7H3lOk|`13YX1ngJ}*25Dyp?K22VEV{)3D&#;j9Yvr;leakX%TkMS@)J{TaUvE! zc!G4WK^nTZIQ{(NgIt3{eL^7JW6(ASaQ7IzpborV4AP|mPl$rMIp7{Ns7C^B7=kN6 zaNOUL#TNd0@rj^y-<kQ~gb^i=RSk44czJ3PINe}Ndbc=ia=}ZQ?LhHS3>t!DViW)k zVz9F?aWF!l03#1G4-*eFXn+F?28n|(BUBEV4G{y0z_9=`3nLdB2y>_iu&^-;un4dS ghzW48F>|m82nYxX)H65;hzp4e7_%|*FtITL0Dj`1-2eap diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-39.pyc deleted file mode 100644 index 3b91e36b9860330261afab3457cf18cdc2344855..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2231 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 B`%C}; diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-39.pyc deleted file mode 100644 index acda5734ea771b4394eab166b0e3ac803689901c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3979 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 FW&l;UkoW)q diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-39.pyc deleted file mode 100644 index fd5a3325512a761d42ef133ff5c6b4eff191f6ab..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1006 zcmYe~<>g{vU|^UdaWGYym4V?gh=Yuo85kHG7#J9el^7TpQW#Pga~N_NqZk<(QkYVh zTNt94QaDmrQ`lM<qnK0JgBdhAUxIXNGTvf~FD=Q;DNbet@u3*R24QEAfh-^c8G{)# znX1$r(@Ii{6p|BjaukY7iV{mw(<>E9G7?J^Qu0%a74q^+GBWeh_54;ctYo~!U6fi< zR2g4fl30>j1acmj_*Lg@6%$&VT2vg9nv;@Q6yu+l>Qa<hma3qu5bEa{<{A|28R8hM z;OXb$@8=rq=@=92>gyUD;u@r2784NQ6O(A7o0FfOSzMBt9g~_@7UPqd6jPj8lB!#f zn4F!Mo?0AJkXfJ~UzVDel3%1>lA4#8oLN$-p9pffUP0w8UN9>j>Q)hu51ByTW-MZ7 zU|{&gs%oHToR$o7FGv)GK>+~bgK)75I5bKaYM7cC#TinV#2Gpn+Zoy!+nLgsQ<zg& zS~zN%YnX!>G+C>haE4Y+etNM&NxnjHer~ElPJViNYLP-oMyf(uW?p7-Mrw*eVo6DA zZb6A&m5duq2ps4o`3mZ)#p()RKPXhGY7}egD3oMm7Auq|7K4pYEmkPW%uNNyQD$Dc zLS~5`M$~dLFfa&%Jg&jOz|g_8fT4q-gRz8h0aFb_7V|>J8ip*E62=9rH4Is73mF%( zGBTtv1T$zd`f0M?V$R7=F9L<vEy48El6a7#k`j}%<MR@8Q*SY)<=ql4PEF3wODT>o z&df_r1;u_*$t|vu{P_H$l+3)uoLhWQzs2X3<|d^U6@fx`CG#!Loc#3ooYb<^oLlT5 zW=TQLEjCEdfYVJ88v_FaSR_8PL>}aLK2Y2+vM@3+GBI*7vM_S}u95_YOMFg#x}Hr= zesW??v7H{su*?!o##_wAB}JMnMM4Y=3`GJU!?=o5ljGC!i*gf7ia@~uv4<Zd54MaG zZkhzhJ`Rw5%zXcuSOqwX#26SD{4^PhK!Tbqw?qmu3-q9AP7jvmz~KZ=Rbb^1<3WiC a!UEgDVUwGmQks)$CkV0v6c#+p94r9M-UTZF diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-39.pyc deleted file mode 100644 index 352c12dc204df5f3c7ee733d55beec0dd720ed4c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 902 zcmYe~<>g{vU|^UdaWJ)sg@NHQh=Yuo7#J8F7#J9e6&M&8QW#Pga~N_NqZk<(QkYVh zTNt94Qdm-0TNt94Q`mwTG}&K*^lCERVv8>=$;>HEW(4t}7{mr)XOM9$AmbQ=88n%y z)SXh(@{3Xxk`r@s6pBlV5=&CkD-}vI5=#_P@>7cy^72bEGV{{){8looWW2>)lv+|$ z8DCtISdv=A%)r0^CVtgBTg8MHrxq2*q~@e#7RC7IrMeVlmZd7_DunuZhPeg>dxkg$ zD|q_3`1`pAdpgDhyZX8YhqwkQn8gGH_{1cd=;q|7XBL-aX2+!FmBsjECdCwImZa(y zBqnDkrl%Ii6l50Y$Cst%rQ{dsm!#$;CTEsZ>L-Dnu2)cbix0w#hq_h-<VjHAF)$Xf zGcYhDgW1rK0680mi-i~%7}^=y8Pk|j7*m*9IBJ<{n1UHJnX9aDhf7X=da*)DzCv++ zZmL2~etLRpkwQsEszPE(NosCEi5^C{b1*P42!ouY!oa}L!MK2-gCT{ngmD2=4MP_5 zLJ*6kh9Qe}A>%?8MurpyP`vn6nFW_57L{b?r9+~oBws;YwOCz8p(G=-SRu0*Y@=$i zLP=&WB=SHiGfVU|*={lC<fj*be0)nVJ+&kr6thW*$=UIFiMgq_n9}lYah2r9=NF}9 z<|XFb;)A+6KCd)4DYd8wlr&Z{-Qvv2Pmj+@ElbV0#Rl;rIHrr(7#JA9BJr6e(jYJK zfI^j#g^`JoiIIzu>ra&wG%9lP)Aej}@{<#DitY43re&6ZjnHH+;s+%hJ`f=QB0!N* z#0z49P3J-wAOW%g<RS)UK8_+m1_lN{O_p0C1(^kU(8QnzOAKHSgCiTP4r~<?0XCV# VCO1E&G$+*#WKuE6Tpnf)762LD<FEh# diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-39.pyc deleted file mode 100644 index 19336c81dafca811eed88bb1a85887e1c153b53e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1250 zcmYe~<>g{vU|^UdaWM4<8w0~*5C<7EGcYhXFfcF_>oG7eq%fo~<}l<kMlmvi*i1Q0 zxy(__j0`EvDJ(4vQ7kE(DQqe1EsRmDDICEJnp`hICTTL>Vv8>=$;>I%WV|Jjo>~&0 zT9F)|nU|IypH`Hg8=qEMQd*Rn%m`8o#UM5aJA*7{0a?r#%%I6srS6oPmS2>rkery4 zqflH@lvt9QUa3%$kyxUTlAl_vke6SQk(rmS=eLqUlkpaJQEEw1Wqff-Vo7Qd$P_T~ ztJT>mCbT%Us5mAyCnd8e#y>CBr6{v3RY6xF)Xy`_H7M9K#4%XG)6d1<&o$W7F(%m6 z*EKlAHAulMCLq8kCecJUCqF&2xFj<>CN-}t#wRl=rZ}@CRkt89IXf{uwK%3Avp_$- zEHy7Bzev9%H7_wav!qf#3GDRv;+)jf0=<IDTO!B;@lcnGf;`Lw3I)a@b_NCpw`5TG zgZLl}@&kwu!o?yC3=HiI?TqbAY0N2%DNHRKwahil!3>(rRaUrzDJMU@SfM0ep*TM` zRUs!oJw3HZp(G<!A+e++HMgKd4<#B{85kHi85kIZL9S|GU|^_W$YRK1EOG$R3z!x% z)G~r>E@7@=Y-Y@2sbNfG5@TRusAZ~U?qDdgDq#hwYi6uvDGW(ru4Ty+NnrtrEMQv* zRRt35V9H|eU`$~x;aI>~!;r<bkg<fjh9Qe5g{_&XhN*_Rh9!l)mmQSef*CY9{BE%o zC1w_<rc|-17F#K(7Q5ZzC`v6UEy_zxsZt99MR;ajx`Jx4LS`O_EKW_%&r2y*NGw*! zECC6q7VF(&1xJD=<1G$YO4Q`N#hzbUlANELdW$VBF*7GM<rZgZMRICENoIcDEtZnX zg4A0a@$q?yxvBB-MW6_{#a5JBT$)pIi#aDhy$BR%w**0n8<aMa5|gvRYHu;6<=tXW zPc2C-DJi<eotIis5}%k1GE<Ya2o$`xm{Kclv6Q72CEa2zOUx-vy~UT4pPZNj&m$|D zi?|sW7;bUq<fq5yq?V=T++u^o8#px=v4JE(BJr6eGN5=;0;Lp24n{6U2__as9ws&> z0Y(-k7DgsUCPpqsE-=mXvq}La`Q_xN>)C)UF1FJH*_2rVHeQpZNS1+tp$KF$*d0Z3 zATB5&7D<CxVCx0Y&5{H;1f+<8SwOr<o`HeEPm|G2lkJvBL1uv-G;8R=vIZpZq_Iiq sCFkcBB$j{!9GoG*hJl@iM1UQ^VUwGmQks)$CkV0}B*eqW!_2_~02t^^iU0rr diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/compat.cpython-39.pyc deleted file mode 100644 index 5dcd8e471a97ace9c209bbe19553aae881787f13..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 986 zcmYe~<>g{vU|^UdaWM5U69dCz5C<7EF)%PVFfcF_%P=r7q%cG=q%fv1<uK+lMKLil zq%fzjv@k?5r?3VyXtGu5hn8gKWR_&67AvIX7bz4J<(FlqWagzSBqb(imnRmbC?x0S z79^HrCV`Yy>b(S6q{(=Txj3^TnGwW+VrB*g1`u`zS!}_;z)-@F#aP5w!?1v9Aww`j z4Z{NFg$yxFwT!h)HH;~Yr3^)CDU87kB`h_J&5SjSHB4#D!3-b~O{T<Ej0_B13JMAe z?x`gTiFpdC70L0Ld1?6yWr;bZsS0UD`MC;-3T~w(rA4WFTo9F+WvO`ziEv?s%)H`~ z#JuEG9fhLQlA_GivQ#W46_;j~BqrsgLj0asT%4Jg4mK_`Pa&~bp(G;}VRu1dQDSat zNotWoNxni(etLRlUb>!7etLRpkzP)Ix`w7gVqS_uQEE<NNotBhZfZ$Jeo8Uab^dt@ z0hJ{g`FRRPItnEjnZ*j_nK?NMNvR5n3K}Jq1*tj^ujwe16eT97g2G-?p`<9YASYE1 z>>h*x#^?rsgD171Br`t`?r8;$^30M9h1A@n)RdIe6eLrj4)RO`d9El`p**ozAuk`~ zONbFV3V!){sS26JpkOO4%1cdA$j?(q$}h=KC`&CW&dkp%R>)6-`Uc`QKTXymP?EdF z91v-Ii!-$%8Di8eJ~$H`d$(9XKGkHt#g+z+xm!%B6}Om5l2$SlfztD@dS|Pc(Bjmh z;+WK&l+2<S|GZR}qRg^X1zm+uKhH4NpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>AO*9S zfB>JEL=)Yd{PfJ?lFaOw)V#77pUk9~;>?m%-GapA?8Nlc;+TTW0{!^1)V!4ZBK?xo zyu{?pl1hC@`qnF`yd{yIS`rUSYw@5|77uYLD=1C#fD$?n8zTo34<iR73u6&Tz)zFq z7JGbrN`7*D{4MT+%mO{A`QQ)%D*<~BiQr~nV7SF$lbfGXnv-e=%0k5~3=9k`j6BQ$ DSZE^= diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-39.pyc deleted file mode 100644 index ada140b69cc271300fd45807a99f8bcaf2574f68..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1055 zcmYe~<>g{vU|^UdaWIvEm4V?gh=Yt-7#J8F7#J9eRTvl;QW#Pga~Pr+QkYVhTNt7k z-5F9?QdnCUQdm=&nwg`RQy7C8G}&H)^!p_<f+#2kv6&ed7@R>S@i8zklrSt{tYKKl z$jAWJ!&EhcOF=<FAvh;BwLqb`q$sf@HN8@yBqOmzAtf~@v9eepwIVgSv?Mb>Pa!S8 zNFh-nJ+mw|Pa&@~Hz~D9AwNx_I5jyxFQr(I3v5tGMrN@>X0bv^Myf(eYFc7xP6^yt z9fica6ouTxN`<6Uh1~q)?9>#6{L&JzxutoTB?={}#U+_}>3U$3{4|+vv6N)yrru&L z2Dwg?@fJJOu9XZ$tPBhcziOPVVnT~ki;81Xb5b&kV*K+`U5YZxQWbO+Lj63$T!Vr= zLmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|M zQgsUwld}`kQ;TB?G7I$M%Tn`F@{9CKQu7j%GfOJ<^AZd63Mz|0;VK3SS0+$kvw``^ zASN;f$$_I$fq{V`l_82Tg&~S5g)xd58kH=Nh>T)QVGCx^WWOZ{_G^4;ab{k6d}>*0 zUP+Y!w#X?@%q%HZ$j?(q%u@g>Qz*#?1#59?iC!|uQkWw^Y!C*g08o;vVXR?@XGmcP zX3%8x(`3BG3f2w^?Bdj%v?2}$21w|FgSd!|fq~%`M|^x{US>&ryb|2Ij8#$?F4co6 z!*Bp7sK5>oVqjpXVaQ_0Vyt0IVeADZLy$w5Kn`ICMRtB^i6#@+5w}=Ce$-?t;sm*f z8$^I29o1RMi8(p(@v3lVF=KZYM46u^8^|kpiMgrq@wd3*<8$*<N^?MLp7{8}(!?C7 z410WhN`7*Dd=V(Pig;0N2D<?iDn;xJ3=Hxhn?XDdMiwRxX0VthOA#o*!Rg@^TYgej hYH|r!0^)SA0bl~8?-qv*#1(eJAfrIJo`ac#69A#P{Zjw{ diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-39.pyc deleted file mode 100644 index 65a3393e79869d742a0b48b593a396668bf2ca64..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7440 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 XY|LQHE5IcnAiyiYE1)dEFTe!=XEh}e diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-39.pyc deleted file mode 100644 index 2db4c1e1427b4a1058f95b522991b81cbb12178a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3816 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 diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-39.pyc deleted file mode 100644 index 69b973f11458b55b226a947be93ecf31d66d6a93..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1370 zcmYe~<>g{vU|^UdaWM5D8w0~*5C<8vFfcGUFfcF_M=&rjq%fo~<}gHoXr>&-T&5@{ zMi84hhcTBqiW$si$zjZ8iDCh>S#ub3S)*9NY_=S>T=pn-Mh16=6!sL37KRj#RHkO; zD2^1yU<OUjmmoX+G#PL4I3*UR2Bnr1Rc7X;Yck&Abjf!tDM`&ODA8oR#qN?HoRgYb zpvicP53I&HF()UuB(Wq_lkpaFdTL%W$QWb{az2P(Y{0<4kjfCnn8Fanl**jNlE&E1 zkj9w8n8MV;8O55)oW+*HoWjz=(99Uc-p;_n5XBM9pviiRKP0~>FEJ$_Y+GhtdNLEp zG$>|fU|;}Qzzqr?1qKF&5{44S8ir=3ET%MuOoke!C5(NHj0`o5H4O30DGb33nv8y$ zEVo#TOAAtqir5(#7;bUI$7kkcmc+;3Vl4*yjQJKzacWLl5hzw}v1OMh7Nr-jWW2>0 zAD^6)SX>+*zmnlsv$Iu9XmM&$aZGAXN@h`ve_pCfQD#}Hg04cSpJ$kBP_So+W3Ym! zpNqerYp|zdOt7o3YjB8bkb+rEK!8t7qKR%!etKqcNoICTYF=54Pi9g~ab`)XZb4#l zc4B&JaZEvGfqr~hYF<iyk$y>PUSe`)Nu_=XBq+*Llk^HIi#Qn=7^FcS2ZaCwqZnhA z1X@_>!Tg32XdrKMFfcIWgY+(9U|^_WSin%jxR8+%9C$U1HB2?kDU7`=wJbFZSxhx7 zDNMbLwX7w~HLN8p%}hl_RU#lYnG7||px_N-sAUUh$WvfpC}FKkVPpWo8kPlYCF~10 z7BYZLjbtdCW57_uvVgOO4a6^$0-MFv%v3a~hGhZwLIy^V8+dA17cz!1FftTMmGCa$ z1M!*|3#Gu(#te!!o+41HjL%QXN=+`g#gvwJiv<)pMLY})44RC$xFOQT;MB-}i!~`V zJu|O}6%@%VnI)-3x41HkGxLf|67!N%i$E#o7B48NyH+Hp7L;V>=iTBhPA!Q~g>#vU zD~oS&q*f%yXXd5l-{Jzv7Nr)K=9CnHLj0CQK~ZW!Vo_>*T7FS{UTQ^2d?F;DfRj!U z8^~g|pwyDmqC8FZB2W@75@KLrC=vz{AU79@fRr$$<lkb0n#&K80uurtDUSH~<iwnu z_;`6xR7rsnJrfs`022=*7b6p+2qO=p2$;>m$j5{&@*$cvIYEg$FEKYYKK>S0e0*+x zN@)&=%@ZGASelpvkpa6G;&M)q-JHq!Mfs&AnR%&2iXc8OH2o*1f*e!?b|jeK1-TjI zTyTB@IkFh!bq+=$78XXZm?mctNcfgWL1uv-G*Rop5_J(MKZBzK9IBA`Vuz-5h@(IW f7Rf@etso0;ao9loVh7?CgMyTUiH8vknRu81V)j<4 diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-39.pyc deleted file mode 100644 index 2beda98fff5b3a24f2af5567aed1c555d1a9d452..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7373 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 diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py b/env/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py index d9a2d463..2e50cd7b 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py @@ -1,4 +1,3 @@ -# -*- coding: utf-8 -*- # Copyright 2016 Étienne Bersac # Copyright 2016 Julien Danjou # Copyright 2016 Joshua Harlow @@ -15,7 +14,10 @@ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. + +import functools import sys +import typing as t from asyncio import sleep from pip._vendor.tenacity import AttemptManager @@ -24,14 +26,21 @@ from pip._vendor.tenacity import DoAttempt from pip._vendor.tenacity import DoSleep from pip._vendor.tenacity import RetryCallState +WrappedFnReturnT = t.TypeVar("WrappedFnReturnT") +WrappedFn = t.TypeVar("WrappedFn", bound=t.Callable[..., t.Awaitable[t.Any]]) + class AsyncRetrying(BaseRetrying): - def __init__(self, sleep=sleep, **kwargs): - super(AsyncRetrying, self).__init__(**kwargs) + sleep: t.Callable[[float], t.Awaitable[t.Any]] + + def __init__(self, sleep: t.Callable[[float], t.Awaitable[t.Any]] = sleep, **kwargs: t.Any) -> None: + super().__init__(**kwargs) self.sleep = sleep - async def __call__(self, fn, *args, **kwargs): - self.begin(fn) + async def __call__( # type: ignore[override] + self, fn: WrappedFn, *args: t.Any, **kwargs: t.Any + ) -> WrappedFnReturnT: + self.begin() retry_state = RetryCallState(retry_object=self, fn=fn, args=args, kwargs=kwargs) while True: @@ -40,21 +49,24 @@ class AsyncRetrying(BaseRetrying): try: result = await fn(*args, **kwargs) except BaseException: # noqa: B902 - retry_state.set_exception(sys.exc_info()) + retry_state.set_exception(sys.exc_info()) # type: ignore[arg-type] else: retry_state.set_result(result) elif isinstance(do, DoSleep): retry_state.prepare_for_next_attempt() await self.sleep(do) else: - return do + return do # type: ignore[no-any-return] - def __aiter__(self): - self.begin(None) + def __iter__(self) -> t.Generator[AttemptManager, None, None]: + raise TypeError("AsyncRetrying object is not iterable") + + def __aiter__(self) -> "AsyncRetrying": + self.begin() self._retry_state = RetryCallState(self, fn=None, args=(), kwargs={}) return self - async def __anext__(self): + async def __anext__(self) -> AttemptManager: while True: do = self.iter(retry_state=self._retry_state) if do is None: @@ -65,17 +77,18 @@ class AsyncRetrying(BaseRetrying): self._retry_state.prepare_for_next_attempt() await self.sleep(do) else: - return do + raise StopAsyncIteration - def wraps(self, fn): + def wraps(self, fn: WrappedFn) -> WrappedFn: fn = super().wraps(fn) # Ensure wrapper is recognized as a coroutine function. - async def async_wrapped(*args, **kwargs): + @functools.wraps(fn) + async def async_wrapped(*args: t.Any, **kwargs: t.Any) -> t.Any: return await fn(*args, **kwargs) # Preserve attributes - async_wrapped.retry = fn.retry - async_wrapped.retry_with = fn.retry_with + async_wrapped.retry = fn.retry # type: ignore[attr-defined] + async_wrapped.retry_with = fn.retry_with # type: ignore[attr-defined] - return async_wrapped + return async_wrapped # type: ignore[return-value] diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/_utils.py b/env/Lib/site-packages/pip/_vendor/tenacity/_utils.py index 8c0ca788..f14ff320 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/_utils.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/_utils.py @@ -14,73 +14,17 @@ # See the License for the specific language governing permissions and # limitations under the License. -import inspect import sys -import time -from functools import update_wrapper +import typing +from datetime import timedelta -from pip._vendor import six -# sys.maxint / 2, since Python 3.2 doesn't have a sys.maxint... -try: - MAX_WAIT = sys.maxint / 2 -except AttributeError: - MAX_WAIT = 1073741823 +# sys.maxsize: +# An integer giving the maximum value a variable of type Py_ssize_t can take. +MAX_WAIT = sys.maxsize / 2 -if six.PY2: - from functools import WRAPPER_ASSIGNMENTS, WRAPPER_UPDATES - - def wraps(fn): - """Do the same as six.wraps but only copy attributes that exist. - - For example, object instances don't have __name__ attribute, so - six.wraps fails. This is fixed in Python 3 - (https://bugs.python.org/issue3445), but didn't get backported to six. - - Also, see https://github.com/benjaminp/six/issues/250. - """ - - def filter_hasattr(obj, attrs): - return tuple(a for a in attrs if hasattr(obj, a)) - - return six.wraps( - fn, - assigned=filter_hasattr(fn, WRAPPER_ASSIGNMENTS), - updated=filter_hasattr(fn, WRAPPER_UPDATES), - ) - - def capture(fut, tb): - # TODO(harlowja): delete this in future, since its - # has to repeatedly calculate this crap. - fut.set_exception_info(tb[1], tb[2]) - - def getargspec(func): - # This was deprecated in Python 3. - return inspect.getargspec(func) - - -else: - from functools import wraps # noqa - - def capture(fut, tb): - fut.set_exception(tb[1]) - - def getargspec(func): - return inspect.getfullargspec(func) - - -def visible_attrs(obj, attrs=None): - if attrs is None: - attrs = {} - for attr_name, attr in inspect.getmembers(obj): - if attr_name.startswith("_"): - continue - attrs[attr_name] = attr - return attrs - - -def find_ordinal(pos_num): +def find_ordinal(pos_num: int) -> str: # See: https://en.wikipedia.org/wiki/English_numerals#Ordinal_numbers if pos_num == 0: return "th" @@ -90,17 +34,17 @@ def find_ordinal(pos_num): return "nd" elif pos_num == 3: return "rd" - elif pos_num >= 4 and pos_num <= 20: + elif 4 <= pos_num <= 20: return "th" else: return find_ordinal(pos_num % 10) -def to_ordinal(pos_num): - return "%i%s" % (pos_num, find_ordinal(pos_num)) +def to_ordinal(pos_num: int) -> str: + return f"{pos_num}{find_ordinal(pos_num)}" -def get_callback_name(cb): +def get_callback_name(cb: typing.Callable[..., typing.Any]) -> str: """Get a callback fully-qualified name. If no name can be produced ``repr(cb)`` is called and returned. @@ -111,14 +55,6 @@ def get_callback_name(cb): except AttributeError: try: segments.append(cb.__name__) - if inspect.ismethod(cb): - try: - # This attribute doesn't exist on py3.x or newer, so - # we optionally ignore it... (on those versions of - # python `__qualname__` should have been found anyway). - segments.insert(0, cb.im_class.__name__) - except AttributeError: - pass except AttributeError: pass if not segments: @@ -133,27 +69,8 @@ def get_callback_name(cb): return ".".join(segments) -try: - now = time.monotonic # noqa -except AttributeError: - from monotonic import monotonic as now # noqa - - -class cached_property(object): - """A property that is computed once per instance. - - Upon being computed it replaces itself with an ordinary attribute. Deleting - the attribute resets the property. - - Source: https://github.com/bottlepy/bottle/blob/1de24157e74a6971d136550afe1b63eec5b0df2b/bottle.py#L234-L246 - """ # noqa: E501 +time_unit_type = typing.Union[int, float, timedelta] - def __init__(self, func): - update_wrapper(self, func) - self.func = func - def __get__(self, obj, cls): - if obj is None: - return self - value = obj.__dict__[self.func.__name__] = self.func(obj) - return value +def to_seconds(time_unit: time_unit_type) -> float: + return float(time_unit.total_seconds() if isinstance(time_unit, timedelta) else time_unit) diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/after.py b/env/Lib/site-packages/pip/_vendor/tenacity/after.py index c04e7c18..574c9bce 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/after.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/after.py @@ -14,27 +14,38 @@ # See the License for the specific language governing permissions and # limitations under the License. +import typing + from pip._vendor.tenacity import _utils +if typing.TYPE_CHECKING: + import logging + + from pip._vendor.tenacity import RetryCallState + -def after_nothing(retry_state): +def after_nothing(retry_state: "RetryCallState") -> None: """After call strategy that does nothing.""" -def after_log(logger, log_level, sec_format="%0.3f"): +def after_log( + logger: "logging.Logger", + log_level: int, + sec_format: str = "%0.3f", +) -> typing.Callable[["RetryCallState"], None]: """After call strategy that logs to some logger the finished attempt.""" - log_tpl = ( - "Finished call to '%s' after " + str(sec_format) + "(s), " - "this was the %s time calling it." - ) - def log_it(retry_state): + def log_it(retry_state: "RetryCallState") -> None: + if retry_state.fn is None: + # NOTE(sileht): can't really happen, but we must please mypy + fn_name = "<unknown>" + else: + fn_name = _utils.get_callback_name(retry_state.fn) logger.log( log_level, - log_tpl, - _utils.get_callback_name(retry_state.fn), - retry_state.seconds_since_start, - _utils.to_ordinal(retry_state.attempt_number), + f"Finished call to '{fn_name}' " + f"after {sec_format % retry_state.seconds_since_start}(s), " + f"this was the {_utils.to_ordinal(retry_state.attempt_number)} time calling it.", ) return log_it diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/before.py b/env/Lib/site-packages/pip/_vendor/tenacity/before.py index 3229517d..cfd7dc72 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/before.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/before.py @@ -14,22 +14,33 @@ # See the License for the specific language governing permissions and # limitations under the License. +import typing + from pip._vendor.tenacity import _utils +if typing.TYPE_CHECKING: + import logging + + from pip._vendor.tenacity import RetryCallState + -def before_nothing(retry_state): +def before_nothing(retry_state: "RetryCallState") -> None: """Before call strategy that does nothing.""" -def before_log(logger, log_level): +def before_log(logger: "logging.Logger", log_level: int) -> typing.Callable[["RetryCallState"], None]: """Before call strategy that logs to some logger the attempt.""" - def log_it(retry_state): + def log_it(retry_state: "RetryCallState") -> None: + if retry_state.fn is None: + # NOTE(sileht): can't really happen, but we must please mypy + fn_name = "<unknown>" + else: + fn_name = _utils.get_callback_name(retry_state.fn) logger.log( log_level, - "Starting call to '%s', this is the %s time calling it.", - _utils.get_callback_name(retry_state.fn), - _utils.to_ordinal(retry_state.attempt_number), + f"Starting call to '{fn_name}', " + f"this is the {_utils.to_ordinal(retry_state.attempt_number)} time calling it.", ) return log_it diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py b/env/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py index a051acac..8c6167fb 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py @@ -14,37 +14,57 @@ # See the License for the specific language governing permissions and # limitations under the License. +import typing + from pip._vendor.tenacity import _utils -from pip._vendor.tenacity.compat import get_exc_info_from_future +if typing.TYPE_CHECKING: + import logging + + from pip._vendor.tenacity import RetryCallState -def before_sleep_nothing(retry_state): + +def before_sleep_nothing(retry_state: "RetryCallState") -> None: """Before call strategy that does nothing.""" -def before_sleep_log(logger, log_level, exc_info=False): +def before_sleep_log( + logger: "logging.Logger", + log_level: int, + exc_info: bool = False, +) -> typing.Callable[["RetryCallState"], None]: """Before call strategy that logs to some logger the attempt.""" - def log_it(retry_state): + def log_it(retry_state: "RetryCallState") -> None: + local_exc_info: BaseException | bool | None + + if retry_state.outcome is None: + raise RuntimeError("log_it() called before outcome was set") + + if retry_state.next_action is None: + raise RuntimeError("log_it() called before next_action was set") + if retry_state.outcome.failed: ex = retry_state.outcome.exception() - verb, value = "raised", "%s: %s" % (type(ex).__name__, ex) + verb, value = "raised", f"{ex.__class__.__name__}: {ex}" if exc_info: - local_exc_info = get_exc_info_from_future(retry_state.outcome) + local_exc_info = retry_state.outcome.exception() else: local_exc_info = False else: verb, value = "returned", retry_state.outcome.result() local_exc_info = False # exc_info does not apply when no exception + if retry_state.fn is None: + # NOTE(sileht): can't really happen, but we must please mypy + fn_name = "<unknown>" + else: + fn_name = _utils.get_callback_name(retry_state.fn) + logger.log( log_level, - "Retrying %s in %s seconds as it %s %s.", - _utils.get_callback_name(retry_state.fn), - getattr(retry_state.next_action, "sleep"), - verb, - value, + f"Retrying {fn_name} " f"in {retry_state.next_action.sleep} seconds as it {verb} {value}.", exc_info=local_exc_info, ) diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/compat.py b/env/Lib/site-packages/pip/_vendor/tenacity/compat.py deleted file mode 100644 index ce4796b1..00000000 --- a/env/Lib/site-packages/pip/_vendor/tenacity/compat.py +++ /dev/null @@ -1,23 +0,0 @@ -"""Utilities for providing backward compatibility.""" -from pip._vendor import six - - -def get_exc_info_from_future(future): - """ - Get an exc_info value from a Future. - - Given a a Future instance, retrieve an exc_info value suitable for passing - in as the exc_info parameter to logging.Logger.log() and related methods. - - On Python 2, this will be a (type, value, traceback) triple. - On Python 3, this will be an exception instance (with embedded traceback). - - If there was no exception, None is returned on both versions of Python. - """ - if six.PY3: - return future.exception() - else: - ex, tb = future.exception_info() - if ex is None: - return None - return type(ex), ex, tb diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/nap.py b/env/Lib/site-packages/pip/_vendor/tenacity/nap.py index 83ff839c..72aa5bfd 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/nap.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/nap.py @@ -1,4 +1,3 @@ -# -*- coding: utf-8 -*- # Copyright 2016 Étienne Bersac # Copyright 2016 Julien Danjou # Copyright 2016 Joshua Harlow @@ -17,9 +16,13 @@ # limitations under the License. import time +import typing +if typing.TYPE_CHECKING: + import threading -def sleep(seconds): + +def sleep(seconds: float) -> None: """ Sleep strategy that delays execution for a given number of seconds. @@ -28,13 +31,13 @@ def sleep(seconds): time.sleep(seconds) -class sleep_using_event(object): +class sleep_using_event: """Sleep strategy that waits on an event to be set.""" - def __init__(self, event): + def __init__(self, event: "threading.Event") -> None: self.event = event - def __call__(self, timeout): + def __call__(self, timeout: typing.Optional[float]) -> None: # NOTE(harlowja): this may *not* actually wait for timeout # seconds if the event is set (ie this may eject out early). self.event.wait(timeout=timeout) diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/retry.py b/env/Lib/site-packages/pip/_vendor/tenacity/retry.py index ddaf8e7f..38988739 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/retry.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/retry.py @@ -1,5 +1,3 @@ -# -*- encoding: utf-8 -*- -# # Copyright 2016–2021 Julien Danjou # Copyright 2016 Joshua Harlow # Copyright 2013-2014 Ray Holder @@ -18,29 +16,33 @@ import abc import re +import typing -from pip._vendor import six +if typing.TYPE_CHECKING: + from pip._vendor.tenacity import RetryCallState -@six.add_metaclass(abc.ABCMeta) -class retry_base(object): +class retry_base(abc.ABC): """Abstract base class for retry strategies.""" @abc.abstractmethod - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: pass - def __and__(self, other): + def __and__(self, other: "retry_base") -> "retry_all": return retry_all(self, other) - def __or__(self, other): + def __or__(self, other: "retry_base") -> "retry_any": return retry_any(self, other) +RetryBaseT = typing.Union[retry_base, typing.Callable[["RetryCallState"], bool]] + + class _retry_never(retry_base): """Retry strategy that never rejects any result.""" - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: return False @@ -50,7 +52,7 @@ retry_never = _retry_never() class _retry_always(retry_base): """Retry strategy that always rejects any result.""" - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: return True @@ -60,12 +62,18 @@ retry_always = _retry_always() class retry_if_exception(retry_base): """Retry strategy that retries if an exception verifies a predicate.""" - def __init__(self, predicate): + def __init__(self, predicate: typing.Callable[[BaseException], bool]) -> None: self.predicate = predicate - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: + if retry_state.outcome is None: + raise RuntimeError("__call__() called before outcome was set") + if retry_state.outcome.failed: - return self.predicate(retry_state.outcome.exception()) + exception = retry_state.outcome.exception() + if exception is None: + raise RuntimeError("outcome failed but the exception is None") + return self.predicate(exception) else: return False @@ -73,36 +81,98 @@ class retry_if_exception(retry_base): class retry_if_exception_type(retry_if_exception): """Retries if an exception has been raised of one or more types.""" - def __init__(self, exception_types=Exception): + def __init__( + self, + exception_types: typing.Union[ + typing.Type[BaseException], + typing.Tuple[typing.Type[BaseException], ...], + ] = Exception, + ) -> None: + self.exception_types = exception_types + super().__init__(lambda e: isinstance(e, exception_types)) + + +class retry_if_not_exception_type(retry_if_exception): + """Retries except an exception has been raised of one or more types.""" + + def __init__( + self, + exception_types: typing.Union[ + typing.Type[BaseException], + typing.Tuple[typing.Type[BaseException], ...], + ] = Exception, + ) -> None: self.exception_types = exception_types - super(retry_if_exception_type, self).__init__( - lambda e: isinstance(e, exception_types) - ) + super().__init__(lambda e: not isinstance(e, exception_types)) class retry_unless_exception_type(retry_if_exception): """Retries until an exception is raised of one or more types.""" - def __init__(self, exception_types=Exception): + def __init__( + self, + exception_types: typing.Union[ + typing.Type[BaseException], + typing.Tuple[typing.Type[BaseException], ...], + ] = Exception, + ) -> None: self.exception_types = exception_types - super(retry_unless_exception_type, self).__init__( - lambda e: not isinstance(e, exception_types) - ) + super().__init__(lambda e: not isinstance(e, exception_types)) + + def __call__(self, retry_state: "RetryCallState") -> bool: + if retry_state.outcome is None: + raise RuntimeError("__call__() called before outcome was set") - def __call__(self, retry_state): # always retry if no exception was raised if not retry_state.outcome.failed: return True - return self.predicate(retry_state.outcome.exception()) + + exception = retry_state.outcome.exception() + if exception is None: + raise RuntimeError("outcome failed but the exception is None") + return self.predicate(exception) + + +class retry_if_exception_cause_type(retry_base): + """Retries if any of the causes of the raised exception is of one or more types. + + The check on the type of the cause of the exception is done recursively (until finding + an exception in the chain that has no `__cause__`) + """ + + def __init__( + self, + exception_types: typing.Union[ + typing.Type[BaseException], + typing.Tuple[typing.Type[BaseException], ...], + ] = Exception, + ) -> None: + self.exception_cause_types = exception_types + + def __call__(self, retry_state: "RetryCallState") -> bool: + if retry_state.outcome is None: + raise RuntimeError("__call__ called before outcome was set") + + if retry_state.outcome.failed: + exc = retry_state.outcome.exception() + while exc is not None: + if isinstance(exc.__cause__, self.exception_cause_types): + return True + exc = exc.__cause__ + + return False class retry_if_result(retry_base): """Retries if the result verifies a predicate.""" - def __init__(self, predicate): + def __init__(self, predicate: typing.Callable[[typing.Any], bool]) -> None: self.predicate = predicate - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: + if retry_state.outcome is None: + raise RuntimeError("__call__() called before outcome was set") + if not retry_state.outcome.failed: return self.predicate(retry_state.outcome.result()) else: @@ -112,10 +182,13 @@ class retry_if_result(retry_base): class retry_if_not_result(retry_base): """Retries if the result refutes a predicate.""" - def __init__(self, predicate): + def __init__(self, predicate: typing.Callable[[typing.Any], bool]) -> None: self.predicate = predicate - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: + if retry_state.outcome is None: + raise RuntimeError("__call__() called before outcome was set") + if not retry_state.outcome.failed: return not self.predicate(retry_state.outcome.result()) else: @@ -125,68 +198,75 @@ class retry_if_not_result(retry_base): class retry_if_exception_message(retry_if_exception): """Retries if an exception message equals or matches.""" - def __init__(self, message=None, match=None): + def __init__( + self, + message: typing.Optional[str] = None, + match: typing.Optional[str] = None, + ) -> None: if message and match: - raise TypeError( - "{}() takes either 'message' or 'match', not both".format( - self.__class__.__name__ - ) - ) + raise TypeError(f"{self.__class__.__name__}() takes either 'message' or 'match', not both") # set predicate if message: - def message_fnc(exception): + def message_fnc(exception: BaseException) -> bool: return message == str(exception) predicate = message_fnc elif match: prog = re.compile(match) - def match_fnc(exception): - return prog.match(str(exception)) + def match_fnc(exception: BaseException) -> bool: + return bool(prog.match(str(exception))) predicate = match_fnc else: - raise TypeError( - "{}() missing 1 required argument 'message' or 'match'".format( - self.__class__.__name__ - ) - ) + raise TypeError(f"{self.__class__.__name__}() missing 1 required argument 'message' or 'match'") - super(retry_if_exception_message, self).__init__(predicate) + super().__init__(predicate) class retry_if_not_exception_message(retry_if_exception_message): """Retries until an exception message equals or matches.""" - def __init__(self, *args, **kwargs): - super(retry_if_not_exception_message, self).__init__(*args, **kwargs) + def __init__( + self, + message: typing.Optional[str] = None, + match: typing.Optional[str] = None, + ) -> None: + super().__init__(message, match) # invert predicate if_predicate = self.predicate self.predicate = lambda *args_, **kwargs_: not if_predicate(*args_, **kwargs_) - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: + if retry_state.outcome is None: + raise RuntimeError("__call__() called before outcome was set") + if not retry_state.outcome.failed: return True - return self.predicate(retry_state.outcome.exception()) + + exception = retry_state.outcome.exception() + if exception is None: + raise RuntimeError("outcome failed but the exception is None") + return self.predicate(exception) class retry_any(retry_base): """Retries if any of the retries condition is valid.""" - def __init__(self, *retries): + def __init__(self, *retries: retry_base) -> None: self.retries = retries - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: return any(r(retry_state) for r in self.retries) class retry_all(retry_base): """Retries if all the retries condition are valid.""" - def __init__(self, *retries): + def __init__(self, *retries: retry_base) -> None: self.retries = retries - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: return all(r(retry_state) for r in self.retries) diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/stop.py b/env/Lib/site-packages/pip/_vendor/tenacity/stop.py index 4db27f14..bb23effd 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/stop.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/stop.py @@ -1,5 +1,3 @@ -# -*- encoding: utf-8 -*- -# # Copyright 2016–2021 Julien Danjou # Copyright 2016 Joshua Harlow # Copyright 2013-2014 Ray Holder @@ -16,49 +14,57 @@ # See the License for the specific language governing permissions and # limitations under the License. import abc +import typing + +from pip._vendor.tenacity import _utils + +if typing.TYPE_CHECKING: + import threading -from pip._vendor import six + from pip._vendor.tenacity import RetryCallState -@six.add_metaclass(abc.ABCMeta) -class stop_base(object): +class stop_base(abc.ABC): """Abstract base class for stop strategies.""" @abc.abstractmethod - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: pass - def __and__(self, other): + def __and__(self, other: "stop_base") -> "stop_all": return stop_all(self, other) - def __or__(self, other): + def __or__(self, other: "stop_base") -> "stop_any": return stop_any(self, other) +StopBaseT = typing.Union[stop_base, typing.Callable[["RetryCallState"], bool]] + + class stop_any(stop_base): """Stop if any of the stop condition is valid.""" - def __init__(self, *stops): + def __init__(self, *stops: stop_base) -> None: self.stops = stops - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: return any(x(retry_state) for x in self.stops) class stop_all(stop_base): """Stop if all the stop conditions are valid.""" - def __init__(self, *stops): + def __init__(self, *stops: stop_base) -> None: self.stops = stops - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: return all(x(retry_state) for x in self.stops) class _stop_never(stop_base): """Never stop.""" - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: return False @@ -68,28 +74,30 @@ stop_never = _stop_never() class stop_when_event_set(stop_base): """Stop when the given event is set.""" - def __init__(self, event): + def __init__(self, event: "threading.Event") -> None: self.event = event - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: return self.event.is_set() class stop_after_attempt(stop_base): """Stop when the previous attempt >= max_attempt.""" - def __init__(self, max_attempt_number): + def __init__(self, max_attempt_number: int) -> None: self.max_attempt_number = max_attempt_number - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: return retry_state.attempt_number >= self.max_attempt_number class stop_after_delay(stop_base): """Stop when the time from the first attempt >= limit.""" - def __init__(self, max_delay): - self.max_delay = max_delay + def __init__(self, max_delay: _utils.time_unit_type) -> None: + self.max_delay = _utils.to_seconds(max_delay) - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> bool: + if retry_state.seconds_since_start is None: + raise RuntimeError("__call__() called but seconds_since_start is not set") return retry_state.seconds_since_start >= self.max_delay diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py b/env/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py index dbf9f762..e19c30b1 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py @@ -1,4 +1,3 @@ -# -*- coding: utf-8 -*- # Copyright 2017 Elisey Zanko # # Licensed under the Apache License, Version 2.0 (the "License"); @@ -14,6 +13,7 @@ # limitations under the License. import sys +import typing from pip._vendor.tenacity import BaseRetrying from pip._vendor.tenacity import DoAttempt @@ -22,15 +22,25 @@ from pip._vendor.tenacity import RetryCallState from tornado import gen +if typing.TYPE_CHECKING: + from tornado.concurrent import Future + +_RetValT = typing.TypeVar("_RetValT") + class TornadoRetrying(BaseRetrying): - def __init__(self, sleep=gen.sleep, **kwargs): - super(TornadoRetrying, self).__init__(**kwargs) + def __init__(self, sleep: "typing.Callable[[float], Future[None]]" = gen.sleep, **kwargs: typing.Any) -> None: + super().__init__(**kwargs) self.sleep = sleep - @gen.coroutine - def __call__(self, fn, *args, **kwargs): - self.begin(fn) + @gen.coroutine # type: ignore[misc] + def __call__( + self, + fn: "typing.Callable[..., typing.Union[typing.Generator[typing.Any, typing.Any, _RetValT], Future[_RetValT]]]", + *args: typing.Any, + **kwargs: typing.Any, + ) -> "typing.Generator[typing.Any, typing.Any, _RetValT]": + self.begin() retry_state = RetryCallState(retry_object=self, fn=fn, args=args, kwargs=kwargs) while True: @@ -39,7 +49,7 @@ class TornadoRetrying(BaseRetrying): try: result = yield fn(*args, **kwargs) except BaseException: # noqa: B902 - retry_state.set_exception(sys.exc_info()) + retry_state.set_exception(sys.exc_info()) # type: ignore[arg-type] else: retry_state.set_result(result) elif isinstance(do, DoSleep): diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/wait.py b/env/Lib/site-packages/pip/_vendor/tenacity/wait.py index 625b0e36..f9349c02 100644 --- a/env/Lib/site-packages/pip/_vendor/tenacity/wait.py +++ b/env/Lib/site-packages/pip/_vendor/tenacity/wait.py @@ -1,5 +1,3 @@ -# -*- encoding: utf-8 -*- -# # Copyright 2016–2021 Julien Danjou # Copyright 2016 Joshua Harlow # Copyright 2013-2014 Ray Holder @@ -18,67 +16,69 @@ import abc import random - -from pip._vendor import six +import typing from pip._vendor.tenacity import _utils +if typing.TYPE_CHECKING: + from pip._vendor.tenacity import RetryCallState + -@six.add_metaclass(abc.ABCMeta) -class wait_base(object): +class wait_base(abc.ABC): """Abstract base class for wait strategies.""" @abc.abstractmethod - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> float: pass - def __add__(self, other): + def __add__(self, other: "wait_base") -> "wait_combine": return wait_combine(self, other) - def __radd__(self, other): + def __radd__(self, other: "wait_base") -> typing.Union["wait_combine", "wait_base"]: # make it possible to use multiple waits with the built-in sum function - if other == 0: + if other == 0: # type: ignore[comparison-overlap] return self return self.__add__(other) +WaitBaseT = typing.Union[wait_base, typing.Callable[["RetryCallState"], typing.Union[float, int]]] + + class wait_fixed(wait_base): """Wait strategy that waits a fixed amount of time between each retry.""" - def __init__(self, wait): - self.wait_fixed = wait + def __init__(self, wait: _utils.time_unit_type) -> None: + self.wait_fixed = _utils.to_seconds(wait) - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> float: return self.wait_fixed class wait_none(wait_fixed): """Wait strategy that doesn't wait at all before retrying.""" - def __init__(self): - super(wait_none, self).__init__(0) + def __init__(self) -> None: + super().__init__(0) class wait_random(wait_base): """Wait strategy that waits a random amount of time between min/max.""" - def __init__(self, min=0, max=1): # noqa - self.wait_random_min = min - self.wait_random_max = max + def __init__(self, min: _utils.time_unit_type = 0, max: _utils.time_unit_type = 1) -> None: # noqa + self.wait_random_min = _utils.to_seconds(min) + self.wait_random_max = _utils.to_seconds(max) - def __call__(self, retry_state): - return self.wait_random_min + ( - random.random() * (self.wait_random_max - self.wait_random_min) - ) + def __call__(self, retry_state: "RetryCallState") -> float: + return self.wait_random_min + (random.random() * (self.wait_random_max - self.wait_random_min)) class wait_combine(wait_base): """Combine several waiting strategies.""" - def __init__(self, *strategies): + def __init__(self, *strategies: wait_base) -> None: self.wait_funcs = strategies - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> float: return sum(x(retry_state=retry_state) for x in self.wait_funcs) @@ -98,10 +98,10 @@ class wait_chain(wait_base): thereafter.") """ - def __init__(self, *strategies): + def __init__(self, *strategies: wait_base) -> None: self.strategies = strategies - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> float: wait_func_no = min(max(retry_state.attempt_number, 1), len(self.strategies)) wait_func = self.strategies[wait_func_no - 1] return wait_func(retry_state=retry_state) @@ -114,12 +114,17 @@ class wait_incrementing(wait_base): (and restricting the upper limit to some maximum value). """ - def __init__(self, start=0, increment=100, max=_utils.MAX_WAIT): # noqa - self.start = start - self.increment = increment - self.max = max - - def __call__(self, retry_state): + def __init__( + self, + start: _utils.time_unit_type = 0, + increment: _utils.time_unit_type = 100, + max: _utils.time_unit_type = _utils.MAX_WAIT, # noqa + ) -> None: + self.start = _utils.to_seconds(start) + self.increment = _utils.to_seconds(increment) + self.max = _utils.to_seconds(max) + + def __call__(self, retry_state: "RetryCallState") -> float: result = self.start + (self.increment * (retry_state.attempt_number - 1)) return max(0, min(result, self.max)) @@ -137,13 +142,19 @@ class wait_exponential(wait_base): wait_random_exponential for the latter case. """ - def __init__(self, multiplier=1, max=_utils.MAX_WAIT, exp_base=2, min=0): # noqa + def __init__( + self, + multiplier: typing.Union[int, float] = 1, + max: _utils.time_unit_type = _utils.MAX_WAIT, # noqa + exp_base: typing.Union[int, float] = 2, + min: _utils.time_unit_type = 0, # noqa + ) -> None: self.multiplier = multiplier - self.min = min - self.max = max + self.min = _utils.to_seconds(min) + self.max = _utils.to_seconds(max) self.exp_base = exp_base - def __call__(self, retry_state): + def __call__(self, retry_state: "RetryCallState") -> float: try: exp = self.exp_base ** (retry_state.attempt_number - 1) result = self.multiplier * exp @@ -178,6 +189,40 @@ class wait_random_exponential(wait_exponential): """ - def __call__(self, retry_state): - high = super(wait_random_exponential, self).__call__(retry_state=retry_state) + def __call__(self, retry_state: "RetryCallState") -> float: + high = super().__call__(retry_state=retry_state) return random.uniform(0, high) + + +class wait_exponential_jitter(wait_base): + """Wait strategy that applies exponential backoff and jitter. + + It allows for a customized initial wait, maximum wait and jitter. + + This implements the strategy described here: + https://cloud.google.com/storage/docs/retry-strategy + + The wait time is min(initial * 2**n + random.uniform(0, jitter), maximum) + where n is the retry count. + """ + + def __init__( + self, + initial: float = 1, + max: float = _utils.MAX_WAIT, # noqa + exp_base: float = 2, + jitter: float = 1, + ) -> None: + self.initial = initial + self.max = max + self.exp_base = exp_base + self.jitter = jitter + + def __call__(self, retry_state: "RetryCallState") -> float: + jitter = random.uniform(0, self.jitter) + try: + exp = self.exp_base ** (retry_state.attempt_number - 1) + result = self.initial * exp + jitter + except OverflowError: + result = self.max + return max(0, min(result, self.max)) diff --git a/env/Lib/site-packages/pip/_vendor/toml/__init__.py b/env/Lib/site-packages/pip/_vendor/toml/__init__.py deleted file mode 100644 index 34a5eabb..00000000 --- a/env/Lib/site-packages/pip/_vendor/toml/__init__.py +++ /dev/null @@ -1,25 +0,0 @@ -"""Python module which parses and emits TOML. - -Released under the MIT license. -""" - -from pip._vendor.toml import encoder -from pip._vendor.toml import decoder - -__version__ = "0.10.2" -_spec_ = "0.5.0" - -load = decoder.load -loads = decoder.loads -TomlDecoder = decoder.TomlDecoder -TomlDecodeError = decoder.TomlDecodeError -TomlPreserveCommentDecoder = decoder.TomlPreserveCommentDecoder - -dump = encoder.dump -dumps = encoder.dumps -TomlEncoder = encoder.TomlEncoder -TomlArraySeparatorEncoder = encoder.TomlArraySeparatorEncoder -TomlPreserveInlineDictEncoder = encoder.TomlPreserveInlineDictEncoder -TomlNumpyEncoder = encoder.TomlNumpyEncoder -TomlPreserveCommentEncoder = encoder.TomlPreserveCommentEncoder -TomlPathlibEncoder = encoder.TomlPathlibEncoder diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index ca82ded3eb81ec38fe627461a835663545c2b4bd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 760 zcmYe~<>g{vU|^UdaWM5Y69dCz5C<7EF)%PVFfcF_moYFfq%cG=q%fv1<uK+lMKLjg z*vvVMxy(__j0`C(Q7kE}QLL%VS!_{ksmxjIQS7PASsYOusmxiNQJksFSzJ+EsZ3ei zQQWCaSv*lZsZ3eCQM{>4S$t7^sZ3e?QT(Y)Sprc4sZ3ddQG%&VSwc}lDQv+En(S3R z0hJ{g`FRSt`6;D2sS4#8naLRn1&Kw)sl^J3c_|91xtS%!3L*Z!K6+eSL8&>ZiN&cY z3Z;1|sYMDU8L0}so*@c3naQbn#i@E+FG2p(WW2?mnwOlPl3D~}rlf+IRcr=&h6Z{@ zRjdYjrg{c`n!>l(<Kt8EljGx~1PU?>^y14>^HTDQ^h)w`bBaJ=Q^d@`z;KH@KE5oq zs5mn}FFyVjTYParYI6K7mYn>=lv}JIviKHvNPcdP3&fUN{0NR~QBi);Eh&&dKv8OO zYEfCLbAE1aYF-IUF-uBmZow^95D7KL72@t&k|14<MMa5~!Knp_MTsT(MKCE@kQB^7 z&%B(>yi}LW<Pw;)07%-eG`FA<CW6fcFgYQR>VU+OjGW9QsMtz|A`u1#2=S}d*(xTq zIJKxaCN(D|vna+tFV&?evn*9XS0U8TGt4z8*fYd2Si#fJ#oy00*wZm4*wxoHIK(wb z!7L^qz$YfrL^mftJ+rtZGdm_VuPnwVGbyGxvm{lwATc>RF+H_7rXaIG9~$)fprF@} vkI&4@EQycTE2zB1VUr6^7IuuFbgIO_z`(-F!^p$L!pOqJ#t4N77FYxTi}U7p diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/decoder.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/decoder.cpython-39.pyc deleted file mode 100644 index ee3886f5664d4469ce2cb19412609f523febcade..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 23252 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%0AtE6#vDkb`+*z<ius}#1_p*gP#vQO zigRHOMiE8>MlMDkMjl2XaE-#j#K8!IT#O=2TudxXOpHQ|e2iedRRVF*j=E8ax>W|c zmhrl=+A1hbIZ%rg)ZYa+pyu!}Fr+ioGS@JrFqSeDiIgzF%Xr3xpuQDLEo%u=4MPcY zGgGlq2}=qSsB8v{ur@OlyVWo(U`t_M$Ovjr)UuVZgF3af>?tg@94V}|oGEOzTq&%z z+$pTJJSpt8yeX`;d?~E8{3$H80x4{@f+=jZLMa@z!X+Fv?9GfW3=>#mV`7+UMQTNB zL{mU5fNeGGH6ke-;tZe`MK)8>wiIrVhz&zwSB<~~rlN=%!5UF>hFZZI(G;$1rlK1q zoGCmtY&9ay%uS3noD&#}^lC(FKr&q^thHh(9JS&#A~oXKtP>cEq(COsh)aOX=FMgT zi-_?s)QZ)Jr*N1v)QT6rs}U>iO5v*&fcd4cEAL&6Kne#~^`;up1zZamCNLIxfz%Xs z<)zh#rtpL1Vp7;^`3t-9LTW@8a4%#i?y3<@5y)l&(}G|XRfS!7W;Og1n2KaT?nvPP zy91;fBqEw31X5MJtVT3NIGYKiDuun4vqrR*tFS9Ct41J&4<ZV8!<!oZqArL@pwOz7 zsF47<uDGj4B85Mjxu`3JqgJ30<PNAEAQuv)UIc8D3n<QN1XCDOL_uw~1w0EGYK6dY z$Xd&vCsM+hB32_R&X6K5&HxX8nA;!KaHR-kGf!YDdIXArDg%(c(2$4tZXPVmYs6C| z!1fhQU@Dw9fvK=4oFPwyg`tFZ0#oG{NDBedGJvZ*Q^U=}P|IDzUCWurR>R4|P|I1v zIf1F@UW#xnR~`!}4c0)yleuU|4OfbAHuD7Lq8+gGkiuFkSyhDOB2dUP7nz{Bh`ER* zg}qjC0&}6s1m;2(kZd;71m<Ets5_X8ifSY$fJk;w3IoR`C{=+(P*T+d=0ZQXpO`B< zQ2Zn|fw_1E*qlXJeZ^d~B}E9ySCZLG6IhCzYB(pb6g$=Mfk_@PDN-wy!d5F?WmLmn zBL&Vq%oA9Ocxt3;7(je;hFWQGUXrq5sF4Dvcc}@?h4;c4@?^lF%~Giaa~UJU1lGb= z&`{?9o6fX=uSU2=s7AVmcOeTSLyc&P6xbzmz%H2scFCL?kW1#&@J?VUno`0K%Hfc_ zoXs+UrKk@S;?SH8(c728UdxjQ3T3`Ljv5ZIn>cDjQ>4Kr-vgU`4`ebp?)dW5K;{=+ zgO~#jZ>UO8X#+9Af}s{<0#`QE1lFQiU=zO7a8F<@ssWM3Y$cp2GVs(2E@{B#fYKyu zu@;iapftf+GyyEa2T}uOf%7cbY={h)50bHA0FfyY*i?c;T?8a&!;mLZ!!d!is0Siu z!vOX@Z;de6@4|&$HN22KEy<9=4a&nHQzaQvWI^l{)>_^gzT&PLo?>vmmt;r*<y6+9 zJ0+Ycaxh<kay_h!1ecj?MGPgJDe^UJCH$bW8d^@W6^WH_rYInbrm#U;^`Me{fnW+3 zsEkixtd&V&1DEHrDJ->eB^)3#To@*>#RkPN)ymf@)X1l>WV1|QE6S^p1KCg`4=LH2 z89{Mv&QL2?!?ZxCM!tp>JQl}2fvspljqC)r;t45SHQZ&46WEGo)F><vUdT|ZP@|B- zmd!MQt!Pt?%mlU~Cy=_LO%vD(ooZwzuot}p^H0=p*C?1X)N<!>z*s4)wX!L!wTd;| zDWIM#D0Q(FeW_7M5tU>BrKVcNJf{-=8ii)Y6uxYh3G78?5IKnYY^Dk9`6e|ADT<N| zXd+4oky^zX#R=?1GpdAYm==iCa4%$xVX9TCRSsv!Gh<;W5uLzZ*}}+BtHQ`oB~!v# zB37f)%vi%#BL@oaaE3^R6vkSWI+Z*w2yMV%z)+)9!&)O_1CjxUab8dfe+@S%+$0!k z#cRY<M8R%7SHoQ+4(<~(O<*rNS0l^AP%8^6jVu^y#V4>AE~$~7z+UvIh8tE=LqZ1J zqvHmLodP^mxQn)c@(MI8K(!i2kyHt1iZaZlH3}&lk__Oy%~50r%AYj~DSRo6pc<f7 zAw{KDHBSJf1}-99tD3@5D^kO>K)gm_A!Dst3Tv%;jhYKXtU;|tjrs(R;<_5u8jUiB z2^>Xrj0_Vv3a8bG)MzY_s8L<WXwFb8QlrkpP^&(HqcEjLVS!+cYK_Q3rdkDv3!$Y4 z!vv1vV~`jFrIQr4Y~~3ZMVCrAQ&i#ZR$Tyc7qqTg$hbf-g?}Mqt!4^Ktw@bX34e`d zGh;Tx1g;{H8qFFJNd}NPAeIdSNDd^@%m_}$oJ9{n;*t#DFawnWoW)K^BA}82uBKKC z;=)>~8ZD6e8ZA(Y%VwIuSyWWQU!w(zOE7OAti-L60@(*jhvE#`EE713mXvU&sMTnR zGo+}CGo)yM>r!x<N#S200J6763KaGW89^?t)tbOr7*wN`!U3t1LGm^X=?owml-odR zZ5Z-2N+cIZfy5*k7BWuYD&_#&0rs~zLy9KC4v_0XaWH|S@Ldh4-6suk9k^x27~53~ z4Xs-38f|dS<SOzg;Y`tjg?d#@4Qq|IBm*M@EQ~>UKbvU+SJ9yw?HcAXP>A=`FfWj) z(FTnT)bN00N;p%rVJ766fyI_V%vm4{8rNUQ08*PLQ^J{|Q==`;kfJNjP$C8znLxNa zoFQ)q3quLZ1nx>1NUc@F3JUvL)*9^^)-uKk+(i-)vp^=>pt}zw%Y#sp&InNz$&i=C z!cZbNfxEH>YAQ7Cfc?chfxF19hIxT3)Hh5E7#A`?bfWp6yQrcDWPSz24M^rQ8Gv<2 zf<|3Hp`lX619LgFjR3NJ4a9ax4LpIXP$lm{4I~%qWiw6SDbj-Eh7|p5kefi|zX2>n zt3Y{CzD5C5w$#Xi>S}li#Z#$9S_zexl_FB3P{sf%i^1k9Ak3}RK{B_FG;?coQW#4? zCBIXRP7HIcOf7e<EV!fs&3+mtx-c>@fX6S26+mNgdFh}53((XNWUK>qRHxWVAs9Tf z2kQGKr79GF28|${dr;q>I^!_lu>x9-u~<PySP~WT^7C||p3W>*KpLq4c?QvA1$SWy z4YT-FDY}A(2S7de;{4pyk_-?lCo?-$ArTt1w^&L`(k#G39&Wc7LcqhQzZiMJ6Cy?0 zpjksB@6<~07@R^{eraBc0;rdtUs?hhiz!XjQwT~;OwLG6QAo{80SzC3rbP69F~+<E z^|ry|u0__MelDo*`HNBM7o++wM%yCLD1Mb1c*F-jpp=}ESd^Gtl3D~BPsoPaX{DfE zC8MsV5K>gBP*|E@0&+iSv;rot2c9SY#i;y?G5Qx{Y?WYWUQ%KXXcjyLtUk5)7b9nt zD8wdk|6U<GwGuQKp{Gzqn$JMpdA%zA(7ck=qTI~9M9@GQG^W4-gAo*94KM%w|NsBx zU(iUkj(<UF9>@bA$EO$Nmlh}_6(uHTr-H^>6hHx|kW{IVSpu33)T?5Ojjd7w1wBM% zUOre=B8EB<Pw0RgR9#|js)BkIkGeuIJi@EE%R%Ec<wf~<>3UT{Xu+9TqF1HioS3Ix zqL7hT21*&(sg)4JKvAubn5O^<I8dln={n{qWabv+WF}{p<Wwr8q^4!&fd(!?gC?M% z9rY50q*Ra|@PKL+TX;rdiM>LVfI?ypXrQJNGNe>&e~YpD7GrIdj!$M@szOpxYGQV= zLSj*>0?40<IXU^|si47E1;`v*eo_`_kV{jsC=!&GK*RCi5uYLf5H}7)m@_ai++u?c zzJ!4|oT+)Gxv52oC8^+f$y@B1#l;1Q$*CYlVoqLZ?k%<=Q2Z6#;_}Q(Nv!~9sapcz zQPQHa)OhF=U=e8Y?iNc{erDb+*5ZPk%#vGtskuq1DKG`aMW9KUTU?+qBG8mUX=;%y z$VH+cM~Hx?;NrpB;`8(3K}k5ZxCk_4c#Ah49LS(hjW0^Q#hRN~lALjiExsr*FFh4B z&y<^AmU@dVv7jI|FXa}8cWNcXg+gG9AORB(37K1*U@=e<($u}hSPUMDDoOx3fDaZ~ zV9Sa@=9YkFIC+vwi;7b7N^(-mQgd!`<QHY8XXYj5++r%uxy23|WJ@e6y2S-zfWjy* z{T4Tr4a%mscydc~N-{zA6_*s<;swWbej0e>thh)YWG@FS5#8cU$uB8MP03EJyu}X9 zdyu(8j)J1pvUspK$fWqZ{9BBfw^%@Pk+*pAQ&N%=le3F+5{ol#F=pT5$V;sNPgCCF zEGfz?00-nP#w^IJ9S7JsAd~pOEVxeaRQfIE%#;ey;9y?rEw<#G{NmJ<BGA<NE!Hy7 zAoeZh)S{wW9N;(t`Gy;8HiUbN4a`Zo#RaCpg16Y9LCFE3ONwr>f?2nii&9G<Lwn$v zJ6=#K2w`AgSPB~2I|M2a`9ae|pn*IV(BcdxE=DdUkO*i>2@7TtVw7OyU}R!s0}uYO zFtYq-VFIy1YGoMN7`eccQ6L`3JO~d$N`WV&*#5IHvi)aaLRP`U2%5BF0_#O)gGAYw zSQwf9Gl4J@%Rd%o5k?k9&@dwhcrcO=Y$F>Z8xwey0TT-&NFHQ1Oby5{Qj9{3Y>Wbo zAk|=XNb1EHnV_y=V&r4wVdMa-1E~~XgvhZms({opfn*@Mg&5hGAohc%&Q%!2{<AO% zFiL^V2ZbINqYQY66l5MK6xcvKa5%9ra{Oljg)uyogc!LPC75`a#27gk#TZ$@YbCgt zAX9pLj36k)$oHRxiSHj1GaK0F0*q?l2|YF@9!3f9<UJcBA6N%yWe^C1;siwVFoM*8 zLIV^75cl(e!wobk2vP-_B;;chU{nFy0ZIizj9mX&m^i?Lys&U*`o{zgdnrZ%Mj<9} ztRTe*Xwp%L5fmPf)WF0D(#^%l#mL6U!o>2AjhT&6gqZ^zgKYnpm|6aEu<(J^gWL}q zFb0JIh%Lg%!3gpr4>%@3eutUJ#mMxZgGqo<gOQ67lujT#HAc{!b`dB&qs)bHFfcH{ z2bUj#mLM|LGNv%pGF80*t<h>`Okv7qDS8K;2nJ0$->U(4u0W0F6xM8}B9|J56t)x= zP&cQRIfb>BB`*go0+}jiO<}KLEn_IEsbO8fl)}D{v6iidHHD#u4Whn=wT2BksmzjR zlEML2y8^711Fu?+6wqKdYb|pPOA13NW6^;U<{B2zWM>HrX!^C85wygygrSDHnNfm4 zm_dZ0nX#5JPXIJk3tHm^vK^#4oFPwwg`tFX0%Iiyq|pxYJEY;B!coJJ!VPg<8RG=T zA_dS2gsNrGaNz_E_!gy<uq|K*O_8QBr0_sY1@m}Q_>g$~DVz}ALgrfbyo3_A1#Dnd zMCk#m6i5+-m;mMpr3fSOL{gX_JkT`mLXKK?$bwF=ukJv66$xJTVZczs9?YOA3YjB& z37%>J&8>qQbhj9zUW$OqJSPwVYVf_}0<l0Vl)&xEBG8=KOE3Xi<n<DibY6ne&Pz~H z`4Y6q<Rz#^e+ioI(d2;CysV`K1)%AaOi&$N1e!j-#hjT}0<L3kae$_0N-}d(Z?S+_ znjGLo9k;l1Gn0$*i&K;H^HOdxl~mp0DK1Tda6xq+Ye^M|5=0hE%u6Y$y2S-9;S2IX z7JwElp_S&hxZ=STEyykoCI*ILP(y<OT)Z%WXKTPqu$Vvv8))_hmht$&1u!VXb1?G# z=U^6L1QiURnH^9u$igVY$oG$p1w_j*DnK)A(J^c*2tdIG3fN)|NJe9ZCM6~bP-13D zVa{eLGO1yx0gZyOWHS|+)G+ga=6YCCm@F7-SqcSe7+n}*U)8eKFc-C@FxG<fvx2fH zlKzq!R=EBWH2ncJ3^h#V;I$+*tRTA3B89b<ErqQXG>Xe!!vvZsDVmqUS<9Znx&YLx zW~pJRVHXEy<%Nt3n82$D*cLE@Mi-0Dm9V66*RY8*fM%F#*izUe8B#ziMSj$<fmW9+ zU{2v($XN6PrYeOGs*<6EwS=vPErlPnrWfQ2(CUX8))Iyqwq{01c54QWEin{YfEQZ| z__;ySpA9HEW`Kw^5CK{#15T5_m|{YUwt|{10tSXg#wMm_<`$NTNy#axX;qT2_H}A; za$-TMLUC$gX=+|_s+B?!D23eOfa$2x)Kl=!%c)c-PEO28EK-23BvJsUCP?EJ+OX9t z+R4Dc08QXUH6VLgK`q`Qa7z-Bve`h|Gm47#f*cBJ+=Av9%WiRGq*g%Iw6YZxrKV+8 z++r!t&MYXJ2{ME!qv95GMn%#swv39ToK%dZEuxUr3o<!BB{d%6p<;7TLI#BlC?WGO zihyf*NS%n_fm$J;x(!srvoK15>oqA*+vGnRlMtg6W6@=hkJyWBLCys&5G{%avD`t< zVl2AFSW=V)R`83F;TI#vFGe0n2QwX{r~pKOq*3Y>P)=uIU|;|zchEAX6i~gwRLfMu z2ubwW3`Hkun2Oe=fW*KH<4PFI7>dGb7*d#P7*kjzz=;ktaS2*9C&>U>_6HIdXGmcN zm3HC`wG4$Epyk(+4B&dG0aYhR28&9zY^LHFAUR0}@N%d{AT!MwY8eYTN|;kPKuNif zBToRT0#v{4OW_2$I)w$I3Y;Xls#HVsAQ7MdYEgqbzM#bw3W*9K{=PoY-nky6W9|n@ zzMzzQi?Q?;W9Tp0pw!~jqB2mw8#P%floqF^fYv{QyDc2BNWLWwWyP1|Ls=;xdyB!T zO_R9@6vB{H#EED<gPXBn0#rcX;*2kax;YV)W<V=c8Nfvws8s@56s5<=!zjln!3b$n zfke3&i|&I8G6pmN%6gz=QVc5ZQP&ZJR!86B_XIDl3;}g3T{4qPs&s-=^GY)FQgalF zOOxP>XFyA36w>lRLk6HOgaV`oqUX1g1$~j7CIiZPZ@8z59xyO4l!LqjYM*m3g886~ zjpATXVgx%Elv!cUO=V64uR(5MjADVVS!IRplVD4cOW{c2Y+;OIPvJ`8ZefVxfb4#V z;!NR7;csDx;!2SR?{i>`;s)<<V2I*L5ls<mVTj^Q5l@k5VTj^OkxY?lVTj^Skxr3m zVTck)kqu_hQ~-B@L93(S4g@(IguyulRO3RHy@J{r;8mI{8NvO*m5`;PU^ZI42419E z3kw7W#wroSNK+AFbt)**V77wTa7#fIc@21#VK4*O%A!Z0+|CGD7zz$+Fab(MMWEh$ z1Cm|R$abME!$2t!K-Pg84`6?Sy3p?6W#KIhDNLaCpe2mWEVYa^jLo10-OPR%aR_oT zI1aHVxhf~@?tpf*!6^%|4#x#FhLo9%o=VR-=jSCCrIvuI3H0QOnM}c>ilA{l5cVtq zElo;9N#5YWOVBE+<P4A`WHb;oJeC5nJ~1b!QUSE!CO;7|;t4Vg)FgromV$U73^hKd zI3G0hhm?iTynx~+zoLgYvdt|q>><zsi&zfEq9>p<zywKepj-xBs|*%LOMth;5D||Y z;LRZ8K(zn^qX<Wp65$wfO9rJ7SRw@_I#AjKr<edn28J4Nh6R=W3mCwQSXk2;YS~H{ zL6Zw9jM+>@W;Lv!i5yTvrP!>7bpi8221d|gRZt^|C7T7*h6jnJuq<S(Wv>#cVPC+I z!kWUkkST_#mZO$4oFPvNG%W#}J}6;HVFT3&kp4goC&*mTVg-;LHJqSEPBv4~q8d&R zKZU)Fq4*h;%>iX|LTONg4z#G{97I<NXmKq}EvU)#2`bK;%~bTMhHU{WXn7_hL!lYe zZxFYO)v$v$P(b`B&H$oqKx$Z0_&}~KG^=5AVTe_$<pM48so|<&s$s5SS;zufYLUWF z3hKeAFfvSFEcBVcSf~OjUo`olRTHTF@QYCgTwN9AfQF3~VC^PId_sz51<)e9QqTx$ zYKkTkxJ^)$4N}dm3u{JMSZXreVks#qO})jMmY7qVT9gM$gZUt$7(|qS)T?1Ny$rPY z9K{ayqFRt1P-O^iT!D6A6oBizqE?VZ2Plp5K+37bAb}nbu>eFY1hriRk`wb%GC}Qq z$Y@=0(Q1$|KbkOPj2kqlRJ0Z(&sJQLSW;SymdcCT85kJ)KuH?3JeYwA)B^ww@PK*) zOpGFopsqLvqYNY0e<mhS=bh^>6EoLeCKj$gV9W}VXJcgh&&3Sd)dT9LgN8S%<dCxk zxPJl(a_Hb7N?if!K!CPMfO7<>kgj0_ZLV3!SPR-7!JN)e%TfYb%F77uN^D4BsbNZC zm1HPmDB1vFEnonreOAyCVMtROyb2$bKiI?|?Wh$H6N*;Uu%@uHf)-nW78J9BT43f3 z%nUXR$a+&)K&rqtxPbcgDeR!!2@!+XCC*UGTIf>40`73I)G)a)#A?*C)i4*Gr~z&I zVFOJT7H+9wsbPbtHwSfvz}+5@XfT5&haWhhLHhup<OWHmnV?t(C0tErq*MY*7Mkpc z6md&1CBHN&ClxUOSX{Icq;mx*q6HyqgOMa}381S-PX!GO3=C^PsQ|K~95h@6T0IUL zz>)y3A_wgd;rS05_5wA-d6+=`$SMWoSjIN0j8gJ}dgkzwPl*Mz^{|!|R7HbUr`EEi zFx9ey^SVYYM-6+iRtj?sM;Swr79&HULk(*U#{x!B=?Gd9Uc=7AP|IE@R>Qb}DTNud zh@+OXgc(vwH8a+7m9Q*eh42<K7F9u53)n!-poL5zo()3@JBXHKXa<!Zn;>lPh5?Rj z<_U~N$ReB=B3u|E+!!J}7$UsLA`3VcGNkZfi10&1s>Dh-A#MUKSq}%5ZkwPJv0M`v zE1h7YAE3>wCEPHT(9$q!0%PH(5*|bdOkga^1BunJrhq!2(2%L+Mh?9is43vlp9Ljc zDFUFfw}z{z3OQU0t5TR3@YZmqFhEAe7BYhT0kI#%N@uF&OcAW%1chW7!vv<H3n?IT z*+DsJ0%P&N6fPvWAaKls)q=*vK(U|BP|E{O0cM~SFoCH^uZCv<UkwK+H|0sx@T3T( z2)8iQa4cX-5nRX!+A?4c(g98l6POAm^7tU;L*#3DYIwkP7-;zpQ&C+F56s=QJQJ7- z6A*kChFGIo-Wp!;assBJITM%)yJ~oAn93L@Fcod8VE}D3s9~z%1(gytypjyHOkfpY z(?R|Q*=oa(7Y3q1JuvV>DW(Zb#b1y_K+C_Fi`1YZERqaR7P}+^XbE4DT8RKugb@<D z&5R(v4MPpX0#KMTf)-B1FxB$a^4IWzmxVAFErPR3YB*CEB^he?YWP75FTsnjn2Snk zSa?7s4_^wS1w$?01m;4g8kPynMLiJJ@bD1G<AI8ZiZj$g-BHV&CsM<(KnNmJ!v$_n z2-XT!Nz{OH5xXP<Xpuz;SBe-Yt%Nh=`GL1kFju~Uq)(VkBtxDF3qy&>1Qz(R2*@Hp z<{E(-mNaHIhDe5Bh8jVbsWuFdmI=5n7l+j4Zs7VGJfa7w)(~SQp!wh;aCaSCih}y= zklGnsF+T^DiZ4L5vly&)234F2`9%tOrMXF|Md0aRj3zy(c^3?tApwmYrh^vJ^MIQ1 zpgl_y5liS-GJ@-GO{OAWP`S$rp0`3TSpygt7~U~4FcbxXT%n0vVuI^MP#+P|hDWTW zF9P+f!6On?{4S-S$<4%)RM13mv7)AE5vaTdPuW3g2~gdAO9HelC@Hll9yCQ7Uz(Sa zT2!2zUzA#0)C6)Kdr@jZPGWK@cnA~h@LQ~DIr)i@VN3AX-YxbJPhZ#gAXo4J5TrE% z>KcLj%eN#TLp2}=$AhP|z%0<lvwBb{gQq;(Ky4RcL`_wM+I9i==8HhJ6r{dd1#%cm zL1JdnEk4kk9%75rEyzq9XiSt19InMhA3?Uv0qJ1R&QD7#PAw^#1QG%_aX|A~=s^!^ zNP(ufir0Y}-;6Ba`6bA1Zcz0FTFTDHD8gt2n)?7@Ccb~5c@`FCzP~Iie1BM2K?A6u z83s1+YzS!H12kX?YVv?8K|V$$Mn2F$DR{6IG;_fNS`z=Cg9%hUf@W0&z&3)0T|tZH zA@f8MjG);L1?aqu5EBn07n2Ah$R?1vAPkz#sS?GSP*B=UphOD7;C536Wbl;<vUEO$ zDVw24B89nzDUB%@+`|AZ9?NDbI#9z1p5tH!k1sJ79jIXdZBkyy2$D&G&RT#}EMNxD zYk&r0nVT6?*s@uQmeeq(fb=m+GNf>1Go$c1p?roEE^u3kIfV;U5{ffG^oTR0Gm10R zG8cwG_~1ca#%9o{8F((EmZ^prl)*q{7})Fwpk9$ALkh^;2T1;4lZ5&PR8tnS)G(%S zBa0OAz|=y+fd||_il|`(xg269xQ+vfaKUwgmfeFycu_^r%wm&ZfP|+eA7ripyv_qs zC?Wa-lAt8{3`Bs7B5<Kp2;zd9cAG)0B2Xq_LCS|>kemgcvX0LzE-onoGr@UVlLeBS zKywne*b5*D{}xMLYB_YD4yZ#3*?;|wfq_AcnSr4gw3!n!atdm?bNpvw5@Xb1Q~}Rz zf|_+4V73b*2V<2Aayo-J1Dvf<GI$8e)(vR}1_n;pC};r-s0UljQ^JtK2&xBaKyzzM zptJ`{cc7G%!j#QaWKhD8!UB??z>;TE!w4SRv`Jxus{xHkh9Iets9^-PB0xj;#d%OR zXl{zBs0qTW1&yb2L0bC@K-=&cYgtmbYgtp+K^yHsvt}t=*(^mzYFNPLfcm2#HYioX z*t`(kwJa%owX7-Jwd^%4E)21AYC+4sL2BOAuogY5VFNE(Wy=GpVlO<C!d=T*Ws<^Q z%T>cs!zBq`@}D9APE$(IW&d0$Tow!n`3Ve#|H2{L2UsRBR$4%6M@Su4!&!W$hJ6BK zkzWZziXbR_3eVJlwuQuj>;<RYloY;NkiG1+Y=viPm_Z>jfvHFf+<FsO$e02RgIb;x z?pod&9v6n#s9LTXF3_aK1jeEzHM~3wwY+&wHC&)@C;=@)WGuP^;eoe9Ab6lH2_PQt z1jgb!B@8JdAotYpPGBtR1DQR6v9K>i6x>$gtKq9*ECX#ic?WVw4c|h>TK*EY8h(%+ zHT*C))$lbl*D_9EEPPkO4&KlMI$DIWnGqB-6PSvMY8XMKL=7`!t3?SjNKJ}ZHp2v_ z;xwonV+t?0eFRa>n<5S>U1}LYvMKx^c8UbFgad8&1#LuNDw<cruz&;9r$~`Pk^?Qv zXDT{T!?1vJA*hYRuz;(Eu|@#A09+tN2BfltdjStf-vs6&IT(8Z??Q$c)>^?@p;}?k zmY@>81^gufHG<8IB?2`<U{bi5u|{+PbCE!aK#gcKXj4D?LY7*w8nF~vu&II|e}NZI zgT^bEi!5ryQ{+H0HK45<ZY2yU@}Q7TQK*$j;jWd0r0*0(aH}vcg%2zOi)F?<DX6>> zSiS=s65v?{P^c^rN>NVXS;z!tgSJjdrKo^oin;hmifRpG8RG<&B7qb&xR^Sa1rmd* zD|!Qp(G-;wu7ymX*a4>_=At(x3@I8QS3+&q1e?TE!jPf`5-kx1`;jq4yH+AkuY|cq zs+loG47_E+u0|?F2gE8is*y_31+j|kkk!{nq$q$zgGvNIrZ<CJFFApwC?$oxhEal{ z1{%W<8r&+>^Q#hb1#OIjEcgSBLqfNJ7J(XknoJ?LSd#MdbE=fVlV6EBISSyptYpx6 zA0Ua;M9|(`$daxiQ1eie$*t%=sB8v}$b!4(;4vWZ9EV#GxU~r?ze6CUJ*a6`We8co zSCXHd3NkDWv`R2h0kW0{HdO*2a01Pr=oQ@r*>DR)+y+$vOjS%VrA5a<d{8}J1g<7P zOSHfZ*jucSN&wW3y~T?%d~%BgG?-enAJn3>2~W)|O36ztE(WiH1Z|WA?HE<4N-fGy zEe17oky?VFaoWoKQdr|x4>FYpYCsf$C&<CeBEggAj-YlHW9ltN*D9TmjLc#Ma8nT! z(z%(%paBMjl+5(Zl46BKu*X5`AHkD~x4004W>xA)I#cpfi;>pz<)kKpoe4Ij=nKd; z=FGgbTg-Whd72`S(XdmXkU@-<Re`v7Km=%F57H)utZ;(_)KicYXgI6rD~JVZ^nypm ziuQrHOpFW+5buI!v5P=ES;5w7N<->b@MO~ukUKcRBPXDls9UThsl_E_x41#eyP(4@ zw*-(l-~(5RmVk6Im6R3D23Z7}_AHtY65@hPrWL0a78l(ENu2``XF&ubBLl-N#*ABx zxka5IJ}BUCG36E)ft-1Zy8ygkI3Cnhxy70ZSrL|(ntqE7oQ%uR8@izOw-%`4zXWaQ zf|{wI$uH2XKZFKNjDp7YSQu5nCk22eO+k%VE++5-E6@TZ@PZxCA|cS?C(uG9E@lDH z!Y4*9aPt?mz=wkgG!n?d#PpAa8Pwnf*#lbWBLrTa!@;NpZbpNaaDf)@KpNSg2Db#G z79(iCC}@n3jgbR9K?ho(1X2ZRhI24#Fe)%|fJT*=K;|le7dU}T1}(6v5<_mJfO}2g zQB{oAFlb5)l$eV_NAy5jfS?g{ffPt9m>J%_V=htwoeGq~TFaEe0&9(ej$uh*%w{Qy z0j)WaWB`o^6vaT78!)A?TQJlz73vhm6zYJ)AftGo@&ZySxIywSsB8ci8=8#Z79Onq z299QM+5jg7aH|bWfF_`B@g;%QF{h@04|>Q;pACvk(D^S6;K%~?JU}zu;H4bk^?6lN z$U%at86{Xi6IAeEu>hUCfi&H)kO5Rtq%dcLb{aB*2TNG9nTicS)5lQno20M@Gk{Ll z(By=4#UUjixI_f`9Z^<>xD|Z>mulerbc-<&J(d1pU|?7U@)&3kkbzNvQGt<#5p@D3 z9vr#g?2Ob7M)45JDB>Gt1_sdDCh+EAMo{;>mN5m?I$(m#l9w?SJEVYm2~a-hfTo3v zpwVNHTJUDj3$PwgEwVa>g$xUrQ`i<V7MFoqv=Gx4FoOF;j1w61{L(=OJTcX>rEt`O z4w?Wh6Jg6{Dw>qSl*g39TFa5bS<6|&UIH-_Tt9<1`+)mdHK4W%S2k1ei5f;Qn>(AS z=wA(I(T^JT6wtC6Q2PzEZ01J|BdCoDs)LJuz+0D~WiwobSD<{(35>;3P;)>dU7#(+ z94Vj$F&v<+$HjV3Imq~<703p2(CF!`JT15ksQ;5v!vR_qH-WJT%mQy(WCxqWUN{S; ztA=#}YYk`%8F)k-G%g2{5eFT^0b2XTh**V|4Qd^31E~ckB+#hpHqa6pbB0>B35<np zAhtNz9W|`AjG*n=;E}1C8g5XSL6-kyGfZGEs;ObD;g$qX<ks?l=YV(?g2v^7N?2-m zz?+#^CNLEps^I~}Y7Gx){)&Zx88oH_Y9;f4wvK_@mxuCL7#Z@W)bOP6NislGgX15h zlOIh4Y-0+$IOwnw?i41_h#G`#0~Ue12If`{2?kKBwP;-pV+v@y9us775y<7BEl`kt zhByOgtsbfhaO?O@4L3NPxhF6dp37SUYAb_IE(5i0n;C0)(;2|w1KzS;!coFf!`sXV z+6)z&RVz@#TO%OJ0GcJ7z+5C!!v{8pFV6=m4(gXM7wLe+LF0dUCQxy9aESb<;hVrz z{G*0(0qCeQ&Klkt{u%+0tqU2!F)IM_c`g40ra}}o5Z^%5fZf9gbx&Na0H{R`2^|m% z99kgvv1Bt(U@q#YfwsA!BbkD=LZB9K(X|?(8m4UK3Cu;eO1L4tpgfiuA<&q>0@fNq zkXt4&7k1Pz2Qz32`GMO;-~txCBmy;*ioiW@P*cqfQ8Gb>(m-=`kRlq?|1Qc0HJ-%% z@=FvF6*BU3^V3uFQu9keYodx0D>Zq*17zS1coC@Fy2Vvol2}wy3>sPk7weG0F)>i1 z0<_?+s2Nm?gH~b`fhuEg`$ZEv4kiw&>sb>)wRllCs9nGT>)_vF%}XthPrM}vHXJgW z7Y|-kc#A(ZF9k(F2(;Ec9=bUr9^CM_#g>@|sxWTx!<WZEbQgiv6x?D;OuEICm{Zgb zavG>X0v>(4#RA%!af>w%>>h9p1SUY$P!R_s1H%ST5e*um1C1bnnhBs|AH*2NSU@!p zWPP<5BWT?)xbg>03xXRCptZXo3>jbGU}R$EU=m^lt!W0WCk9O)f%Jn$(m)kHSnMAc z6Wc!?_-LC9_-F|wCJ{zHCPa+~nur8p5%4sW1fu|WeKu%4Hy5}j<YTPDY#xAX5R}O$ z&=fqVz5+K7K&@?1M*^}g1myjdtl(O!Xa*>(K&OU*7x9C)4WL(J)u6@2EDQ|ApsJOD zu}TKHCPv?>fiiFcs)zBo0eZey(ISu=z~iPMmqDxt$4(ss0|OtD%_waE)cqfRnoMqP znv5Zuf@q75Zn1#YCxI8&fLFZ~AzIDgF=f!0X%T2336hS%2^^FGz)7PB<o6<wGa#-) zb026UOf_f{5p;SO2NMr72QvpZ10%zKE;$Y{jt~wJu0jre4mOTx4ra)TAy8`-8H3^l z#4iS&Ux~b=34Bx(V+vCXC+4!Ib_N!PD9{RE_FLcp2>=}_R8*D<J?6{>eBfgdN*e+c zbD+ooVenZwnV{qMz-M>XFf=nQU<Qo>fDWgHE*;Wjxy4tUScbH}<`!#lX+dgHkvgaV z0C~3vbO!E9##@~6@!*wU@$rx#0!JK3fe0w#z#e2|W2{mJB^vB5MXYTCrCCsLfG~&+ zaxOUif@UQk3n9{&LCcJ47?BRZ(_}0Ht;8)-1vw2ZhCuNr0dfc^1Q-~rwDC9tZ&C)$ z*Mpn{b`I!tIMDj8EQT`1B0f;Yf;dW&A%?k@xfZmEml5P#Ne0l2IrwBe77!oV(aaD> zgHDbEug-xTZ-~eY_;V#FQA&e+2J$iJm{HJ<3?4?7|5e~A7aT#2nrSpS&@xMr8Ym1w zv4=?cw|Jp3oSd4I1B+#lrJ$K=2FO4xC{+l790Lj_4kiH>4rXvl(bR+VML~!1LCypM z#ltP8qEzrPtG9#;G7I#e2i59<Hkay^RDqY57lGDD++wQ$@53qr*EQgA0?;DdTdWXK z&=Rs+%*h!=MW;ap2p@<5En0`1OeBbLqE%4@s4n94OU#9y9mEbj{^}O!q{)KJoK#3Z z8oY4~bc$xtCy)j<$o4Mq8Gl8fc_&C9fsP9*Y6RH{+KmC8O#-jKEdq7eZ}Fn6@4Ura zm03`97o-@p5EHz-5nLdE0|}CEz#$4IKso3ZhfOZ{NKiXa`B@B_Qv=mLpzbYbwuOrk z)QJVvFD%R)92{&MoS;1@Jd9k-T+9LjT+9NZ9O8V2T+Dp+4D}4D9Qqu}984Tce9RnT M0xSX`v3dq603W2I&;S4c diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/encoder.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/encoder.cpython-39.pyc deleted file mode 100644 index 8b97b1bb72931a01834061a9be164ebc033076c5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9435 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 BQ5FCI diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/ordered.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/ordered.cpython-39.pyc deleted file mode 100644 index 90cfae58691e54ede44f5243c98e1955324a18e1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 999 zcmYe~<>g{vU|^UdaWJ)tk%8ech=Yt-7#J8F7#J9eJs21mQW#Pga~N_NqZk=MY^EHh zT;?cdFq=7tDVHURg^|IXA%!J{wS^&tHI=2AIf~VtA%!i4y@er#J(ancIf^ZXBbY&x z^Cid*O~zZ?{zWONMX4z+naL#}Zb*J^j%!|WeoAT)jO&sL<|c!5AY*1Ir&xx8fgzP4 ziZO*Dim9C;jWLBWg{g%jin*PEg&~S1m_d{ImJrBXm{m~o7@_(>6o?Hn4}^;)7#J8z z7-|@@7;6}snX;Hlm{S;g!9EUVSjpt4$#{!3J|#1`WF^Zj*5cBF)S_FQ@$tzyiN(e7 z@wYhQ<1_OzOXA~;m>3usRx;jVDNfBvTgg}i3g(pzziOPVVnT~ki;81Xb5b&kV*K+` zU5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(O zi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F@{9CK@^f?a^C3a3S5R5R z&A`CG0g6qK;}{sLq%p%q59WcDtRT<iCFZ8a$KT?LkI&6dDa`?~dE(;>OA~V-GGHTb z@j?S2IW;FIKE8;bfq?-+@PSwYAcB>Ffq@NXH3w4>h)=aRg(jI~P&|U-6NEu*P<(<g z-Z(7+Ijaa1EJZvZmxA34_5#@9pfCdo6=MlAsJ-woD-r}50M-j8K>CWnrid{xFn~-4 zo5I0V1mgQ?vftuP&d<q7O)kmI&npHenJ9sR%mO`V1nPkzun6RXB2Y#I2O3x_By_=c cfC-Qtw>WGdabySbdNIgDJd8YyJj?=Y09~`)SpWb4 diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/tz.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/tz.cpython-39.pyc deleted file mode 100644 index 648184f27d9f9fa32c959539c8b12e66a5449dba..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1301 zcmYe~<>g{vU|^UdaWHi+69dCz5C<8vFfcGUFfcF_t1vJyq%fo~<}l<kMlt3xMKLil zxHF_Mr7*WJq%fy4HZw;tr?3PwXtKTp>DOes#a2?4nU|J-i?bv%H#H?Srz9~MB!i5Z zV5XZeFfgPtL@}l?L@}i>rZBZIL@}o@r?9jzM6sl>rm(dzM6sr@r*O0|M6soCrf{_| zM6suE2Qz5$++qvK&&>&`N(Pw)GaJMPx!f7#@+bxdh8o5c#%!h{ffS}1hIocNwi-qd zUBi&Ykism<kiwG9RHTu@n#YvFR>Kg_Si%IBVM}3eWs+oQ2B~F+igBcH!o^rp7=jrz zx%_T1MpdzC8yHv_7!)xwFfjaL)P4E?|Ns9lL7bP&3=9k}L5_LJ#=yX!$$E=Bz9_Lg zK0ht3IJM*!YkYBLdfqMO%)F9YZ1EZSrA5WJIO20N^GZuni#3^Uu@tA~q}}2!$<NJ! zYFWupBn+~o+}SE7v^ce>I3_hGC9^2TKQGm#D6=e8L02Kv&oj(5DA+T^F<8OV&&A)* zHQ3WJCfL>2H8{jINWm;7AiyUk(L^^VKRvU!Br`iEHLonjCo?IgII|>Gw;(Y&J25@A zIHn-8KtH}LH7_N<NFU??{gNuZg34PQ@$s2?nI-Y@tf0{40fjju2O|d)8>0lH2xApL zBtG<DsxTr36d>S;0covaSin%jkj1!=F_=M<(NB}<7H52Xa!z7#aeRCcNP#9(kst#D z!!4HF)ZBcq&mn{eNRTH!J|#7^AUVIFGCrOU<Q!1UGcZ;O!ySQ;$8ZQpE!ZKTERezo zigR&Lj57J%Vh#;))?@@bU?tQ6OerN0n?a#p1h$^7q$)2lHx=Z*Vvu1Bj8(i)iy<-? zR)T^IY^4||Q8HvPlz^-SB{$|2#$F~7i1nIGw^$)bfgP3-Sc-TV7#NB`VOPWtVhMl< zDG&j6510TuinFvN8Irg_T$sBApzeZ8VmJ-t0kG3J7#J8z7*ZIUK~ciw2TszOj1a4_ zS;(AHTq2GX_FPb_Qi@CbG&w-Y1r$i}@wd3*<8$*<N^?@<<8SfA#}}3+=0IeML_z+L z01+}ELLNjYfC#X+5Cq6aMWDO{!o{Fy<6z|A<X{Ftu(+Ql%Po$S#FA7{nNtMv62#pg Z^+>S?HW6glEe;!qlk7lw6&zRs%m6T<7V`iA diff --git a/env/Lib/site-packages/pip/_vendor/toml/decoder.py b/env/Lib/site-packages/pip/_vendor/toml/decoder.py deleted file mode 100644 index e071100d..00000000 --- a/env/Lib/site-packages/pip/_vendor/toml/decoder.py +++ /dev/null @@ -1,1057 +0,0 @@ -import datetime -import io -from os import linesep -import re -import sys - -from pip._vendor.toml.tz import TomlTz - -if sys.version_info < (3,): - _range = xrange # noqa: F821 -else: - unicode = str - _range = range - basestring = str - unichr = chr - - -def _detect_pathlib_path(p): - if (3, 4) <= sys.version_info: - import pathlib - if isinstance(p, pathlib.PurePath): - return True - return False - - -def _ispath(p): - if isinstance(p, (bytes, basestring)): - return True - return _detect_pathlib_path(p) - - -def _getpath(p): - if (3, 6) <= sys.version_info: - import os - return os.fspath(p) - if _detect_pathlib_path(p): - return str(p) - return p - - -try: - FNFError = FileNotFoundError -except NameError: - FNFError = IOError - - -TIME_RE = re.compile(r"([0-9]{2}):([0-9]{2}):([0-9]{2})(\.([0-9]{3,6}))?") - - -class TomlDecodeError(ValueError): - """Base toml Exception / Error.""" - - def __init__(self, msg, doc, pos): - lineno = doc.count('\n', 0, pos) + 1 - colno = pos - doc.rfind('\n', 0, pos) - emsg = '{} (line {} column {} char {})'.format(msg, lineno, colno, pos) - ValueError.__init__(self, emsg) - self.msg = msg - self.doc = doc - self.pos = pos - self.lineno = lineno - self.colno = colno - - -# Matches a TOML number, which allows underscores for readability -_number_with_underscores = re.compile('([0-9])(_([0-9]))*') - - -class CommentValue(object): - def __init__(self, val, comment, beginline, _dict): - self.val = val - separator = "\n" if beginline else " " - self.comment = separator + comment - self._dict = _dict - - def __getitem__(self, key): - return self.val[key] - - def __setitem__(self, key, value): - self.val[key] = value - - def dump(self, dump_value_func): - retstr = dump_value_func(self.val) - if isinstance(self.val, self._dict): - return self.comment + "\n" + unicode(retstr) - else: - return unicode(retstr) + self.comment - - -def _strictly_valid_num(n): - n = n.strip() - if not n: - return False - if n[0] == '_': - return False - if n[-1] == '_': - return False - if "_." in n or "._" in n: - return False - if len(n) == 1: - return True - if n[0] == '0' and n[1] not in ['.', 'o', 'b', 'x']: - return False - if n[0] == '+' or n[0] == '-': - n = n[1:] - if len(n) > 1 and n[0] == '0' and n[1] != '.': - return False - if '__' in n: - return False - return True - - -def load(f, _dict=dict, decoder=None): - """Parses named file or files as toml and returns a dictionary - - Args: - f: Path to the file to open, array of files to read into single dict - or a file descriptor - _dict: (optional) Specifies the class of the returned toml dictionary - decoder: The decoder to use - - Returns: - Parsed toml file represented as a dictionary - - Raises: - TypeError -- When f is invalid type - TomlDecodeError: Error while decoding toml - IOError / FileNotFoundError -- When an array with no valid (existing) - (Python 2 / Python 3) file paths is passed - """ - - if _ispath(f): - with io.open(_getpath(f), encoding='utf-8') as ffile: - return loads(ffile.read(), _dict, decoder) - elif isinstance(f, list): - from os import path as op - from warnings import warn - if not [path for path in f if op.exists(path)]: - error_msg = "Load expects a list to contain filenames only." - error_msg += linesep - error_msg += ("The list needs to contain the path of at least one " - "existing file.") - raise FNFError(error_msg) - if decoder is None: - decoder = TomlDecoder(_dict) - d = decoder.get_empty_table() - for l in f: # noqa: E741 - if op.exists(l): - d.update(load(l, _dict, decoder)) - else: - warn("Non-existent filename in list with at least one valid " - "filename") - return d - else: - try: - return loads(f.read(), _dict, decoder) - except AttributeError: - raise TypeError("You can only load a file descriptor, filename or " - "list") - - -_groupname_re = re.compile(r'^[A-Za-z0-9_-]+$') - - -def loads(s, _dict=dict, decoder=None): - """Parses string as toml - - Args: - s: String to be parsed - _dict: (optional) Specifies the class of the returned toml dictionary - - Returns: - Parsed toml file represented as a dictionary - - Raises: - TypeError: When a non-string is passed - TomlDecodeError: Error while decoding toml - """ - - implicitgroups = [] - if decoder is None: - decoder = TomlDecoder(_dict) - retval = decoder.get_empty_table() - currentlevel = retval - if not isinstance(s, basestring): - raise TypeError("Expecting something like a string") - - if not isinstance(s, unicode): - s = s.decode('utf8') - - original = s - sl = list(s) - openarr = 0 - openstring = False - openstrchar = "" - multilinestr = False - arrayoftables = False - beginline = True - keygroup = False - dottedkey = False - keyname = 0 - key = '' - prev_key = '' - line_no = 1 - - for i, item in enumerate(sl): - if item == '\r' and sl[i + 1] == '\n': - sl[i] = ' ' - continue - if keyname: - key += item - if item == '\n': - raise TomlDecodeError("Key name found without value." - " Reached end of line.", original, i) - if openstring: - if item == openstrchar: - oddbackslash = False - k = 1 - while i >= k and sl[i - k] == '\\': - oddbackslash = not oddbackslash - k += 1 - if not oddbackslash: - keyname = 2 - openstring = False - openstrchar = "" - continue - elif keyname == 1: - if item.isspace(): - keyname = 2 - continue - elif item == '.': - dottedkey = True - continue - elif item.isalnum() or item == '_' or item == '-': - continue - elif (dottedkey and sl[i - 1] == '.' and - (item == '"' or item == "'")): - openstring = True - openstrchar = item - continue - elif keyname == 2: - if item.isspace(): - if dottedkey: - nextitem = sl[i + 1] - if not nextitem.isspace() and nextitem != '.': - keyname = 1 - continue - if item == '.': - dottedkey = True - nextitem = sl[i + 1] - if not nextitem.isspace() and nextitem != '.': - keyname = 1 - continue - if item == '=': - keyname = 0 - prev_key = key[:-1].rstrip() - key = '' - dottedkey = False - else: - raise TomlDecodeError("Found invalid character in key name: '" + - item + "'. Try quoting the key name.", - original, i) - if item == "'" and openstrchar != '"': - k = 1 - try: - while sl[i - k] == "'": - k += 1 - if k == 3: - break - except IndexError: - pass - if k == 3: - multilinestr = not multilinestr - openstring = multilinestr - else: - openstring = not openstring - if openstring: - openstrchar = "'" - else: - openstrchar = "" - if item == '"' and openstrchar != "'": - oddbackslash = False - k = 1 - tripquote = False - try: - while sl[i - k] == '"': - k += 1 - if k == 3: - tripquote = True - break - if k == 1 or (k == 3 and tripquote): - while sl[i - k] == '\\': - oddbackslash = not oddbackslash - k += 1 - except IndexError: - pass - if not oddbackslash: - if tripquote: - multilinestr = not multilinestr - openstring = multilinestr - else: - openstring = not openstring - if openstring: - openstrchar = '"' - else: - openstrchar = "" - if item == '#' and (not openstring and not keygroup and - not arrayoftables): - j = i - comment = "" - try: - while sl[j] != '\n': - comment += s[j] - sl[j] = ' ' - j += 1 - except IndexError: - break - if not openarr: - decoder.preserve_comment(line_no, prev_key, comment, beginline) - if item == '[' and (not openstring and not keygroup and - not arrayoftables): - if beginline: - if len(sl) > i + 1 and sl[i + 1] == '[': - arrayoftables = True - else: - keygroup = True - else: - openarr += 1 - if item == ']' and not openstring: - if keygroup: - keygroup = False - elif arrayoftables: - if sl[i - 1] == ']': - arrayoftables = False - else: - openarr -= 1 - if item == '\n': - if openstring or multilinestr: - if not multilinestr: - raise TomlDecodeError("Unbalanced quotes", original, i) - if ((sl[i - 1] == "'" or sl[i - 1] == '"') and ( - sl[i - 2] == sl[i - 1])): - sl[i] = sl[i - 1] - if sl[i - 3] == sl[i - 1]: - sl[i - 3] = ' ' - elif openarr: - sl[i] = ' ' - else: - beginline = True - line_no += 1 - elif beginline and sl[i] != ' ' and sl[i] != '\t': - beginline = False - if not keygroup and not arrayoftables: - if sl[i] == '=': - raise TomlDecodeError("Found empty keyname. ", original, i) - keyname = 1 - key += item - if keyname: - raise TomlDecodeError("Key name found without value." - " Reached end of file.", original, len(s)) - if openstring: # reached EOF and have an unterminated string - raise TomlDecodeError("Unterminated string found." - " Reached end of file.", original, len(s)) - s = ''.join(sl) - s = s.split('\n') - multikey = None - multilinestr = "" - multibackslash = False - pos = 0 - for idx, line in enumerate(s): - if idx > 0: - pos += len(s[idx - 1]) + 1 - - decoder.embed_comments(idx, currentlevel) - - if not multilinestr or multibackslash or '\n' not in multilinestr: - line = line.strip() - if line == "" and (not multikey or multibackslash): - continue - if multikey: - if multibackslash: - multilinestr += line - else: - multilinestr += line - multibackslash = False - closed = False - if multilinestr[0] == '[': - closed = line[-1] == ']' - elif len(line) > 2: - closed = (line[-1] == multilinestr[0] and - line[-2] == multilinestr[0] and - line[-3] == multilinestr[0]) - if closed: - try: - value, vtype = decoder.load_value(multilinestr) - except ValueError as err: - raise TomlDecodeError(str(err), original, pos) - currentlevel[multikey] = value - multikey = None - multilinestr = "" - else: - k = len(multilinestr) - 1 - while k > -1 and multilinestr[k] == '\\': - multibackslash = not multibackslash - k -= 1 - if multibackslash: - multilinestr = multilinestr[:-1] - else: - multilinestr += "\n" - continue - if line[0] == '[': - arrayoftables = False - if len(line) == 1: - raise TomlDecodeError("Opening key group bracket on line by " - "itself.", original, pos) - if line[1] == '[': - arrayoftables = True - line = line[2:] - splitstr = ']]' - else: - line = line[1:] - splitstr = ']' - i = 1 - quotesplits = decoder._get_split_on_quotes(line) - quoted = False - for quotesplit in quotesplits: - if not quoted and splitstr in quotesplit: - break - i += quotesplit.count(splitstr) - quoted = not quoted - line = line.split(splitstr, i) - if len(line) < i + 1 or line[-1].strip() != "": - raise TomlDecodeError("Key group not on a line by itself.", - original, pos) - groups = splitstr.join(line[:-1]).split('.') - i = 0 - while i < len(groups): - groups[i] = groups[i].strip() - if len(groups[i]) > 0 and (groups[i][0] == '"' or - groups[i][0] == "'"): - groupstr = groups[i] - j = i + 1 - while ((not groupstr[0] == groupstr[-1]) or - len(groupstr) == 1): - j += 1 - if j > len(groups) + 2: - raise TomlDecodeError("Invalid group name '" + - groupstr + "' Something " + - "went wrong.", original, pos) - groupstr = '.'.join(groups[i:j]).strip() - groups[i] = groupstr[1:-1] - groups[i + 1:j] = [] - else: - if not _groupname_re.match(groups[i]): - raise TomlDecodeError("Invalid group name '" + - groups[i] + "'. Try quoting it.", - original, pos) - i += 1 - currentlevel = retval - for i in _range(len(groups)): - group = groups[i] - if group == "": - raise TomlDecodeError("Can't have a keygroup with an empty " - "name", original, pos) - try: - currentlevel[group] - if i == len(groups) - 1: - if group in implicitgroups: - implicitgroups.remove(group) - if arrayoftables: - raise TomlDecodeError("An implicitly defined " - "table can't be an array", - original, pos) - elif arrayoftables: - currentlevel[group].append(decoder.get_empty_table() - ) - else: - raise TomlDecodeError("What? " + group + - " already exists?" + - str(currentlevel), - original, pos) - except TypeError: - currentlevel = currentlevel[-1] - if group not in currentlevel: - currentlevel[group] = decoder.get_empty_table() - if i == len(groups) - 1 and arrayoftables: - currentlevel[group] = [decoder.get_empty_table()] - except KeyError: - if i != len(groups) - 1: - implicitgroups.append(group) - currentlevel[group] = decoder.get_empty_table() - if i == len(groups) - 1 and arrayoftables: - currentlevel[group] = [decoder.get_empty_table()] - currentlevel = currentlevel[group] - if arrayoftables: - try: - currentlevel = currentlevel[-1] - except KeyError: - pass - elif line[0] == "{": - if line[-1] != "}": - raise TomlDecodeError("Line breaks are not allowed in inline" - "objects", original, pos) - try: - decoder.load_inline_object(line, currentlevel, multikey, - multibackslash) - except ValueError as err: - raise TomlDecodeError(str(err), original, pos) - elif "=" in line: - try: - ret = decoder.load_line(line, currentlevel, multikey, - multibackslash) - except ValueError as err: - raise TomlDecodeError(str(err), original, pos) - if ret is not None: - multikey, multilinestr, multibackslash = ret - return retval - - -def _load_date(val): - microsecond = 0 - tz = None - try: - if len(val) > 19: - if val[19] == '.': - if val[-1].upper() == 'Z': - subsecondval = val[20:-1] - tzval = "Z" - else: - subsecondvalandtz = val[20:] - if '+' in subsecondvalandtz: - splitpoint = subsecondvalandtz.index('+') - subsecondval = subsecondvalandtz[:splitpoint] - tzval = subsecondvalandtz[splitpoint:] - elif '-' in subsecondvalandtz: - splitpoint = subsecondvalandtz.index('-') - subsecondval = subsecondvalandtz[:splitpoint] - tzval = subsecondvalandtz[splitpoint:] - else: - tzval = None - subsecondval = subsecondvalandtz - if tzval is not None: - tz = TomlTz(tzval) - microsecond = int(int(subsecondval) * - (10 ** (6 - len(subsecondval)))) - else: - tz = TomlTz(val[19:]) - except ValueError: - tz = None - if "-" not in val[1:]: - return None - try: - if len(val) == 10: - d = datetime.date( - int(val[:4]), int(val[5:7]), - int(val[8:10])) - else: - d = datetime.datetime( - int(val[:4]), int(val[5:7]), - int(val[8:10]), int(val[11:13]), - int(val[14:16]), int(val[17:19]), microsecond, tz) - except ValueError: - return None - return d - - -def _load_unicode_escapes(v, hexbytes, prefix): - skip = False - i = len(v) - 1 - while i > -1 and v[i] == '\\': - skip = not skip - i -= 1 - for hx in hexbytes: - if skip: - skip = False - i = len(hx) - 1 - while i > -1 and hx[i] == '\\': - skip = not skip - i -= 1 - v += prefix - v += hx - continue - hxb = "" - i = 0 - hxblen = 4 - if prefix == "\\U": - hxblen = 8 - hxb = ''.join(hx[i:i + hxblen]).lower() - if hxb.strip('0123456789abcdef'): - raise ValueError("Invalid escape sequence: " + hxb) - if hxb[0] == "d" and hxb[1].strip('01234567'): - raise ValueError("Invalid escape sequence: " + hxb + - ". Only scalar unicode points are allowed.") - v += unichr(int(hxb, 16)) - v += unicode(hx[len(hxb):]) - return v - - -# Unescape TOML string values. - -# content after the \ -_escapes = ['0', 'b', 'f', 'n', 'r', 't', '"'] -# What it should be replaced by -_escapedchars = ['\0', '\b', '\f', '\n', '\r', '\t', '\"'] -# Used for substitution -_escape_to_escapedchars = dict(zip(_escapes, _escapedchars)) - - -def _unescape(v): - """Unescape characters in a TOML string.""" - i = 0 - backslash = False - while i < len(v): - if backslash: - backslash = False - if v[i] in _escapes: - v = v[:i - 1] + _escape_to_escapedchars[v[i]] + v[i + 1:] - elif v[i] == '\\': - v = v[:i - 1] + v[i:] - elif v[i] == 'u' or v[i] == 'U': - i += 1 - else: - raise ValueError("Reserved escape sequence used") - continue - elif v[i] == '\\': - backslash = True - i += 1 - return v - - -class InlineTableDict(object): - """Sentinel subclass of dict for inline tables.""" - - -class TomlDecoder(object): - - def __init__(self, _dict=dict): - self._dict = _dict - - def get_empty_table(self): - return self._dict() - - def get_empty_inline_table(self): - class DynamicInlineTableDict(self._dict, InlineTableDict): - """Concrete sentinel subclass for inline tables. - It is a subclass of _dict which is passed in dynamically at load - time - - It is also a subclass of InlineTableDict - """ - - return DynamicInlineTableDict() - - def load_inline_object(self, line, currentlevel, multikey=False, - multibackslash=False): - candidate_groups = line[1:-1].split(",") - groups = [] - if len(candidate_groups) == 1 and not candidate_groups[0].strip(): - candidate_groups.pop() - while len(candidate_groups) > 0: - candidate_group = candidate_groups.pop(0) - try: - _, value = candidate_group.split('=', 1) - except ValueError: - raise ValueError("Invalid inline table encountered") - value = value.strip() - if ((value[0] == value[-1] and value[0] in ('"', "'")) or ( - value[0] in '-0123456789' or - value in ('true', 'false') or - (value[0] == "[" and value[-1] == "]") or - (value[0] == '{' and value[-1] == '}'))): - groups.append(candidate_group) - elif len(candidate_groups) > 0: - candidate_groups[0] = (candidate_group + "," + - candidate_groups[0]) - else: - raise ValueError("Invalid inline table value encountered") - for group in groups: - status = self.load_line(group, currentlevel, multikey, - multibackslash) - if status is not None: - break - - def _get_split_on_quotes(self, line): - doublequotesplits = line.split('"') - quoted = False - quotesplits = [] - if len(doublequotesplits) > 1 and "'" in doublequotesplits[0]: - singlequotesplits = doublequotesplits[0].split("'") - doublequotesplits = doublequotesplits[1:] - while len(singlequotesplits) % 2 == 0 and len(doublequotesplits): - singlequotesplits[-1] += '"' + doublequotesplits[0] - doublequotesplits = doublequotesplits[1:] - if "'" in singlequotesplits[-1]: - singlequotesplits = (singlequotesplits[:-1] + - singlequotesplits[-1].split("'")) - quotesplits += singlequotesplits - for doublequotesplit in doublequotesplits: - if quoted: - quotesplits.append(doublequotesplit) - else: - quotesplits += doublequotesplit.split("'") - quoted = not quoted - return quotesplits - - def load_line(self, line, currentlevel, multikey, multibackslash): - i = 1 - quotesplits = self._get_split_on_quotes(line) - quoted = False - for quotesplit in quotesplits: - if not quoted and '=' in quotesplit: - break - i += quotesplit.count('=') - quoted = not quoted - pair = line.split('=', i) - strictly_valid = _strictly_valid_num(pair[-1]) - if _number_with_underscores.match(pair[-1]): - pair[-1] = pair[-1].replace('_', '') - while len(pair[-1]) and (pair[-1][0] != ' ' and pair[-1][0] != '\t' and - pair[-1][0] != "'" and pair[-1][0] != '"' and - pair[-1][0] != '[' and pair[-1][0] != '{' and - pair[-1].strip() != 'true' and - pair[-1].strip() != 'false'): - try: - float(pair[-1]) - break - except ValueError: - pass - if _load_date(pair[-1]) is not None: - break - if TIME_RE.match(pair[-1]): - break - i += 1 - prev_val = pair[-1] - pair = line.split('=', i) - if prev_val == pair[-1]: - raise ValueError("Invalid date or number") - if strictly_valid: - strictly_valid = _strictly_valid_num(pair[-1]) - pair = ['='.join(pair[:-1]).strip(), pair[-1].strip()] - if '.' in pair[0]: - if '"' in pair[0] or "'" in pair[0]: - quotesplits = self._get_split_on_quotes(pair[0]) - quoted = False - levels = [] - for quotesplit in quotesplits: - if quoted: - levels.append(quotesplit) - else: - levels += [level.strip() for level in - quotesplit.split('.')] - quoted = not quoted - else: - levels = pair[0].split('.') - while levels[-1] == "": - levels = levels[:-1] - for level in levels[:-1]: - if level == "": - continue - if level not in currentlevel: - currentlevel[level] = self.get_empty_table() - currentlevel = currentlevel[level] - pair[0] = levels[-1].strip() - elif (pair[0][0] == '"' or pair[0][0] == "'") and \ - (pair[0][-1] == pair[0][0]): - pair[0] = _unescape(pair[0][1:-1]) - k, koffset = self._load_line_multiline_str(pair[1]) - if k > -1: - while k > -1 and pair[1][k + koffset] == '\\': - multibackslash = not multibackslash - k -= 1 - if multibackslash: - multilinestr = pair[1][:-1] - else: - multilinestr = pair[1] + "\n" - multikey = pair[0] - else: - value, vtype = self.load_value(pair[1], strictly_valid) - try: - currentlevel[pair[0]] - raise ValueError("Duplicate keys!") - except TypeError: - raise ValueError("Duplicate keys!") - except KeyError: - if multikey: - return multikey, multilinestr, multibackslash - else: - currentlevel[pair[0]] = value - - def _load_line_multiline_str(self, p): - poffset = 0 - if len(p) < 3: - return -1, poffset - if p[0] == '[' and (p.strip()[-1] != ']' and - self._load_array_isstrarray(p)): - newp = p[1:].strip().split(',') - while len(newp) > 1 and newp[-1][0] != '"' and newp[-1][0] != "'": - newp = newp[:-2] + [newp[-2] + ',' + newp[-1]] - newp = newp[-1] - poffset = len(p) - len(newp) - p = newp - if p[0] != '"' and p[0] != "'": - return -1, poffset - if p[1] != p[0] or p[2] != p[0]: - return -1, poffset - if len(p) > 5 and p[-1] == p[0] and p[-2] == p[0] and p[-3] == p[0]: - return -1, poffset - return len(p) - 1, poffset - - def load_value(self, v, strictly_valid=True): - if not v: - raise ValueError("Empty value is invalid") - if v == 'true': - return (True, "bool") - elif v.lower() == 'true': - raise ValueError("Only all lowercase booleans allowed") - elif v == 'false': - return (False, "bool") - elif v.lower() == 'false': - raise ValueError("Only all lowercase booleans allowed") - elif v[0] == '"' or v[0] == "'": - quotechar = v[0] - testv = v[1:].split(quotechar) - triplequote = False - triplequotecount = 0 - if len(testv) > 1 and testv[0] == '' and testv[1] == '': - testv = testv[2:] - triplequote = True - closed = False - for tv in testv: - if tv == '': - if triplequote: - triplequotecount += 1 - else: - closed = True - else: - oddbackslash = False - try: - i = -1 - j = tv[i] - while j == '\\': - oddbackslash = not oddbackslash - i -= 1 - j = tv[i] - except IndexError: - pass - if not oddbackslash: - if closed: - raise ValueError("Found tokens after a closed " + - "string. Invalid TOML.") - else: - if not triplequote or triplequotecount > 1: - closed = True - else: - triplequotecount = 0 - if quotechar == '"': - escapeseqs = v.split('\\')[1:] - backslash = False - for i in escapeseqs: - if i == '': - backslash = not backslash - else: - if i[0] not in _escapes and (i[0] != 'u' and - i[0] != 'U' and - not backslash): - raise ValueError("Reserved escape sequence used") - if backslash: - backslash = False - for prefix in ["\\u", "\\U"]: - if prefix in v: - hexbytes = v.split(prefix) - v = _load_unicode_escapes(hexbytes[0], hexbytes[1:], - prefix) - v = _unescape(v) - if len(v) > 1 and v[1] == quotechar and (len(v) < 3 or - v[1] == v[2]): - v = v[2:-2] - return (v[1:-1], "str") - elif v[0] == '[': - return (self.load_array(v), "array") - elif v[0] == '{': - inline_object = self.get_empty_inline_table() - self.load_inline_object(v, inline_object) - return (inline_object, "inline_object") - elif TIME_RE.match(v): - h, m, s, _, ms = TIME_RE.match(v).groups() - time = datetime.time(int(h), int(m), int(s), int(ms) if ms else 0) - return (time, "time") - else: - parsed_date = _load_date(v) - if parsed_date is not None: - return (parsed_date, "date") - if not strictly_valid: - raise ValueError("Weirdness with leading zeroes or " - "underscores in your number.") - itype = "int" - neg = False - if v[0] == '-': - neg = True - v = v[1:] - elif v[0] == '+': - v = v[1:] - v = v.replace('_', '') - lowerv = v.lower() - if '.' in v or ('x' not in v and ('e' in v or 'E' in v)): - if '.' in v and v.split('.', 1)[1] == '': - raise ValueError("This float is missing digits after " - "the point") - if v[0] not in '0123456789': - raise ValueError("This float doesn't have a leading " - "digit") - v = float(v) - itype = "float" - elif len(lowerv) == 3 and (lowerv == 'inf' or lowerv == 'nan'): - v = float(v) - itype = "float" - if itype == "int": - v = int(v, 0) - if neg: - return (0 - v, itype) - return (v, itype) - - def bounded_string(self, s): - if len(s) == 0: - return True - if s[-1] != s[0]: - return False - i = -2 - backslash = False - while len(s) + i > 0: - if s[i] == "\\": - backslash = not backslash - i -= 1 - else: - break - return not backslash - - def _load_array_isstrarray(self, a): - a = a[1:-1].strip() - if a != '' and (a[0] == '"' or a[0] == "'"): - return True - return False - - def load_array(self, a): - atype = None - retval = [] - a = a.strip() - if '[' not in a[1:-1] or "" != a[1:-1].split('[')[0].strip(): - strarray = self._load_array_isstrarray(a) - if not a[1:-1].strip().startswith('{'): - a = a[1:-1].split(',') - else: - # a is an inline object, we must find the matching parenthesis - # to define groups - new_a = [] - start_group_index = 1 - end_group_index = 2 - open_bracket_count = 1 if a[start_group_index] == '{' else 0 - in_str = False - while end_group_index < len(a[1:]): - if a[end_group_index] == '"' or a[end_group_index] == "'": - if in_str: - backslash_index = end_group_index - 1 - while (backslash_index > -1 and - a[backslash_index] == '\\'): - in_str = not in_str - backslash_index -= 1 - in_str = not in_str - if not in_str and a[end_group_index] == '{': - open_bracket_count += 1 - if in_str or a[end_group_index] != '}': - end_group_index += 1 - continue - elif a[end_group_index] == '}' and open_bracket_count > 1: - open_bracket_count -= 1 - end_group_index += 1 - continue - - # Increase end_group_index by 1 to get the closing bracket - end_group_index += 1 - - new_a.append(a[start_group_index:end_group_index]) - - # The next start index is at least after the closing - # bracket, a closing bracket can be followed by a comma - # since we are in an array. - start_group_index = end_group_index + 1 - while (start_group_index < len(a[1:]) and - a[start_group_index] != '{'): - start_group_index += 1 - end_group_index = start_group_index + 1 - a = new_a - b = 0 - if strarray: - while b < len(a) - 1: - ab = a[b].strip() - while (not self.bounded_string(ab) or - (len(ab) > 2 and - ab[0] == ab[1] == ab[2] and - ab[-2] != ab[0] and - ab[-3] != ab[0])): - a[b] = a[b] + ',' + a[b + 1] - ab = a[b].strip() - if b < len(a) - 2: - a = a[:b + 1] + a[b + 2:] - else: - a = a[:b + 1] - b += 1 - else: - al = list(a[1:-1]) - a = [] - openarr = 0 - j = 0 - for i in _range(len(al)): - if al[i] == '[': - openarr += 1 - elif al[i] == ']': - openarr -= 1 - elif al[i] == ',' and not openarr: - a.append(''.join(al[j:i])) - j = i + 1 - a.append(''.join(al[j:])) - for i in _range(len(a)): - a[i] = a[i].strip() - if a[i] != '': - nval, ntype = self.load_value(a[i]) - if atype: - if ntype != atype: - raise ValueError("Not a homogeneous array") - else: - atype = ntype - retval.append(nval) - return retval - - def preserve_comment(self, line_no, key, comment, beginline): - pass - - def embed_comments(self, idx, currentlevel): - pass - - -class TomlPreserveCommentDecoder(TomlDecoder): - - def __init__(self, _dict=dict): - self.saved_comments = {} - super(TomlPreserveCommentDecoder, self).__init__(_dict) - - def preserve_comment(self, line_no, key, comment, beginline): - self.saved_comments[line_no] = (key, comment, beginline) - - def embed_comments(self, idx, currentlevel): - if idx not in self.saved_comments: - return - - key, comment, beginline = self.saved_comments[idx] - currentlevel[key] = CommentValue(currentlevel[key], comment, beginline, - self._dict) diff --git a/env/Lib/site-packages/pip/_vendor/toml/encoder.py b/env/Lib/site-packages/pip/_vendor/toml/encoder.py deleted file mode 100644 index 7fb94da9..00000000 --- a/env/Lib/site-packages/pip/_vendor/toml/encoder.py +++ /dev/null @@ -1,304 +0,0 @@ -import datetime -import re -import sys -from decimal import Decimal - -from pip._vendor.toml.decoder import InlineTableDict - -if sys.version_info >= (3,): - unicode = str - - -def dump(o, f, encoder=None): - """Writes out dict as toml to a file - - Args: - o: Object to dump into toml - f: File descriptor where the toml should be stored - encoder: The ``TomlEncoder`` to use for constructing the output string - - Returns: - String containing the toml corresponding to dictionary - - Raises: - TypeError: When anything other than file descriptor is passed - """ - - if not f.write: - raise TypeError("You can only dump an object to a file descriptor") - d = dumps(o, encoder=encoder) - f.write(d) - return d - - -def dumps(o, encoder=None): - """Stringifies input dict as toml - - Args: - o: Object to dump into toml - encoder: The ``TomlEncoder`` to use for constructing the output string - - Returns: - String containing the toml corresponding to dict - - Examples: - ```python - >>> import toml - >>> output = { - ... 'a': "I'm a string", - ... 'b': ["I'm", "a", "list"], - ... 'c': 2400 - ... } - >>> toml.dumps(output) - 'a = "I\'m a string"\nb = [ "I\'m", "a", "list",]\nc = 2400\n' - ``` - """ - - retval = "" - if encoder is None: - encoder = TomlEncoder(o.__class__) - addtoretval, sections = encoder.dump_sections(o, "") - retval += addtoretval - outer_objs = [id(o)] - while sections: - section_ids = [id(section) for section in sections.values()] - for outer_obj in outer_objs: - if outer_obj in section_ids: - raise ValueError("Circular reference detected") - outer_objs += section_ids - newsections = encoder.get_empty_table() - for section in sections: - addtoretval, addtosections = encoder.dump_sections( - sections[section], section) - - if addtoretval or (not addtoretval and not addtosections): - if retval and retval[-2:] != "\n\n": - retval += "\n" - retval += "[" + section + "]\n" - if addtoretval: - retval += addtoretval - for s in addtosections: - newsections[section + "." + s] = addtosections[s] - sections = newsections - return retval - - -def _dump_str(v): - if sys.version_info < (3,) and hasattr(v, 'decode') and isinstance(v, str): - v = v.decode('utf-8') - v = "%r" % v - if v[0] == 'u': - v = v[1:] - singlequote = v.startswith("'") - if singlequote or v.startswith('"'): - v = v[1:-1] - if singlequote: - v = v.replace("\\'", "'") - v = v.replace('"', '\\"') - v = v.split("\\x") - while len(v) > 1: - i = -1 - if not v[0]: - v = v[1:] - v[0] = v[0].replace("\\\\", "\\") - # No, I don't know why != works and == breaks - joinx = v[0][i] != "\\" - while v[0][:i] and v[0][i] == "\\": - joinx = not joinx - i -= 1 - if joinx: - joiner = "x" - else: - joiner = "u00" - v = [v[0] + joiner + v[1]] + v[2:] - return unicode('"' + v[0] + '"') - - -def _dump_float(v): - return "{}".format(v).replace("e+0", "e+").replace("e-0", "e-") - - -def _dump_time(v): - utcoffset = v.utcoffset() - if utcoffset is None: - return v.isoformat() - # The TOML norm specifies that it's local time thus we drop the offset - return v.isoformat()[:-6] - - -class TomlEncoder(object): - - def __init__(self, _dict=dict, preserve=False): - self._dict = _dict - self.preserve = preserve - self.dump_funcs = { - str: _dump_str, - unicode: _dump_str, - list: self.dump_list, - bool: lambda v: unicode(v).lower(), - int: lambda v: v, - float: _dump_float, - Decimal: _dump_float, - datetime.datetime: lambda v: v.isoformat().replace('+00:00', 'Z'), - datetime.time: _dump_time, - datetime.date: lambda v: v.isoformat() - } - - def get_empty_table(self): - return self._dict() - - def dump_list(self, v): - retval = "[" - for u in v: - retval += " " + unicode(self.dump_value(u)) + "," - retval += "]" - return retval - - def dump_inline_table(self, section): - """Preserve inline table in its compact syntax instead of expanding - into subsection. - - https://github.com/toml-lang/toml#user-content-inline-table - """ - retval = "" - if isinstance(section, dict): - val_list = [] - for k, v in section.items(): - val = self.dump_inline_table(v) - val_list.append(k + " = " + val) - retval += "{ " + ", ".join(val_list) + " }\n" - return retval - else: - return unicode(self.dump_value(section)) - - def dump_value(self, v): - # Lookup function corresponding to v's type - dump_fn = self.dump_funcs.get(type(v)) - if dump_fn is None and hasattr(v, '__iter__'): - dump_fn = self.dump_funcs[list] - # Evaluate function (if it exists) else return v - return dump_fn(v) if dump_fn is not None else self.dump_funcs[str](v) - - def dump_sections(self, o, sup): - retstr = "" - if sup != "" and sup[-1] != ".": - sup += '.' - retdict = self._dict() - arraystr = "" - for section in o: - section = unicode(section) - qsection = section - if not re.match(r'^[A-Za-z0-9_-]+$', section): - qsection = _dump_str(section) - if not isinstance(o[section], dict): - arrayoftables = False - if isinstance(o[section], list): - for a in o[section]: - if isinstance(a, dict): - arrayoftables = True - if arrayoftables: - for a in o[section]: - arraytabstr = "\n" - arraystr += "[[" + sup + qsection + "]]\n" - s, d = self.dump_sections(a, sup + qsection) - if s: - if s[0] == "[": - arraytabstr += s - else: - arraystr += s - while d: - newd = self._dict() - for dsec in d: - s1, d1 = self.dump_sections(d[dsec], sup + - qsection + "." + - dsec) - if s1: - arraytabstr += ("[" + sup + qsection + - "." + dsec + "]\n") - arraytabstr += s1 - for s1 in d1: - newd[dsec + "." + s1] = d1[s1] - d = newd - arraystr += arraytabstr - else: - if o[section] is not None: - retstr += (qsection + " = " + - unicode(self.dump_value(o[section])) + '\n') - elif self.preserve and isinstance(o[section], InlineTableDict): - retstr += (qsection + " = " + - self.dump_inline_table(o[section])) - else: - retdict[qsection] = o[section] - retstr += arraystr - return (retstr, retdict) - - -class TomlPreserveInlineDictEncoder(TomlEncoder): - - def __init__(self, _dict=dict): - super(TomlPreserveInlineDictEncoder, self).__init__(_dict, True) - - -class TomlArraySeparatorEncoder(TomlEncoder): - - def __init__(self, _dict=dict, preserve=False, separator=","): - super(TomlArraySeparatorEncoder, self).__init__(_dict, preserve) - if separator.strip() == "": - separator = "," + separator - elif separator.strip(' \t\n\r,'): - raise ValueError("Invalid separator for arrays") - self.separator = separator - - def dump_list(self, v): - t = [] - retval = "[" - for u in v: - t.append(self.dump_value(u)) - while t != []: - s = [] - for u in t: - if isinstance(u, list): - for r in u: - s.append(r) - else: - retval += " " + unicode(u) + self.separator - t = s - retval += "]" - return retval - - -class TomlNumpyEncoder(TomlEncoder): - - def __init__(self, _dict=dict, preserve=False): - import numpy as np - super(TomlNumpyEncoder, self).__init__(_dict, preserve) - self.dump_funcs[np.float16] = _dump_float - self.dump_funcs[np.float32] = _dump_float - self.dump_funcs[np.float64] = _dump_float - self.dump_funcs[np.int16] = self._dump_int - self.dump_funcs[np.int32] = self._dump_int - self.dump_funcs[np.int64] = self._dump_int - - def _dump_int(self, v): - return "{}".format(int(v)) - - -class TomlPreserveCommentEncoder(TomlEncoder): - - def __init__(self, _dict=dict, preserve=False): - from pip._vendor.toml.decoder import CommentValue - super(TomlPreserveCommentEncoder, self).__init__(_dict, preserve) - self.dump_funcs[CommentValue] = lambda v: v.dump(self.dump_value) - - -class TomlPathlibEncoder(TomlEncoder): - - def _dump_pathlib_path(self, v): - return _dump_str(str(v)) - - def dump_value(self, v): - if (3, 4) <= sys.version_info: - import pathlib - if isinstance(v, pathlib.PurePath): - v = str(v) - return super(TomlPathlibEncoder, self).dump_value(v) diff --git a/env/Lib/site-packages/pip/_vendor/toml/ordered.py b/env/Lib/site-packages/pip/_vendor/toml/ordered.py deleted file mode 100644 index 6052016e..00000000 --- a/env/Lib/site-packages/pip/_vendor/toml/ordered.py +++ /dev/null @@ -1,15 +0,0 @@ -from collections import OrderedDict -from pip._vendor.toml import TomlEncoder -from pip._vendor.toml import TomlDecoder - - -class TomlOrderedDecoder(TomlDecoder): - - def __init__(self): - super(self.__class__, self).__init__(_dict=OrderedDict) - - -class TomlOrderedEncoder(TomlEncoder): - - def __init__(self): - super(self.__class__, self).__init__(_dict=OrderedDict) diff --git a/env/Lib/site-packages/pip/_vendor/toml/tz.py b/env/Lib/site-packages/pip/_vendor/toml/tz.py deleted file mode 100644 index bf20593a..00000000 --- a/env/Lib/site-packages/pip/_vendor/toml/tz.py +++ /dev/null @@ -1,24 +0,0 @@ -from datetime import tzinfo, timedelta - - -class TomlTz(tzinfo): - def __init__(self, toml_offset): - if toml_offset == "Z": - self._raw_offset = "+00:00" - else: - self._raw_offset = toml_offset - self._sign = -1 if self._raw_offset[0] == '-' else 1 - self._hours = int(self._raw_offset[1:3]) - self._minutes = int(self._raw_offset[4:6]) - - def __deepcopy__(self, memo): - return self.__class__(self._raw_offset) - - def tzname(self, dt): - return "UTC" + self._raw_offset - - def utcoffset(self, dt): - return self._sign * timedelta(hours=self._hours, minutes=self._minutes) - - def dst(self, dt): - return timedelta(0) diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__init__.py b/env/Lib/site-packages/pip/_vendor/urllib3/__init__.py index fe86b59d..c6fa3821 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/__init__.py @@ -19,6 +19,23 @@ from .util.retry import Retry from .util.timeout import Timeout from .util.url import get_host +# === NOTE TO REPACKAGERS AND VENDORS === +# Please delete this block, this logic is only +# for urllib3 being distributed via PyPI. +# See: https://github.com/urllib3/urllib3/issues/2680 +try: + import urllib3_secure_extra # type: ignore # noqa: F401 +except ImportError: + pass +else: + warnings.warn( + "'urllib3[secure]' extra is deprecated and will be removed " + "in a future release of urllib3 2.x. Read more in this issue: " + "https://github.com/urllib3/urllib3/issues/2680", + category=DeprecationWarning, + stacklevel=2, + ) + __author__ = "Andrey Petrov (andrey.petrov@shazow.net)" __license__ = "MIT" __version__ = __version__ diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index b0590e20ffb854e1fd19aaaddc309c7fee8edf69..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2217 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-39.pyc deleted file mode 100644 index 0d9be279d8b2c7d61f720aa03326b027a08b7f60..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10812 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 LCJtscW&s}n=-SuF diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-39.pyc deleted file mode 100644 index c0bd79342a7aeb9d625633d06149e15b205ed032..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 241 zcmYe~<>g{vU|^UdaWK`Mfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}W{4E2o6 z^i2FT8E<jN$CsrR6=&w>#mBE?C}Lt@fDpeLoULL)i&Kk=V^VWcGK*sT^HN=kGRsmG zbQMDVJi}arf;~eVgB3jeT>Sl9gFPK%f?a)GgF{?{6wG1*0(@c;O>}ee(=&@pGP7e+ z^U7j;GLvG8GfPr+3lfvF6Vp?RV+t}0^yAA?^HTDQ^h=9!ax#;QL42@d^a?6(aoFVM Pr<CTT+JPMP8RRbjWu`)J diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-39.pyc deleted file mode 100644 index fad7489d93a83a43191f25236d7f559d3a244f45..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13397 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 QLpBFL2a5n38zT!d0F2=B!T<mO diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-39.pyc deleted file mode 100644 index c25e2fb87d2531988733a761435734aac771227d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 24496 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-39.pyc deleted file mode 100644 index b9f098e35685713970d82289a63bb3930bf72b52..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11674 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-39.pyc deleted file mode 100644 index 56130a5219588566ba17d89f0b54fd2ab1a3bd1e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8189 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 F1^}hfu!;Zx diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-39.pyc deleted file mode 100644 index 4cab2f7c226b170283d267ba4b6af10d53616dfe..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2790 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 DhsDs| diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-39.pyc deleted file mode 100644 index 76b6ecb0865fb55ce8ac8c0e6377b267c8537887..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15192 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 DAr94p diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-39.pyc deleted file mode 100644 index d45e5d369b6050a8e0bb4032ab07b627ea6a015b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5653 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 IVPazj05M>3B>(^b diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-39.pyc deleted file mode 100644 index 1d8c0efa8688b1d8bfd74c549b9ba8e5c0061757..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 20864 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 JP(YM}7XS(J6ITEL diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/_version.py b/env/Lib/site-packages/pip/_vendor/urllib3/_version.py index 97c98330..d69ca314 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/_version.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/_version.py @@ -1,2 +1,2 @@ # This file is protected via CODEOWNERS -__version__ = "1.26.4" +__version__ = "1.26.16" diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/connection.py b/env/Lib/site-packages/pip/_vendor/urllib3/connection.py index 45580b7e..54b96b19 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/connection.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/connection.py @@ -51,15 +51,16 @@ from .exceptions import ( SubjectAltNameWarning, SystemTimeWarning, ) -from .packages.ssl_match_hostname import CertificateError, match_hostname from .util import SKIP_HEADER, SKIPPABLE_HEADERS, connection from .util.ssl_ import ( assert_fingerprint, create_urllib3_context, + is_ipaddress, resolve_cert_reqs, resolve_ssl_version, ssl_wrap_socket, ) +from .util.ssl_match_hostname import CertificateError, match_hostname log = logging.getLogger(__name__) @@ -67,7 +68,7 @@ port_by_scheme = {"http": 80, "https": 443} # When it comes time to update this value as a part of regular maintenance # (ie test_recent_date is failing) update it to ~6 months before the current date. -RECENT_DATE = datetime.date(2020, 7, 1) +RECENT_DATE = datetime.date(2022, 1, 1) _CONTAINS_CONTROL_CHAR_RE = re.compile(r"[^-!#$%&'*+.^_`|~0-9a-zA-Z]") @@ -107,6 +108,10 @@ class HTTPConnection(_HTTPConnection, object): #: Whether this connection verifies the host's certificate. is_verified = False + #: Whether this proxy connection (if used) verifies the proxy host's + #: certificate. + proxy_is_verified = None + def __init__(self, *args, **kw): if not six.PY2: kw.pop("strict", None) @@ -201,7 +206,7 @@ class HTTPConnection(_HTTPConnection, object): self._prepare_conn(conn) def putrequest(self, method, url, *args, **kwargs): - """""" + """ """ # Empty docstring because the indentation of CPython's implementation # is broken but we don't want this method in our documentation. match = _CONTAINS_CONTROL_CHAR_RE.search(method) @@ -214,7 +219,7 @@ class HTTPConnection(_HTTPConnection, object): return _HTTPConnection.putrequest(self, method, url, *args, **kwargs) def putheader(self, header, *values): - """""" + """ """ if not any(isinstance(v, str) and v == SKIP_HEADER for v in values): _HTTPConnection.putheader(self, header, *values) elif six.ensure_str(header.lower()) not in SKIPPABLE_HEADERS: @@ -224,6 +229,11 @@ class HTTPConnection(_HTTPConnection, object): ) def request(self, method, url, body=None, headers=None): + # Update the inner socket's timeout value to send the request. + # This only triggers if the connection is re-used. + if getattr(self, "sock", None) is not None: + self.sock.settimeout(self.timeout) + if headers is None: headers = {} else: @@ -249,7 +259,7 @@ class HTTPConnection(_HTTPConnection, object): self.putheader("User-Agent", _get_default_user_agent()) for header, value in headers.items(): self.putheader(header, value) - if "transfer-encoding" not in headers: + if "transfer-encoding" not in header_keys: self.putheader("Transfer-Encoding", "chunked") self.endheaders() @@ -350,17 +360,15 @@ class HTTPSConnection(HTTPConnection): def connect(self): # Add certificate verification - conn = self._new_conn() + self.sock = conn = self._new_conn() hostname = self.host tls_in_tls = False if self._is_using_tunnel(): if self.tls_in_tls_required: - conn = self._connect_tls_proxy(hostname, conn) + self.sock = conn = self._connect_tls_proxy(hostname, conn) tls_in_tls = True - self.sock = conn - # Calls self._set_hostport(), so self.host is # self._tunnel_host below. self._tunnel() @@ -490,14 +498,10 @@ class HTTPSConnection(HTTPConnection): self.ca_cert_dir, self.ca_cert_data, ) - # By default urllib3's SSLContext disables `check_hostname` and uses - # a custom check. For proxies we're good with relying on the default - # verification. - ssl_context.check_hostname = True # If no cert was provided, use only the default options for server # certificate validation - return ssl_wrap_socket( + socket = ssl_wrap_socket( sock=conn, ca_certs=self.ca_certs, ca_cert_dir=self.ca_cert_dir, @@ -506,8 +510,37 @@ class HTTPSConnection(HTTPConnection): ssl_context=ssl_context, ) + if ssl_context.verify_mode != ssl.CERT_NONE and not getattr( + ssl_context, "check_hostname", False + ): + # While urllib3 attempts to always turn off hostname matching from + # the TLS library, this cannot always be done. So we check whether + # the TLS Library still thinks it's matching hostnames. + cert = socket.getpeercert() + if not cert.get("subjectAltName", ()): + warnings.warn( + ( + "Certificate for {0} has no `subjectAltName`, falling back to check for a " + "`commonName` for now. This feature is being removed by major browsers and " + "deprecated by RFC 2818. (See https://github.com/urllib3/urllib3/issues/497 " + "for details.)".format(hostname) + ), + SubjectAltNameWarning, + ) + _match_hostname(cert, hostname) + + self.proxy_is_verified = ssl_context.verify_mode == ssl.CERT_REQUIRED + return socket + def _match_hostname(cert, asserted_hostname): + # Our upstream implementation of ssl.match_hostname() + # only applies this normalization to IP addresses so it doesn't + # match DNS SANs so we do the same thing! + stripped_hostname = asserted_hostname.strip("u[]") + if is_ipaddress(stripped_hostname): + asserted_hostname = stripped_hostname + try: match_hostname(cert, asserted_hostname) except CertificateError as e: diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py b/env/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py index 4708c5bf..96844d93 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py @@ -2,6 +2,7 @@ from __future__ import absolute_import import errno import logging +import re import socket import sys import warnings @@ -35,7 +36,6 @@ from .exceptions import ( ) from .packages import six from .packages.six.moves import queue -from .packages.ssl_match_hostname import CertificateError from .request import RequestMethods from .response import HTTPResponse from .util.connection import is_connection_dropped @@ -44,11 +44,19 @@ from .util.queue import LifoQueue from .util.request import set_file_position from .util.response import assert_header_parsing from .util.retry import Retry +from .util.ssl_match_hostname import CertificateError from .util.timeout import Timeout from .util.url import Url, _encode_target from .util.url import _normalize_host as normalize_host from .util.url import get_host, parse_url +try: # Platform-specific: Python 3 + import weakref + + weakref_finalize = weakref.finalize +except AttributeError: # Platform-specific: Python 2 + from .packages.backports.weakref_finalize import weakref_finalize + xrange = six.moves.xrange log = logging.getLogger(__name__) @@ -219,6 +227,16 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods): self.conn_kw["proxy"] = self.proxy self.conn_kw["proxy_config"] = self.proxy_config + # Do not pass 'self' as callback to 'finalize'. + # Then the 'finalize' would keep an endless living (leak) to self. + # By just passing a reference to the pool allows the garbage collector + # to free self if nobody else has a reference to it. + pool = self.pool + + # Close all the HTTPConnections in the pool before the + # HTTPConnectionPool object is garbage collected. + weakref_finalize(self, _close_pool_connections, pool) + def _new_conn(self): """ Return a fresh :class:`HTTPConnection`. @@ -301,8 +319,11 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods): pass except queue.Full: # This should never happen if self.block == True - log.warning("Connection pool is full, discarding connection: %s", self.host) - + log.warning( + "Connection pool is full, discarding connection: %s. Connection pool size: %s", + self.host, + self.pool.qsize(), + ) # Connection never got put back into the pool, close it. if conn: conn.close() @@ -318,7 +339,7 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods): pass def _get_timeout(self, timeout): - """ Helper that always returns a :class:`urllib3.util.Timeout` """ + """Helper that always returns a :class:`urllib3.util.Timeout`""" if timeout is _Default: return self.timeout.clone() @@ -375,7 +396,7 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods): timeout_obj = self._get_timeout(timeout) timeout_obj.start_connect() - conn.timeout = timeout_obj.connect_timeout + conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout) # Trigger any extra validation we need to do. try: @@ -485,14 +506,8 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods): # Disable access to the pool old_pool, self.pool = self.pool, None - try: - while True: - conn = old_pool.get(block=False) - if conn: - conn.close() - - except queue.Empty: - pass # Done. + # Close all the HTTPConnections in the pool. + _close_pool_connections(old_pool) def is_same_host(self, url): """ @@ -745,7 +760,35 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods): # Discard the connection for these exceptions. It will be # replaced during the next _get_conn() call. clean_exit = False - if isinstance(e, (BaseSSLError, CertificateError)): + + def _is_ssl_error_message_from_http_proxy(ssl_error): + # We're trying to detect the message 'WRONG_VERSION_NUMBER' but + # SSLErrors are kinda all over the place when it comes to the message, + # so we try to cover our bases here! + message = " ".join(re.split("[^a-z]", str(ssl_error).lower())) + return ( + "wrong version number" in message or "unknown protocol" in message + ) + + # Try to detect a common user error with proxies which is to + # set an HTTP proxy to be HTTPS when it should be 'http://' + # (ie {'http': 'http://proxy', 'https': 'https://proxy'}) + # Instead we add a nice error message and point to a URL. + if ( + isinstance(e, BaseSSLError) + and self.proxy + and _is_ssl_error_message_from_http_proxy(e) + and conn.proxy + and conn.proxy.scheme == "https" + ): + e = ProxyError( + "Your proxy appears to only use HTTP and not HTTPS, " + "try changing your proxy URL to be HTTP. See: " + "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html" + "#https-proxy-error-http-proxy", + SSLError(e), + ) + elif isinstance(e, (BaseSSLError, CertificateError)): e = SSLError(e) elif isinstance(e, (SocketError, NewConnectionError)) and self.proxy: e = ProxyError("Cannot connect to proxy.", e) @@ -830,7 +873,7 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods): ) # Check if we should retry the HTTP response. - has_retry_after = bool(response.getheader("Retry-After")) + has_retry_after = bool(response.headers.get("Retry-After")) if retries.is_retry(method, response.status, has_retry_after): try: retries = retries.increment(method, url, response=response, _pool=self) @@ -1014,12 +1057,23 @@ class HTTPSConnectionPool(HTTPConnectionPool): ( "Unverified HTTPS request is being made to host '%s'. " "Adding certificate verification is strongly advised. See: " - "https://urllib3.readthedocs.io/en/latest/advanced-usage.html" + "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html" "#ssl-warnings" % conn.host ), InsecureRequestWarning, ) + if getattr(conn, "proxy_is_verified", None) is False: + warnings.warn( + ( + "Unverified HTTPS connection done to an HTTPS proxy. " + "Adding certificate verification is strongly advised. See: " + "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html" + "#ssl-warnings" + ), + InsecureRequestWarning, + ) + def connection_from_url(url, **kw): """ @@ -1065,3 +1119,14 @@ def _normalize_host(host, scheme): if host.startswith("[") and host.endswith("]"): host = host[1:-1] return host + + +def _close_pool_connections(pool): + """Drains a queue of connections and closes each one.""" + try: + while True: + conn = pool.get(block=False) + if conn: + conn.close() + except queue.Empty: + pass # Done. diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 40e6d611f523e4472813c5a5e4ea2ff113b25b3d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 227 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>TtG- z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2 z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk xFVZh9%E`%0GS*Md&nqd)Owx~!&&<m#iI3MSsJz8tlbfGXnv-e=a^Yu?PXL)cJ(U0e diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc deleted file mode 100644 index 3e32e8d745d2691a7f5293dae56899ced8c6f0d7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1447 zcmYe~<>g{vU|^UdaWHi+GXuk85C<7EF)%PVFfcF_TQD#%q%cG=q%fv1<uFDurZA_l zv@k?5rLd;3wJ=06r?97Rv@k@mq;RHiwJ=1nrf{e5v@k@mr7#6EX!2G$afM`L7AxfD zr<CTTDijpumu04;7AxeYCgv3@l;kU<q?V*6mnf8Eq$)TT6ezgnrDx`)Dx~I>WftY< z<)-G9=yAOSxyvsZL?UBG1_lOakPCSj7#K<zni&eXN*J3Nf*CX!{WO_w31t??=j10R z=ENr!6r_TUy(O4g9A8kBpMnrt$xy_?zyKkBO>(x12`x@7Dvn9bNy#jV@y|<jDatHM zRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-24N@?R2?+3sNi@;T$xqKLF3HS} zNzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+BkFVZh9%E`%0GS*Md&nqd)Owva< zDjw>6y@JYHJekD^2@a5VK{3O?Sj5J_z<?1ZAUSZDh(N<6U#NsJiz$Usk|BjD8x$kV ziOP%&3_+;{`9&qg3Ylr(kWVZqP{=G+C@Rg%%gjqx$jk$arezitmnfvC=A{-TmSpDV zDHJE>r6lE7=y7o=C@3g|WTYw-rzYp;r68**D$Og&%uOv;NGwWKC`nDu$jeMl%*m-# zC@#s&$pIOi2s1}VA*r-PA+rQ*8YqpFCTA$*q!t$|6r~oI6lErtWR|7sC=};I%?FuM znO~|<oRMFelai-iqL7!GngU8h$r-81*$Qd-MGBcEdSK&<Q&SZ(N=gcft@QPibMi}5 z^wRV5({obwlJj%*;R!-NB|o`XzqlkZFD0=kMIYvNunD&W9RmVf{oFnMT;qd6{X#r_ zU2ky|RF-7q=NXx6GK0ha7E^xlEp}*ZArcaV#md0Ia7zR^`r@Gh2uiTUpr~SCFXF}) zji4k6jz&39=3^{j$YLyG$d>`p3z$-vQkWMqEnrSzS;!d7pvmf2#168FKiD-W%rz)J z*xxNA+%d@Y7DE+}OKMqaPJRI>8|klPDdGgBbWpax#hjj6a*M0DB(bQZxID8Y1L9(k zwGbA_?L{CLih)ubNDBj_03*wP7AB^DU~!C;2hvNTlZ!y%P{hl?z)&UR4vrn9B0#^0 z59C^qu@EPLSzvcDGcYj7U~v~n9K&7kQUatu1r%URRopJA1x2aJi6yBidTvOjgOotH zAbW0!VU!l}xn;S<N+7F2VZ*>wB*?(PpviuVJw84qKRG@g62hRI3658ANELyc1y%?# f8qE?8n_O_wXa{m=F(^b>SU8wDSU9*i*f`h#l_g?R diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-39.pyc deleted file mode 100644 index baa44069aba7776faed88519d3ff6eae68581e63..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8300 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc deleted file mode 100644 index 4470deba90c92bfb21b4b8dff348fd5d12b54a10..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3292 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc deleted file mode 100644 index 86e6bed6938f93244b2d9763c4905e02d23f1776..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15559 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 Bp8x;= diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc deleted file mode 100644 index 3ea8ac016dae5f4200b945e5593622933a9881df..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21871 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-39.pyc deleted file mode 100644 index 8bbdbfc62c257f22db850c24fb51b81e5cc42215..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5663 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 7a98112d02adb973bace1e0d5af4cdc2621eae0b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 244 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<n(1s6 z6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux&p>F46_=Njzk7!&O3>lz&5 z8l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0ns#}nloSm4SS{zf5S)d<ZmYSE6 zU!-4Jl#`R0WUQZ@pI1_pnWP_IoSIx(lv+}hm{(koUsR$WAD@|*SrQ+wS5SG2!zMRB Pr8Fni4&>y|Ag=)cGfYIN diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc deleted file mode 100644 index 5530fef9006d1747934f5a357781467c698c22f7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10751 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 L#K*|TEWil>Z@#hF diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc deleted file mode 100644 index f7b77d6125dde46e61d6fd9ac1b5d34a06c6f2ee..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9200 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 E03bD+(f|Me diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py index 42526be7..264d564d 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py @@ -48,7 +48,7 @@ from ctypes import ( ) from ctypes.util import find_library -from pip._vendor.urllib3.packages.six import raise_from +from ...packages.six import raise_from if platform.system() != "Darwin": raise ImportError("Only macOS is supported") diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py index ed812019..fa0b245d 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py @@ -188,6 +188,7 @@ def _cert_array_from_pem(pem_bundle): # We only want to do that if an error occurs: otherwise, the caller # should free. CoreFoundation.CFRelease(cert_array) + raise return cert_array diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py index b9d2a690..1717ee22 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py @@ -111,7 +111,7 @@ class AppEngineManager(RequestMethods): warnings.warn( "urllib3 is using URLFetch on Google App Engine sandbox instead " "of sockets. To use sockets directly instead of URLFetch see " - "https://urllib3.readthedocs.io/en/latest/reference/urllib3.contrib.html.", + "https://urllib3.readthedocs.io/en/1.26.x/reference/urllib3.contrib.html.", AppEnginePlatformWarning, ) @@ -224,7 +224,7 @@ class AppEngineManager(RequestMethods): ) # Check if we should retry the HTTP response. - has_retry_after = bool(http_response.getheader("Retry-After")) + has_retry_after = bool(http_response.headers.get("Retry-After")) if retries.is_retry(method, http_response.status, has_retry_after): retries = retries.increment(method, url, response=http_response, _pool=self) log.debug("Retry: %s", url) diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py index b2df45dc..47166575 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py @@ -5,6 +5,7 @@ Issue #10, see: http://code.google.com/p/urllib3/issues/detail?id=10 """ from __future__ import absolute_import +import warnings from logging import getLogger from ntlm import ntlm @@ -12,6 +13,14 @@ from ntlm import ntlm from .. import HTTPSConnectionPool from ..packages.six.moves.http_client import HTTPSConnection +warnings.warn( + "The 'urllib3.contrib.ntlmpool' module is deprecated and will be removed " + "in urllib3 v2.0 release, urllib3 is not able to support it properly due " + "to reasons listed in issue: https://github.com/urllib3/urllib3/issues/2282. " + "If you are a user of this module please comment in the mentioned issue.", + DeprecationWarning, +) + log = getLogger(__name__) @@ -60,7 +69,7 @@ class NTLMConnectionPool(HTTPSConnectionPool): log.debug("Request headers: %s", headers) conn.request("GET", self.authurl, None, headers) res = conn.getresponse() - reshdr = dict(res.getheaders()) + reshdr = dict(res.headers) log.debug("Response status: %s %s", res.status, res.reason) log.debug("Response headers: %s", reshdr) log.debug("Response data: %s [...]", res.read(100)) @@ -92,7 +101,7 @@ class NTLMConnectionPool(HTTPSConnectionPool): conn.request("GET", self.authurl, None, headers) res = conn.getresponse() log.debug("Response status: %s %s", res.status, res.reason) - log.debug("Response headers: %s", dict(res.getheaders())) + log.debug("Response headers: %s", dict(res.headers)) log.debug("Response data: %s [...]", res.read()[:100]) if res.status != 200: if res.status == 401: diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py index bc5c114f..19e4aa97 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py @@ -28,8 +28,8 @@ like this: .. code-block:: python try: - import urllib3.contrib.pyopenssl - urllib3.contrib.pyopenssl.inject_into_urllib3() + import pip._vendor.urllib3.contrib.pyopenssl as pyopenssl + pyopenssl.inject_into_urllib3() except ImportError: pass @@ -47,10 +47,10 @@ compression in Python 2 (see `CRIME attack`_). """ from __future__ import absolute_import +import OpenSSL.crypto import OpenSSL.SSL from cryptography import x509 from cryptography.hazmat.backends.openssl import backend as openssl_backend -from cryptography.hazmat.backends.openssl.x509 import _Certificate try: from cryptography.x509 import UnsupportedExtension @@ -73,9 +73,19 @@ except ImportError: # Platform-specific: Python 3 import logging import ssl import sys +import warnings from .. import util from ..packages import six +from ..util.ssl_ import PROTOCOL_TLS_CLIENT + +warnings.warn( + "'urllib3.contrib.pyopenssl' module is deprecated and will be removed " + "in a future release of urllib3 2.x. Read more in this issue: " + "https://github.com/urllib3/urllib3/issues/2680", + category=DeprecationWarning, + stacklevel=2, +) __all__ = ["inject_into_urllib3", "extract_from_urllib3"] @@ -85,6 +95,7 @@ HAS_SNI = True # Map from urllib3 to PyOpenSSL compatible parameter-values. _openssl_versions = { util.PROTOCOL_TLS: OpenSSL.SSL.SSLv23_METHOD, + PROTOCOL_TLS_CLIENT: OpenSSL.SSL.SSLv23_METHOD, ssl.PROTOCOL_TLSv1: OpenSSL.SSL.TLSv1_METHOD, } @@ -217,9 +228,8 @@ def get_subj_alt_name(peer_cert): if hasattr(peer_cert, "to_cryptography"): cert = peer_cert.to_cryptography() else: - # This is technically using private APIs, but should work across all - # relevant versions before PyOpenSSL got a proper API for this. - cert = _Certificate(openssl_backend, peer_cert._x509) + der = OpenSSL.crypto.dump_certificate(OpenSSL.crypto.FILETYPE_ASN1, peer_cert) + cert = x509.load_der_x509_certificate(der, openssl_backend) # We want to find the SAN extension. Ask Cryptography to locate it (it's # faster than looping in Python) @@ -404,7 +414,6 @@ if _fileobject: # Platform-specific: Python 2 self._makefile_refs += 1 return _fileobject(self, mode, bufsize, close=True) - else: # Platform-specific: Python 3 makefile = backport_makefile diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py index 8f058f50..4a06bc69 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py @@ -19,8 +19,8 @@ contrib module. So...here we are. To use this module, simply import and inject it:: - import urllib3.contrib.securetransport - urllib3.contrib.securetransport.inject_into_urllib3() + import pip._vendor.urllib3.contrib.securetransport as securetransport + securetransport.inject_into_urllib3() Happy TLSing! @@ -67,6 +67,7 @@ import weakref from pip._vendor import six from .. import util +from ..util.ssl_ import PROTOCOL_TLS_CLIENT from ._securetransport.bindings import CoreFoundation, Security, SecurityConst from ._securetransport.low_level import ( _assert_no_error, @@ -154,7 +155,8 @@ CIPHER_SUITES = [ # TLSv1 and a high of TLSv1.2. For everything else, we pin to that version. # TLSv1 to 1.2 are supported on macOS 10.8+ _protocol_to_min_max = { - util.PROTOCOL_TLS: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12) + util.PROTOCOL_TLS: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12), + PROTOCOL_TLS_CLIENT: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12), } if hasattr(ssl, "PROTOCOL_SSLv2"): @@ -768,7 +770,6 @@ if _fileobject: # Platform-specific: Python 2 self._makefile_refs += 1 return _fileobject(self, mode, bufsize, close=True) - else: # Platform-specific: Python 3 def makefile(self, mode="r", buffering=None, *args, **kwargs): diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py index 93df8325..c326e80d 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py @@ -51,7 +51,7 @@ except ImportError: ( "SOCKS support in urllib3 requires the installation of optional " "dependencies: specifically, PySocks. For more information, see " - "https://urllib3.readthedocs.io/en/latest/contrib.html#socks-proxies" + "https://urllib3.readthedocs.io/en/1.26.x/contrib.html#socks-proxies" ), DependencyWarning, ) diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py b/env/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py index fce4caa6..e69de29b 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py @@ -1,5 +0,0 @@ -from __future__ import absolute_import - -from . import ssl_match_hostname - -__all__ = ("ssl_match_hostname",) diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 02aa51fa15e346b938ec39b1ff8d34076c0ab5e2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 341 zcmYe~<>g{vU|^UdaWFN9fq~&Mh=Yuo7#J8F7#J9e6&M&8QW#Pga~N_NqZk<(QkYVh zbC`0OqnH^PQkbJyQdoi+G+AGQ^lCER;!jK}&d(_=NsZ6UEyyn_dCADYz@W)^OQ^Uw zCq6f^Bsn8KBfq#LFEKaOPm}c)SA2Y0X-R2OYJ7YV$i`a?MJx;q47b?h;}dgo;^S8` z6mc*xK!{(R&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5 z!JdvW!LGip!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1u zF$I|g`tfC{c`5lt`lUrVIhjeu`Y=iT`1s7c%#!$cy@JYH95%W6DWy57b|CK+gPhF6 H#KQytyA58^ diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-39.pyc deleted file mode 100644 index a62240feffc825fce5986b0c7e43ef59b2e74fa2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 26545 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 801ef48ec8379dbb973b0eef1967c6e3c3f0bfdb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 238 zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<n(S;9 z6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux&p>F46_=Njzk7!&O3>lz&5 z8l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0ns#}nloSm4SS{zf5S)d<ZmYSE6 zU!-4Jl#`R0WULR9)K5xG&MwF=Dk;{FkI&4@EQycTE2zB1VUwGmQks)$2XgFZkf#89 CDnaG| diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc deleted file mode 100644 index 51dce1992154739169f3e848cbcd7c28112c0c8b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1336 zcmYe~<>g{vU|^UdaWJ)$m4V?gh=Yt-85kHG7#J9e)fgBUQW&BbQW#U1au}l+Qy5d2 zbC`0OqnH^PQrJ^iQ`lM<qgYayf*CY9s^)SfB_?MV<QJ6`>*Xe9r>14*q;l0^04^>k zm@<Wuj8uhy%94!yJOyKggoNV!<m}WExaNceh1}GVjQkXZwEQB4(&AKw^30M9g~Ytd zl8nr}bcK?P#1gLZ#JrMXg_3-Q<f7EXl2nC61*Npa>{KNMh+zu(Nm;4MC3;*hK_2we zWW2=@47SD7{}y9WG8;$~ig_6r7(jeykk9!T85l|!Y8aatGZ<1B7c*uv7R!||rZCko zrZI{!G&43arZCqqmNC?_rLchL0;3u>9)?=>8uns`8n$8wFNP+@6jqQ-Ek_DlEoTjT zQA7=A3X3^IEoTi|QA!PG3NwgZ!c@ah!`aMK%T>d`!jQ$B!fwvM#1PM1!<52N%23pi z!dc5y!<536%}_M0ge8j=%3~^8SHn@fs)R9x8|0Q6u3&~5_M&4oY(>XPSQfC=aMf_t zFfC-R<<3*9VK2H-!m@xJEW%XFohMSmR{Q|uz7m!N95B%uj-oF$+`$YbEDJbmxNDee zSZY`ovefd_FxK$IbJg$!GidTuS#c>SC@8?9Pa!`IYn-JO<>$g<RnJrptjUg<fq~%` zV|fvTPO4JN%qvUG$xKnm%}+^HP%To>$j{5ER4CF>DA!R)Qb^3n$uCb$(JW$NU|;}i zDgvd-TMRE585kJ+UjG08|9=sPS*2K-msFaTmRgjWqEK8?l$w}ZtdLt;T%wSas*seK zmsnJ($$g8tIJM*!S6E_BX{u{cQGQVo69WT76kj|noyHfXrWM~}%FMqd?BeR?80r%e z?-c6h<{A_q>>1^Hi_ZyaLr{1?VrCH%KQ%EW6^S2Slv$Embc;76wW7q+KfEZhpdhvA z77NIan!LAIic@paiUdI+!3lA5W?uR&j?}#5{1gz2EfwUp;#=%_spUDDd8xP9%ZoBg zKr-w_sfiFJ5HH<gFG?&2nR<)4D6#w&8^p9*EG4NGB`X<<<QNzjeoc0^iU}=FEh>&l z%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwu ziAglk&B;&CEH25+j!Dfci}A@!iYd-4N!2Y#OwLYBPc4oq$Sly0FH6l!$uH6`Ey~Hs zOfuGoN$SH31ASN^>lIYq5`+oEgC3Oaib16f1DgONA0r1NA0rPV2O|q33z+0!<N}L= zcx+G+5L<weg^`bmgOLZUQh<?-u}Fb|fkBfMoLKz){QNXoZ?VV6r{pKc#}{#f!ki6K qB!J@{tQZ_lNQ68{6^Bi3eoARhsvRha6mu{zFtD(5F!Hc4{09J(DSyuZ diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/six.py b/env/Lib/site-packages/pip/_vendor/urllib3/packages/six.py index 31442409..f099a3dc 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/packages/six.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/packages/six.py @@ -1,4 +1,4 @@ -# Copyright (c) 2010-2019 Benjamin Peterson +# Copyright (c) 2010-2020 Benjamin Peterson # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to deal @@ -29,7 +29,7 @@ import sys import types __author__ = "Benjamin Peterson <benjamin@python.org>" -__version__ = "1.12.0" +__version__ = "1.16.0" # Useful for very coarse version differentiation. @@ -71,6 +71,11 @@ else: MAXSIZE = int((1 << 63) - 1) del X +if PY34: + from importlib.util import spec_from_loader +else: + spec_from_loader = None + def _add_doc(func, doc): """Add documentation to a function.""" @@ -182,6 +187,11 @@ class _SixMetaPathImporter(object): return self return None + def find_spec(self, fullname, path, target=None): + if fullname in self.known_modules: + return spec_from_loader(fullname, self) + return None + def __get_module(self, fullname): try: return self.known_modules[fullname] @@ -220,6 +230,12 @@ class _SixMetaPathImporter(object): get_source = get_code # same as get_code + def create_module(self, spec): + return self.load_module(spec.name) + + def exec_module(self, module): + pass + _importer = _SixMetaPathImporter(__name__) @@ -260,9 +276,19 @@ _moved_attributes = [ ), MovedModule("builtins", "__builtin__"), MovedModule("configparser", "ConfigParser"), + MovedModule( + "collections_abc", + "collections", + "collections.abc" if sys.version_info >= (3, 3) else "collections", + ), MovedModule("copyreg", "copy_reg"), MovedModule("dbm_gnu", "gdbm", "dbm.gnu"), - MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"), + MovedModule("dbm_ndbm", "dbm", "dbm.ndbm"), + MovedModule( + "_dummy_thread", + "dummy_thread", + "_dummy_thread" if sys.version_info < (3, 9) else "_thread", + ), MovedModule("http_cookiejar", "cookielib", "http.cookiejar"), MovedModule("http_cookies", "Cookie", "http.cookies"), MovedModule("html_entities", "htmlentitydefs", "html.entities"), @@ -307,7 +333,9 @@ _moved_attributes = [ ] # Add windows specific modules. if sys.platform == "win32": - _moved_attributes += [MovedModule("winreg", "_winreg")] + _moved_attributes += [ + MovedModule("winreg", "_winreg"), + ] for attr in _moved_attributes: setattr(_MovedItems, attr.name, attr) @@ -476,7 +504,7 @@ class Module_six_moves_urllib_robotparser(_LazyModule): _urllib_robotparser_moved_attributes = [ - MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser") + MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"), ] for attr in _urllib_robotparser_moved_attributes: setattr(Module_six_moves_urllib_robotparser, attr.name, attr) @@ -678,9 +706,11 @@ if PY3: if sys.version_info[1] <= 1: _assertRaisesRegex = "assertRaisesRegexp" _assertRegex = "assertRegexpMatches" + _assertNotRegex = "assertNotRegexpMatches" else: _assertRaisesRegex = "assertRaisesRegex" _assertRegex = "assertRegex" + _assertNotRegex = "assertNotRegex" else: def b(s): @@ -707,6 +737,7 @@ else: _assertCountEqual = "assertItemsEqual" _assertRaisesRegex = "assertRaisesRegexp" _assertRegex = "assertRegexpMatches" + _assertNotRegex = "assertNotRegexpMatches" _add_doc(b, """Byte literal""") _add_doc(u, """Text literal""") @@ -723,6 +754,10 @@ def assertRegex(self, *args, **kwargs): return getattr(self, _assertRegex)(*args, **kwargs) +def assertNotRegex(self, *args, **kwargs): + return getattr(self, _assertNotRegex)(*args, **kwargs) + + if PY3: exec_ = getattr(moves.builtins, "exec") @@ -737,7 +772,6 @@ if PY3: value = None tb = None - else: def exec_(_code_, _globs_=None, _locs_=None): @@ -750,7 +784,7 @@ else: del frame elif _locs_ is None: _locs_ = _globs_ - exec("""exec _code_ in _globs_, _locs_""") + exec ("""exec _code_ in _globs_, _locs_""") exec_( """def reraise(tp, value, tb=None): @@ -762,18 +796,7 @@ else: ) -if sys.version_info[:2] == (3, 2): - exec_( - """def raise_from(value, from_value): - try: - if from_value is None: - raise value - raise value from from_value - finally: - value = None -""" - ) -elif sys.version_info[:2] > (3, 2): +if sys.version_info[:2] > (3,): exec_( """def raise_from(value, from_value): try: @@ -863,19 +886,41 @@ if sys.version_info[:2] < (3, 3): _add_doc(reraise, """Reraise an exception.""") if sys.version_info[0:2] < (3, 4): + # This does exactly the same what the :func:`py3:functools.update_wrapper` + # function does on Python versions after 3.2. It sets the ``__wrapped__`` + # attribute on ``wrapper`` object and it doesn't raise an error if any of + # the attributes mentioned in ``assigned`` and ``updated`` are missing on + # ``wrapped`` object. + def _update_wrapper( + wrapper, + wrapped, + assigned=functools.WRAPPER_ASSIGNMENTS, + updated=functools.WRAPPER_UPDATES, + ): + for attr in assigned: + try: + value = getattr(wrapped, attr) + except AttributeError: + continue + else: + setattr(wrapper, attr, value) + for attr in updated: + getattr(wrapper, attr).update(getattr(wrapped, attr, {})) + wrapper.__wrapped__ = wrapped + return wrapper + + _update_wrapper.__doc__ = functools.update_wrapper.__doc__ def wraps( wrapped, assigned=functools.WRAPPER_ASSIGNMENTS, updated=functools.WRAPPER_UPDATES, ): - def wrapper(f): - f = functools.wraps(wrapped, assigned, updated)(f) - f.__wrapped__ = wrapped - return f - - return wrapper + return functools.partial( + _update_wrapper, wrapped=wrapped, assigned=assigned, updated=updated + ) + wraps.__doc__ = functools.wraps.__doc__ else: wraps = functools.wraps @@ -888,7 +933,15 @@ def with_metaclass(meta, *bases): # the actual metaclass. class metaclass(type): def __new__(cls, name, this_bases, d): - return meta(name, bases, d) + if sys.version_info[:2] >= (3, 7): + # This version introduced PEP 560 that requires a bit + # of extra care (we mimic what is done by __build_class__). + resolved_bases = types.resolve_bases(bases) + if resolved_bases is not bases: + d["__orig_bases__"] = bases + else: + resolved_bases = bases + return meta(name, resolved_bases, d) @classmethod def __prepare__(cls, name, this_bases): @@ -928,12 +981,11 @@ def ensure_binary(s, encoding="utf-8", errors="strict"): - `str` -> encoded to `bytes` - `bytes` -> `bytes` """ + if isinstance(s, binary_type): + return s if isinstance(s, text_type): return s.encode(encoding, errors) - elif isinstance(s, binary_type): - return s - else: - raise TypeError("not expecting type '%s'" % type(s)) + raise TypeError("not expecting type '%s'" % type(s)) def ensure_str(s, encoding="utf-8", errors="strict"): @@ -947,12 +999,15 @@ def ensure_str(s, encoding="utf-8", errors="strict"): - `str` -> `str` - `bytes` -> decoded to `str` """ - if not isinstance(s, (text_type, binary_type)): - raise TypeError("not expecting type '%s'" % type(s)) + # Optimization: Fast return for the common case. + if type(s) is str: + return s if PY2 and isinstance(s, text_type): - s = s.encode(encoding, errors) + return s.encode(encoding, errors) elif PY3 and isinstance(s, binary_type): - s = s.decode(encoding, errors) + return s.decode(encoding, errors) + elif not isinstance(s, (text_type, binary_type)): + raise TypeError("not expecting type '%s'" % type(s)) return s @@ -977,7 +1032,7 @@ def ensure_text(s, encoding="utf-8", errors="strict"): def python_2_unicode_compatible(klass): """ - A decorator that defines __unicode__ and __str__ methods under Python 2. + A class decorator that defines __unicode__ and __str__ methods under Python 2. Under Python 3 it does nothing. To support Python 2 and 3 with a single code base, define a __str__ method diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py b/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py deleted file mode 100644 index 6b12fd90..00000000 --- a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py +++ /dev/null @@ -1,22 +0,0 @@ -import sys - -try: - # Our match_hostname function is the same as 3.5's, so we only want to - # import the match_hostname function if it's at least that good. - if sys.version_info < (3, 5): - raise ImportError("Fallback to vendored code") - - from ssl import CertificateError, match_hostname -except ImportError: - try: - # Backport of the function from a pypi module - from backports.ssl_match_hostname import ( # type: ignore - CertificateError, - match_hostname, - ) - except ImportError: - # Our vendored copy - from ._implementation import CertificateError, match_hostname # type: ignore - -# Not needed, but documenting what we provide. -__all__ = ("CertificateError", "match_hostname") diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 4c8deda5a4c951151d1e1a6c9be59dfe23c4c621..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 578 zcmYe~<>g{vU|^UdaWM5O69dCz5C<7^GcYhXFfcF_H!(0Uq%fo~<}gGtRH>yhWHF{N zWiu4Xq%x&2H#0UdrZA+i<S^&5M6u+uMzJz7gfrxMu`r}ERaP)EfMAsfSOpu33MH_L zB9J^ILkepOOAb3iK9V7i$$$Yurm#eDq%a0EXtKQoxz10M=_NA*1H(&J1_p*INw>tD zoTS9$Y=x41g|gJVl>DO96ousclvGWoTLR9hMJ1VOnaPPIsjfvu`9-(*auZ9EGvYJy zi%aqnb5mb3GB7Y`a^7Mtt}MRAQ<hp(oSB~&pP84Ie~a5Qw;;c$1fq?(xHzYXg@J*g z2xMuL49G%|Y_VQ(aZWs{nNj@lnYjfysky0nC5a`O`FXe4<Kq)^a^mAxG8FNE%m5L; z<~Uo$gche3700CJq+}Mw_~)g%6lIpBD(EVN`gw-A1_gVDI0h?t`nmY~xdwYW#ss_i zx(0{11}T`u1O)iRB%0{v<fmsAmt<zgq~?{y_+%!<6la#C>J}s>XD6no7RMB17U;)A zf<(WxC?_W~$ygsIsgLPy{rLFIyv&mLc)fzkTO2mI`6;D2sdk_MDi&d2VBlb4V&-Dx SU=m^EVPs+wVc}ttVFm!YI-s=x diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc deleted file mode 100644 index d3d2d92d3417ed330295530a81a606b993b2cac4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3331 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 AeE<Le diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py b/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py deleted file mode 100644 index 689208d3..00000000 --- a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py +++ /dev/null @@ -1,160 +0,0 @@ -"""The match_hostname() function from Python 3.3.3, essential when using SSL.""" - -# Note: This file is under the PSF license as the code comes from the python -# stdlib. http://docs.python.org/3/license.html - -import re -import sys - -# ipaddress has been backported to 2.6+ in pypi. If it is installed on the -# system, use it to handle IPAddress ServerAltnames (this was added in -# python-3.5) otherwise only do DNS matching. This allows -# backports.ssl_match_hostname to continue to be used in Python 2.7. -try: - import ipaddress -except ImportError: - ipaddress = None - -__version__ = "3.5.0.1" - - -class CertificateError(ValueError): - pass - - -def _dnsname_match(dn, hostname, max_wildcards=1): - """Matching according to RFC 6125, section 6.4.3 - - http://tools.ietf.org/html/rfc6125#section-6.4.3 - """ - pats = [] - if not dn: - return False - - # Ported from python3-syntax: - # leftmost, *remainder = dn.split(r'.') - parts = dn.split(r".") - leftmost = parts[0] - remainder = parts[1:] - - wildcards = leftmost.count("*") - if wildcards > max_wildcards: - # Issue #17980: avoid denials of service by refusing more - # than one wildcard per fragment. A survey of established - # policy among SSL implementations showed it to be a - # reasonable choice. - raise CertificateError( - "too many wildcards in certificate DNS name: " + repr(dn) - ) - - # speed up common case w/o wildcards - if not wildcards: - return dn.lower() == hostname.lower() - - # RFC 6125, section 6.4.3, subitem 1. - # The client SHOULD NOT attempt to match a presented identifier in which - # the wildcard character comprises a label other than the left-most label. - if leftmost == "*": - # When '*' is a fragment by itself, it matches a non-empty dotless - # fragment. - pats.append("[^.]+") - elif leftmost.startswith("xn--") or hostname.startswith("xn--"): - # RFC 6125, section 6.4.3, subitem 3. - # The client SHOULD NOT attempt to match a presented identifier - # where the wildcard character is embedded within an A-label or - # U-label of an internationalized domain name. - pats.append(re.escape(leftmost)) - else: - # Otherwise, '*' matches any dotless string, e.g. www* - pats.append(re.escape(leftmost).replace(r"\*", "[^.]*")) - - # add the remaining fragments, ignore any wildcards - for frag in remainder: - pats.append(re.escape(frag)) - - pat = re.compile(r"\A" + r"\.".join(pats) + r"\Z", re.IGNORECASE) - return pat.match(hostname) - - -def _to_unicode(obj): - if isinstance(obj, str) and sys.version_info < (3,): - obj = unicode(obj, encoding="ascii", errors="strict") - return obj - - -def _ipaddress_match(ipname, host_ip): - """Exact matching of IP addresses. - - RFC 6125 explicitly doesn't define an algorithm for this - (section 1.7.2 - "Out of Scope"). - """ - # OpenSSL may add a trailing newline to a subjectAltName's IP address - # Divergence from upstream: ipaddress can't handle byte str - ip = ipaddress.ip_address(_to_unicode(ipname).rstrip()) - return ip == host_ip - - -def match_hostname(cert, hostname): - """Verify that *cert* (in decoded format as returned by - SSLSocket.getpeercert()) matches the *hostname*. RFC 2818 and RFC 6125 - rules are followed, but IP addresses are not accepted for *hostname*. - - CertificateError is raised on failure. On success, the function - returns nothing. - """ - if not cert: - raise ValueError( - "empty or no certificate, match_hostname needs a " - "SSL socket or SSL context with either " - "CERT_OPTIONAL or CERT_REQUIRED" - ) - try: - # Divergence from upstream: ipaddress can't handle byte str - host_ip = ipaddress.ip_address(_to_unicode(hostname)) - except ValueError: - # Not an IP address (common case) - host_ip = None - except UnicodeError: - # Divergence from upstream: Have to deal with ipaddress not taking - # byte strings. addresses should be all ascii, so we consider it not - # an ipaddress in this case - host_ip = None - except AttributeError: - # Divergence from upstream: Make ipaddress library optional - if ipaddress is None: - host_ip = None - else: - raise - dnsnames = [] - san = cert.get("subjectAltName", ()) - for key, value in san: - if key == "DNS": - if host_ip is None and _dnsname_match(value, hostname): - return - dnsnames.append(value) - elif key == "IP Address": - if host_ip is not None and _ipaddress_match(value, host_ip): - return - dnsnames.append(value) - if not dnsnames: - # The subject is only checked when there is no dNSName entry - # in subjectAltName - for sub in cert.get("subject", ()): - for key, value in sub: - # XXX according to RFC 2818, the most specific Common Name - # must be used. - if key == "commonName": - if _dnsname_match(value, hostname): - return - dnsnames.append(value) - if len(dnsnames) > 1: - raise CertificateError( - "hostname %r " - "doesn't match either of %s" % (hostname, ", ".join(map(repr, dnsnames))) - ) - elif len(dnsnames) == 1: - raise CertificateError("hostname %r doesn't match %r" % (hostname, dnsnames[0])) - else: - raise CertificateError( - "no appropriate commonName or subjectAltName fields were found" - ) diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py b/env/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py index 3a31a285..14b10daf 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py @@ -34,6 +34,7 @@ SSL_KEYWORDS = ( "ca_cert_dir", "ssl_context", "key_password", + "server_hostname", ) # All known keyword arguments that could be provided to the pool manager, its @@ -170,7 +171,7 @@ class PoolManager(RequestMethods): def __init__(self, num_pools=10, headers=None, **connection_pool_kw): RequestMethods.__init__(self, headers) self.connection_pool_kw = connection_pool_kw - self.pools = RecentlyUsedContainer(num_pools, dispose_func=lambda p: p.close()) + self.pools = RecentlyUsedContainer(num_pools) # Locally set the pool classes and keys so other PoolManagers can # override them. diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/response.py b/env/Lib/site-packages/pip/_vendor/urllib3/response.py index 38693f4f..8909f845 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/response.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/response.py @@ -2,16 +2,16 @@ from __future__ import absolute_import import io import logging +import sys +import warnings import zlib from contextlib import contextmanager from socket import error as SocketError from socket import timeout as SocketTimeout -try: - import brotli -except ImportError: - brotli = None +brotli = None +from . import util from ._collections import HTTPHeaderDict from .connection import BaseSSLError, HTTPException from .exceptions import ( @@ -478,6 +478,54 @@ class HTTPResponse(io.IOBase): if self._original_response and self._original_response.isclosed(): self.release_conn() + def _fp_read(self, amt): + """ + Read a response with the thought that reading the number of bytes + larger than can fit in a 32-bit int at a time via SSL in some + known cases leads to an overflow error that has to be prevented + if `amt` or `self.length_remaining` indicate that a problem may + happen. + + The known cases: + * 3.8 <= CPython < 3.9.7 because of a bug + https://github.com/urllib3/urllib3/issues/2513#issuecomment-1152559900. + * urllib3 injected with pyOpenSSL-backed SSL-support. + * CPython < 3.10 only when `amt` does not fit 32-bit int. + """ + assert self._fp + c_int_max = 2 ** 31 - 1 + if ( + ( + (amt and amt > c_int_max) + or (self.length_remaining and self.length_remaining > c_int_max) + ) + and not util.IS_SECURETRANSPORT + and (util.IS_PYOPENSSL or sys.version_info < (3, 10)) + ): + buffer = io.BytesIO() + # Besides `max_chunk_amt` being a maximum chunk size, it + # affects memory overhead of reading a response by this + # method in CPython. + # `c_int_max` equal to 2 GiB - 1 byte is the actual maximum + # chunk size that does not lead to an overflow error, but + # 256 MiB is a compromise. + max_chunk_amt = 2 ** 28 + while amt is None or amt != 0: + if amt is not None: + chunk_amt = min(amt, max_chunk_amt) + amt -= chunk_amt + else: + chunk_amt = max_chunk_amt + data = self._fp.read(chunk_amt) + if not data: + break + buffer.write(data) + del data # to reduce peak memory usage by `max_chunk_amt`. + return buffer.getvalue() + else: + # StringIO doesn't like amt=None + return self._fp.read(amt) if amt is not None else self._fp.read() + def read(self, amt=None, decode_content=None, cache_content=False): """ Similar to :meth:`http.client.HTTPResponse.read`, but with two additional @@ -510,13 +558,11 @@ class HTTPResponse(io.IOBase): fp_closed = getattr(self._fp, "closed", False) with self._error_catcher(): + data = self._fp_read(amt) if not fp_closed else b"" if amt is None: - # cStringIO doesn't like amt=None - data = self._fp.read() if not fp_closed else b"" flush_decoder = True else: cache_content = False - data = self._fp.read(amt) if not fp_closed else b"" if ( amt != 0 and not data ): # Platform-specific: Buggy versions of Python. @@ -612,9 +658,21 @@ class HTTPResponse(io.IOBase): # Backwards-compatibility methods for http.client.HTTPResponse def getheaders(self): + warnings.warn( + "HTTPResponse.getheaders() is deprecated and will be removed " + "in urllib3 v2.1.0. Instead access HTTPResponse.headers directly.", + category=DeprecationWarning, + stacklevel=2, + ) return self.headers def getheader(self, name, default=None): + warnings.warn( + "HTTPResponse.getheader() is deprecated and will be removed " + "in urllib3 v2.1.0. Instead use HTTPResponse.headers.get(name, default).", + category=DeprecationWarning, + stacklevel=2, + ) return self.headers.get(name, default) # Backwards compatibility for http.cookiejar diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index 4b38bab0daaa82c515278469603046675949dc42..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1137 zcmYe~<>g{vU|^UdaWJ)+g@NHQh=Yuo7#J8F7#J9ew=gg;q%fo~<}l<kMlmunq%fs0 z=P>0mM=^uhEIBN>tWm7FY*B2v>{0AsG1eT8T+S#?Fq<uhE0;Tp8_Z_U;mPHV;?3oY z;>+ca;?EU`637*d63i8f63P{h63!Kg63G>f63rEh5(BH}$Pv$#h?2;ajFJTNIdi0P zrK6;CWujzqWus(s<)Y-k;#@iMxe8GVxr$MWj0`E<QA#O1!3>(bFG2p%WW2?nm{gpf zQ(BT5pP5^bUsUpvk%56hlkt{lW^sISeqLT`a!F=>UVKVXenCNMiYD_d?qF}vfOrpA zM;F(iTY?}?fTNR-D^w)-7Ef+sc4~Y^YGO)iQL!fDEuPHc__Tuf<edEC)D%s|TdYB; zB}J8*T(|ffeFFUA1A_cR{GI)Mf^V^VI0nZD`+45t@eGa+i1ZI|^$QO6xh3Qo93SlJ z92(>r66EL?9N-@ma*GG1D?Y?0_!d`iu#a<oUP)?2$t|J8;^NezlK8aDy!6zff}+g4 zl3RjBsm1v@WvTJWAeo}n!s1)PFrnh&ocOZTqT<Z_yj%PrPI*ycL40w3a&~HoCetnU zkj&iF{L+$JJjta+MX7lu@g<qLshTXem_v(lZgHfimc(b|7nj`PEJ!RWPK_@u%DKf| zT#%CqazIfr$OPW<L=Z2(D848)G36E?oLgR$S(2(LQN+!_z)-{kB6vXrKZxK15uhYk z#0g@FfCw=VApjyoK?Dnk-~bWgAVLB}u!9Ie5FrF2Bte8Qh>!vi(jbBrM6fY1F!*UI z-{OjoPb)1cElQ1#F9Id$TU>}3F9KO`i@hkdur#%}qzJCB2xQ4Ej-u4!g8aPV)FO}* zZm|}D;uP%ITP&bZECM?o&1+y^f&B;e2Ew5rH{N0gg=~IlNfFq$AV1z>E-lI_0{a`` zN06s(v4BFc2=1#}?D6r5IXUt1D;bK^Kpq4UzgnHGVnT~ki;81Xb5b&kV*K+`U5YZx zQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-I zV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F@{9CKi*j-@lZ^FCOEPox<Kr{) tGE3s)^$IF)aoFVMr<CTT+JQ1wF(_hqn0XjQ7<m|Z7!7y?7$q15m;gjeFq{AY diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-39.pyc deleted file mode 100644 index 36f120ff5056d4d4a8dac8cbebf80bbccb921c3f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3491 zcmYe~<>g{vU|^UdaWK_Nn1SIjh=Yuo85kHG7#J9e+ZY%aQW#Pga~N_NqZk=MY^EHh zD5eyK6y_Y}T$U&nMurrY6xJNpT(&4SFq<uhJ(nYjgOMSHJ%uBOGnXrhE0;Tpn~@=f zGli>#A&MuJDT_CSDTOJGIfXlgr-d<!FNHUSuZ1CsKZQR<poJkyAVn}msD&X)FjX)` zxS26ZD1|AQK~v-<$c37WxA+s2it}?yOH$)Aa|`l|O8hh#ZwdM2CnuI<=H~?@78R$u z78T_ey<}owU;s(QCl(Z>=A~!mrN*b`m1P#?=V>zDVlK|Cc*zJ-!E{T~FF!o7G9*7d zF|))izbH6AIXkrkY{o6#^2E%N__X|@_@dOrlw^<wkSjnKWIP801A{XtoO~D<7)lsw z7*ZHhn3|bu8EY6*m`WLnBtR~&VN78zWhhcfVF_la;wu5kv8J%~GKDh)Gq5m}FjcxS zGJs$t14y+2Lke>+gC={T3L^spmx6+VLQrZ+X;EIWLP$|*szPR(LP<udLUMjyUTQMP z!wQ+j3MobT1qG=o3W<3s3dI@ur8y}INvR6SIr+t@DSBLBL#zrCixP9e`mDeLAd{_< za}tY-tr9XyN(%Inb23x&O7uKJLIRxOrY9)mCuOB3mq1PN%P&c_QgF*JQYgqtEJ@2R z$}LvN$;?hwa4aZr1qZQ?LP<tuu|j!fPL4uiPI+Qwu|g5p{R#;QZizX?sR;=RCHY_% z<fN8>{Q@&eAtNy_B?rZCMXAY^$vK&M=?W!9iFw5ZiAAY-B{`J}Y57G8rNw$+V{Wk& z=O<^o`Gur|Vg-aX8E>(dWag&kmzHQU-(pWsElDgXDJtS*U|=ZXfJ8Y9C;*E<nP4SD z5g!8s!>@K{tC-N@)S}{;)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0e?Qk? zPsf;GS6|oQ5Z53DvzUMYpO{1w-JJaN%;J*F?3mQNvKXJtq?qE&l2qM-#N_P6^wi>* zg3JQ___EZzl>8$7(xRN4%p_y|(vr*^eUMuqk*QZuc}q02I36Jq4~<(MP%0Aw`HqW+ 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-39.pyc deleted file mode 100644 index 476231a2cf4013ef8d11179c6c76b5d4a106cab7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1373 zcmYe~<>g{vU|^UdaWK_|je+4Yh=Yuo85kHG7#J9ebr={JQW#Pga~N_NqZo6UqL^}- zqnH^PQrJ_NQ&?IUqgYZnQdm>iS{S2PQ<#DoG&x@~GB7Y`GT#zQE=o--NsTWp%E`%0 zGLBEq&nro-D7htAlv<phQ<fT^oLW>8UzA!{d`lQ6R9u`BUzS=_oSC2Jmke?P%uOIR z69WT-GssOQ3=9l43@MDI3`IO3J8PIyn6sIRB*1KjEQS=8Y^EZE8b%P#Vk|NMiKnmz zGib6U+A}gRa49G#C<LXJlosU`D})r4rYdBnDU@WSDkSIU<)tQ<Waj576r~oHW)`Iu zD<tMAc!Y!mC^-B3`MElWD3oLr<(H;sfYlci<yTbdae>XVDo89!%vA^t@=*W_gS>48 zmI2uY63&NM0+!VS%Ru!6fQ)g@&r8cphw4oRa}e6WDnQOl%S<mVN(8$wttdZNp&&m$ zCpR%KF+H_Nub>jy(BhIJg_P9dlFU4?^7!K9jMUszgpnZ`sR|G=1*pT2RO=~dWa_0V zWR#Q?6zhN~9fj1AWKFOIer~r|Kr**jL1b}=Cetl8h)K63N{dtD)AEbT6N^$Z^U^`g zc(5W(=3AU#kAs5c77v68@#QTcB#WWWT**+x!@$7stI63aCbT%Us5mAyCnd8e#y>CB zr6{v3RY6xF)Xy`_H7M9K#4%XG)6d1<&o$W7F(%m6*EKlAHAulMCLq8kCecJUCqF&2 zxFj<>CN-}t#wRl=rZ}@CRkt89IXf{uwK%3Avp_$-EHy7BzepdNQ1weoGIR97PSh)? zyd{rF6`;gg3Q84VPsNv%=H;d4uz*se1Sp;IaWJwlb1<^7aQtUtV*1C#%<`9sm4&&8 zkAZ<9nH8i0irE+#7(m*<iP?;SfuV$<gt3O9nX!bahOwD3g|U~ZmbHed*r<lN*r<l3 z*r<fLhBbw$nW@OAhIIkULIy^L8c=d(u8IN2h<j>YYEfbdD77l2q^2d7=9EAZl0tED z4k+1x@*OCV=jWv=WF!{nsh21urKaYA6qRMBq^2k&Re};U*s#*#)FMdo)MUEFjg%p8 zaUwFTP)>egN<7pqa7HfHWGw<^&?1n>ia^=*7JEiwabihHQIR01KwvB4XJB9`5@29p zxW$p22+?$l8_J4L$t=3X1Lq``Btq<l78>B>03mom21r257H}-ZgB%G}s0xY=8BjR0 zGcmF;vi)OYWrD^A(_bbQjz3In985*xAO|t~`T1#r3AS4-AR{2|2RR+$2~fO&l|n2A jrAP=1>;w**-29Z%oK!ndaaYX2z`!8F!tkF<iQzv0oMDNV diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-39.pyc deleted file mode 100644 index ad5b7f43da3c90bad6d8062c2995ccb02e817cf4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1092 zcmYe~<>g{vU|^UdaWM50BLl-@5C<8vFfcGUFfcF_yD%^?q%fo~<}gGtq%fs0=P>3n zMKLjg*ep5BxhzpEj0~wvS*%5RU{!2U?CuOHtSM|Q3@L1>ELm*L%uyUEjKK_=>@Pv) z`@LjhU|`T>yv1CcS+SDw7HeT?YH4aRND3J<!>l)8U|>jPh+<4(h+;}%Okrwah+<A< zNn=c5PGM<bjADgY6~&gqp2E?>5XGLt8O)%`b&Jy{Gc7+5Y&6I|n9(3M2s?v(#>c?G zP{Oc)aUnwuLp)OoLomZiMn6sFTinU{IXS7xC7Jno#kW{fQVUB{i&#O9X1c{voSKt% zi!pvBLlF-H1H-Q-XRDad;?$zznADt<%%T|oyi}K>%(7GkU4>9T&oI}ZV9yZ8U<FS< z7k@w3U{A-GU{_z);1Jg!1+$od0H2sd6WyHr^vvRt%<P!dys{Xd%%qs&%#u{yg2d$P z#PrnSn1aj#{rIxfyp;SR{nDbGoXjL+{nC=m9DQ)O=@nGoVvWzt%Pavorx@fl2F5CW zxaal2a>-zEXc&OlAPf!yP#UOVtYOGvXl4v%C}L+|U?>8`ye3l-Na_}IPHG<5rx1dd zfq~%`TYO=0W>qRbC<s9YF)&sMAXx~O#IO+*pI{pW7#J8p_AOwnVO+?_$N&m<u)Ug0 z;6T2`mRL}bnwJ7|0ZV2{YA(cfkQa-<PGE^IC@m2}asVHa0}4t@k{O|%1yLY2$em#8 zLB4`mzmNgyVVK3t1^ES<j9`Cb+LxYMB8tPl^wbhRO^#a}@$q?yxvBB-x47ctbMsS5 zb3kmK`1r!o#2koB5h%qKfdZ}w6bwbepx_1>i)0_%lSOO{3=G^LJ2@B_7&sU?n0c5v zn8Bi&oJAn9TO6=dQUnU#C?ObEuQ;<pFE_s|wHOkl%mI-`w^+fsAxb2^G_SNcH3jBG huqfD6Y>v3aVFU4s9VirwL7~UN#KXwL#Ky$I3;>K<>M#HR diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-39.pyc deleted file mode 100644 index 98be7c28afb8b1f4d975ff29946c63fb10233bad..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3480 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 ZpuEn*$i~FM#Kr>d{6O;NFD?%bApkm}=L-M; diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-39.pyc deleted file mode 100644 index c074f5247b59fc475cbe9b46f44b6bb5c9fcea87..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2377 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 bN@-3isCZ>4=3!u9;9(K~r7>m>c@8rGigJ*r diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-39.pyc deleted file mode 100644 index 0cd5e28e0363729af88574bbefc54ec4514fb3dd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 15994 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 X#lpnM@t=i_jafjAgHfoS0Rlw;OI1j4 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-39.pyc deleted file mode 100644 index d042504c017a559495708b2f2d1f32f85b4dcb78..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11055 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 HF9$aOsZsz) diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-39.pyc deleted file mode 100644 index 218adca57277a39ada6f19f46a67f7b701b337e9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 7543 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 Rl^mc^F%BjkMjj>>W&rDP7a;%u diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-39.pyc deleted file mode 100644 index 32587903fb663fc956d83adf48903c45aa24c356..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8975 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-39.pyc deleted file mode 100644 index 0a4b62b6136e95016e31300d89d9fefd9ae3ab9e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10651 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 diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-39.pyc deleted file mode 100644 index 32922559841fde664bda32b4ee90639fdca557c7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3160 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 TY#icT!dxO8EF8QX{9Nn+2Zg@w diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/connection.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/connection.py index f1e5d37f..6af1138f 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/util/connection.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/connection.py @@ -2,9 +2,8 @@ from __future__ import absolute_import import socket -from pip._vendor.urllib3.exceptions import LocationParseError - from ..contrib import _appengine_environ +from ..exceptions import LocationParseError from ..packages import six from .wait import NoWayToWaitForSocketError, wait_for_read @@ -118,7 +117,7 @@ def allowed_gai_family(): def _has_ipv6(host): - """ Returns True if the system can bind an IPv6 address. """ + """Returns True if the system can bind an IPv6 address.""" sock = None has_ipv6 = False diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py index 34f884d5..2199cc7b 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py @@ -45,6 +45,7 @@ def create_proxy_ssl_context( ssl_version=resolve_ssl_version(ssl_version), cert_reqs=resolve_cert_reqs(cert_reqs), ) + if ( not ca_certs and not ca_cert_dir diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/request.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/request.py index 25103383..330766ef 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/util/request.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/request.py @@ -13,12 +13,6 @@ SKIP_HEADER = "@@@SKIP_HEADER@@@" SKIPPABLE_HEADERS = frozenset(["accept-encoding", "host", "user-agent"]) ACCEPT_ENCODING = "gzip,deflate" -try: - import brotli as _unused_module_brotli # noqa: F401 -except ImportError: - pass -else: - ACCEPT_ENCODING += ",br" _FAILEDTELL = object() diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/retry.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/retry.py index d25a41b4..2490d5e5 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/util/retry.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/retry.py @@ -37,7 +37,7 @@ class _RetryMeta(type): def DEFAULT_METHOD_WHITELIST(cls): warnings.warn( "Using 'Retry.DEFAULT_METHOD_WHITELIST' is deprecated and " - "will be removed in v2.0. Use 'Retry.DEFAULT_METHODS_ALLOWED' instead", + "will be removed in v2.0. Use 'Retry.DEFAULT_ALLOWED_METHODS' instead", DeprecationWarning, ) return cls.DEFAULT_ALLOWED_METHODS @@ -69,6 +69,24 @@ class _RetryMeta(type): ) cls.DEFAULT_REMOVE_HEADERS_ON_REDIRECT = value + @property + def BACKOFF_MAX(cls): + warnings.warn( + "Using 'Retry.BACKOFF_MAX' is deprecated and " + "will be removed in v2.0. Use 'Retry.DEFAULT_BACKOFF_MAX' instead", + DeprecationWarning, + ) + return cls.DEFAULT_BACKOFF_MAX + + @BACKOFF_MAX.setter + def BACKOFF_MAX(cls, value): + warnings.warn( + "Using 'Retry.BACKOFF_MAX' is deprecated and " + "will be removed in v2.0. Use 'Retry.DEFAULT_BACKOFF_MAX' instead", + DeprecationWarning, + ) + cls.DEFAULT_BACKOFF_MAX = value + @six.add_metaclass(_RetryMeta) class Retry(object): @@ -181,7 +199,7 @@ class Retry(object): seconds. If the backoff_factor is 0.1, then :func:`.sleep` will sleep for [0.0s, 0.2s, 0.4s, ...] between retries. It will never be longer - than :attr:`Retry.BACKOFF_MAX`. + than :attr:`Retry.DEFAULT_BACKOFF_MAX`. By default, backoff is disabled (set to 0). @@ -220,7 +238,7 @@ class Retry(object): DEFAULT_REMOVE_HEADERS_ON_REDIRECT = frozenset(["Authorization"]) #: Maximum backoff time. - BACKOFF_MAX = 120 + DEFAULT_BACKOFF_MAX = 120 def __init__( self, @@ -321,7 +339,7 @@ class Retry(object): @classmethod def from_int(cls, retries, redirect=True, default=None): - """ Backwards-compatibility for the old retries format.""" + """Backwards-compatibility for the old retries format.""" if retries is None: retries = default if default is not None else cls.DEFAULT @@ -348,7 +366,7 @@ class Retry(object): return 0 backoff_value = self.backoff_factor * (2 ** (consecutive_errors_len - 1)) - return min(self.BACKOFF_MAX, backoff_value) + return min(self.DEFAULT_BACKOFF_MAX, backoff_value) def parse_retry_after(self, retry_after): # Whitespace: https://tools.ietf.org/html/rfc7230#section-3.2.4 @@ -374,9 +392,9 @@ class Retry(object): return seconds def get_retry_after(self, response): - """ Get the value of Retry-After in seconds. """ + """Get the value of Retry-After in seconds.""" - retry_after = response.getheader("Retry-After") + retry_after = response.headers.get("Retry-After") if retry_after is None: return None @@ -468,7 +486,7 @@ class Retry(object): ) def is_exhausted(self): - """ Are we out of retries? """ + """Are we out of retries?""" retry_counts = ( self.total, self.connect, diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py index 763da82b..2b45d391 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py @@ -71,6 +71,11 @@ except ImportError: except ImportError: PROTOCOL_SSLv23 = PROTOCOL_TLS = 2 +try: + from ssl import PROTOCOL_TLS_CLIENT +except ImportError: + PROTOCOL_TLS_CLIENT = PROTOCOL_TLS + try: from ssl import OP_NO_COMPRESSION, OP_NO_SSLv2, OP_NO_SSLv3 @@ -159,7 +164,7 @@ except ImportError: "urllib3 from configuring SSL appropriately and may cause " "certain SSL connections to fail. You can upgrade to a newer " "version of Python to solve this. For more information, see " - "https://urllib3.readthedocs.io/en/latest/advanced-usage.html" + "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html" "#ssl-warnings", InsecurePlatformWarning, ) @@ -278,7 +283,11 @@ def create_urllib3_context( Constructed SSLContext object with specified options :rtype: SSLContext """ - context = SSLContext(ssl_version or PROTOCOL_TLS) + # PROTOCOL_TLS is deprecated in Python 3.10 + if not ssl_version or ssl_version == PROTOCOL_TLS: + ssl_version = PROTOCOL_TLS_CLIENT + + context = SSLContext(ssl_version) context.set_ciphers(ciphers or DEFAULT_CIPHERS) @@ -313,13 +322,25 @@ def create_urllib3_context( ) is not None: context.post_handshake_auth = True - context.verify_mode = cert_reqs - if ( - getattr(context, "check_hostname", None) is not None - ): # Platform-specific: Python 3.2 - # We do our own verification, including fingerprints and alternative - # hostnames. So disable it here - context.check_hostname = False + def disable_check_hostname(): + if ( + getattr(context, "check_hostname", None) is not None + ): # Platform-specific: Python 3.2 + # We do our own verification, including fingerprints and alternative + # hostnames. So disable it here + context.check_hostname = False + + # The order of the below lines setting verify_mode and check_hostname + # matter due to safe-guards SSLContext has to prevent an SSLContext with + # check_hostname=True, verify_mode=NONE/OPTIONAL. This is made even more + # complex because we don't know whether PROTOCOL_TLS_CLIENT will be used + # or not so we don't know the initial state of the freshly created SSLContext. + if cert_reqs == ssl.CERT_REQUIRED: + context.verify_mode = cert_reqs + disable_check_hostname() + else: + disable_check_hostname() + context.verify_mode = cert_reqs # Enable logging of TLS session keys via defacto standard environment variable # 'SSLKEYLOGFILE', if the feature is available (Python 3.8+). Skip empty values. @@ -401,7 +422,7 @@ def ssl_wrap_socket( try: if hasattr(context, "set_alpn_protocols"): context.set_alpn_protocols(ALPN_PROTOCOLS) - except NotImplementedError: + except NotImplementedError: # Defensive: in CI, we always have set_alpn_protocols pass # If we detect server_hostname is an IP address then the SNI @@ -419,7 +440,7 @@ def ssl_wrap_socket( "This may cause the server to present an incorrect TLS " "certificate, which can cause validation failures. You can upgrade to " "a newer version of Python to solve this. For more information, see " - "https://urllib3.readthedocs.io/en/latest/advanced-usage.html" + "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html" "#ssl-warnings", SNIMissingWarning, ) diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py index ca00233c..4a7105d1 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py @@ -2,8 +2,8 @@ import io import socket import ssl -from pip._vendor.urllib3.exceptions import ProxySchemeUnsupported -from pip._vendor.urllib3.packages import six +from ..exceptions import ProxySchemeUnsupported +from ..packages import six SSL_BLOCKSIZE = 16384 @@ -193,7 +193,7 @@ class SSLTransport: raise def _ssl_io_loop(self, func, *args): - """ Performs an I/O loop between incoming/outgoing and the socket.""" + """Performs an I/O loop between incoming/outgoing and the socket.""" should_loop = True ret = None diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py index ff69593b..78e18a62 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py @@ -2,9 +2,8 @@ from __future__ import absolute_import import time -# The default socket timeout, used by httplib to indicate that no timeout was -# specified by the user -from socket import _GLOBAL_DEFAULT_TIMEOUT +# The default socket timeout, used by httplib to indicate that no timeout was; specified by the user +from socket import _GLOBAL_DEFAULT_TIMEOUT, getdefaulttimeout from ..exceptions import TimeoutStateError @@ -116,6 +115,10 @@ class Timeout(object): # __str__ provided for backwards compatibility __str__ = __repr__ + @classmethod + def resolve_default_timeout(cls, timeout): + return getdefaulttimeout() if timeout is cls.DEFAULT_TIMEOUT else timeout + @classmethod def _validate_timeout(cls, value, name): """Check that a timeout attribute is valid. diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/url.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/url.py index 66c8795b..a960b2f3 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/util/url.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/url.py @@ -50,7 +50,7 @@ _variations = [ "(?:(?:%(hex)s:){0,6}%(hex)s)?::", ] -UNRESERVED_PAT = r"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._!\-~" +UNRESERVED_PAT = r"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._\-~" IPV6_PAT = "(?:" + "|".join([x % _subs for x in _variations]) + ")" ZONE_ID_PAT = "(?:%25|%)(?:[" + UNRESERVED_PAT + "]|%[a-fA-F0-9]{2})+" IPV6_ADDRZ_PAT = r"\[" + IPV6_PAT + r"(?:" + ZONE_ID_PAT + r")?\]" @@ -63,12 +63,12 @@ IPV6_ADDRZ_RE = re.compile("^" + IPV6_ADDRZ_PAT + "$") BRACELESS_IPV6_ADDRZ_RE = re.compile("^" + IPV6_ADDRZ_PAT[2:-2] + "$") ZONE_ID_RE = re.compile("(" + ZONE_ID_PAT + r")\]$") -SUBAUTHORITY_PAT = (u"^(?:(.*)@)?(%s|%s|%s)(?::([0-9]{0,5}))?$") % ( +_HOST_PORT_PAT = ("^(%s|%s|%s)(?::0*?(|0|[1-9][0-9]{0,4}))?$") % ( REG_NAME_PAT, IPV4_PAT, IPV6_ADDRZ_PAT, ) -SUBAUTHORITY_RE = re.compile(SUBAUTHORITY_PAT, re.UNICODE | re.DOTALL) +_HOST_PORT_RE = re.compile(_HOST_PORT_PAT, re.UNICODE | re.DOTALL) UNRESERVED_CHARS = set( "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._-~" @@ -279,6 +279,9 @@ def _normalize_host(host, scheme): if scheme in NORMALIZABLE_SCHEMES: is_ipv6 = IPV6_ADDRZ_RE.match(host) if is_ipv6: + # IPv6 hosts of the form 'a::b%zone' are encoded in a URL as + # such per RFC 6874: 'a::b%25zone'. Unquote the ZoneID + # separator as necessary to return a valid RFC 4007 scoped IP. match = ZONE_ID_RE.search(host) if match: start, end = match.span(1) @@ -300,7 +303,7 @@ def _normalize_host(host, scheme): def _idna_encode(name): - if name and any([ord(x) > 128 for x in name]): + if name and any(ord(x) >= 128 for x in name): try: from pip._vendor import idna except ImportError: @@ -331,7 +334,7 @@ def parse_url(url): """ Given a url, return a parsed :class:`.Url` namedtuple. Best-effort is performed to parse incomplete urls. Fields not provided will be None. - This parser is RFC 3986 compliant. + This parser is RFC 3986 and RFC 6874 compliant. The parser logic and helper functions are based heavily on work done in the ``rfc3986`` module. @@ -365,7 +368,9 @@ def parse_url(url): scheme = scheme.lower() if authority: - auth, host, port = SUBAUTHORITY_RE.match(authority).groups() + auth, _, host_port = authority.rpartition("@") + auth = auth or None + host, port = _HOST_PORT_RE.match(host_port).groups() if auth and normalize_uri: auth = _encode_invalid_chars(auth, USERINFO_CHARS) if port == "": diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/wait.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/wait.py index c280646c..21b4590b 100644 --- a/env/Lib/site-packages/pip/_vendor/urllib3/util/wait.py +++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/wait.py @@ -42,7 +42,6 @@ if sys.version_info >= (3, 5): def _retry_on_intr(fn, timeout): return fn(timeout) - else: # Old and broken Pythons. def _retry_on_intr(fn, timeout): diff --git a/env/Lib/site-packages/pip/_vendor/vendor.txt b/env/Lib/site-packages/pip/_vendor/vendor.txt index 6c9732e9..4ab2915f 100644 --- a/env/Lib/site-packages/pip/_vendor/vendor.txt +++ b/env/Lib/site-packages/pip/_vendor/vendor.txt @@ -1,22 +1,23 @@ -appdirs==1.4.4 -CacheControl==0.12.6 -colorama==0.4.4 -distlib==0.3.1 -distro==1.5.0 -html5lib==1.1 -msgpack==1.0.2 -packaging==20.9 -pep517==0.10.0 -progress==1.5 -pyparsing==2.4.7 -requests==2.25.1 - certifi==2020.12.05 - chardet==4.0.0 - idna==3.1 - urllib3==1.26.4 -resolvelib==0.7.0 -setuptools==44.0.0 -six==1.15.0 -tenacity==7.0.0 -toml==0.10.2 +CacheControl==0.12.11 # Make sure to update the license in pyproject.toml for this. +colorama==0.4.6 +distlib==0.3.6 +distro==1.8.0 +msgpack==1.0.5 +packaging==21.3 +platformdirs==3.8.1 +pyparsing==3.1.0 +pyproject-hooks==1.0.0 +requests==2.31.0 + certifi==2023.5.7 + chardet==5.1.0 + idna==3.4 + urllib3==1.26.16 +rich==13.4.2 + pygments==2.15.1 + typing_extensions==4.7.1 +resolvelib==1.0.1 +setuptools==68.0.0 +six==1.16.0 +tenacity==8.2.2 +tomli==2.0.1 webencodings==0.5.1 diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-39.pyc deleted file mode 100644 index fcdd9887065062532204f48c133c95c606a5caed..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9751 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 TVjSFjd|Wad3VZ?_Tmr@b_<Ae) diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-39.pyc deleted file mode 100644 index 73c17f1c89e2d66c3a7e254eef7bd576669cab77..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3865 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 Xj49s0$iToNz{EHThe!xCFsuRqg|HFv diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-39.pyc deleted file mode 100644 index df8605f830f49418442d79feebbf5d5abfdd9974..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1935 zcmYe~<>g{vU|^UdaWGYqm4V?gh=Ytd7#J8F7#J9eQy3T+QW&BbQW#U1au}l+s{~RQ zQ<!s@a+#x;85zPE^5j?;Qdugk7#TniEXN9wi)6@SGGItyNnveah+<1&OJQ$eh+<FW zNa4t4DoRM@Ol42uY-Vg`WMoKT3TDvcsyf8QrJ$goP@bBUnwOlPl9`uYte2aelbDp6 zQw)}=!v-Llf>P5{^Ad{^OHvg|GEz~^fS90=o1apeld1<%Z<U;1P+63jo>5|@;0$9b z7#SEEDI`@Y1ZU>v=P3jy7G&muEw;+ZOis-!PPI~S3U<*^C{9gP@bPqZ^$T`YNXsu$ zNJ%Y8%*-j)<KlV=3PV3l##`*AMLGEesd>qaAQ31Av6&ed7@R=?E5g9QP{UBeuz+D9 zLpD>ffEPm(V+}(v!%9Ywe%74)^3)<t##?N~B}JKe=_?tE*cccXeziJV#e^2878S>& z=A>j6#rWr?x)f!Wr7Gwug!*}gxdsJ$hByW*c>1~c`?&^tI>rRM`nm>(xCSYh#RLTS z#3Y*N=H#bm7MEmZ$E4<!#rR|<#S~|jr0NzVCTAz6rxwQ)WESYhm!;;V<QM59M}<Bt zD)b5}Z}B7+7pE4L#DiT4@<}lZ$d8Nyj76Z7gW_wDk3nt+(Zy+?<iwcHSj(8gl)~J? zP{Oc)v4p9Hp_y?3^FoFNEGaAt85c6TFf=pPGL^8Vu%@uJFw`)C_|1%+3^j}k*xDJ= z7*p6&*jhLs;tLrWLE`Kw93WN-=K_uz#)XWa1m%|~%*eo?q@)Cia%9iwLDB>`a<L>T zhz8%p0tHw~RDftuD9Hz<ugoHayu@4@rzNn%l@%f)A{1Qm74q^+6jD<%OBA`36+$vH zixtu`b5a#Dixm<}OY(CQOEQxab8;#b(o^$NLAf9Wl#G#LjEl?1(aF^(Six4InhPa* zKoJLuvtUr7^kHCNNN1>Fh;^xDtYJ)HkYsRSh&8Kas$oiD1hX}2nM)W-7;Bh8Id=h5 z3e!Ty5{4S46lO_K6oUC_OcPlOWeNofS%MifS#EK{g0T1&8zc~KF_zw90fnC?^DUO5 z)Pf>#nz_Z614`-znk=`N^bBrsBqx@nrso$`-r|56aEleJADj^&1Umx*!!0hGoXp~q z<ow(MI~|Z8co-NM*qE6Zc^G;A2rvr#uabcUik?kQesW??v7H`5%PrQ#;^fRslpq16 zR1hu(87BqKr?EmYOtqji$xy@C%oxVN$WX|X!Vt_*1X8z>@fLGVYTiobB7O!2h9V&l z0dfVzk)X6+1a>K>4ag-G1x0p73=9mPK{=*M8YBdYF(k)<gg~k=90fAP8009BM{5{j zRUnQ^VW?qDVeDWi0Xt5DL4=`(DUDf-0qRUp>B?Ni2P#`ti>*|P6;z9LxPCDz_!WtQ zTq@4Mz_60>7JF`DMSM<b9>mcgn~EeD7#P6Tfzk*I6Wjk=jJ3BIG&ygvWEJP<-D1tj zPfRH;Vgf}1OHpcK$}P5()a3k>)LYECi50ilQY%VQ^HOfHB^DHbXqK$}%sfrzTg;_J zIk#8~5{pWTi$IkS#6oG1Q$V)f;sALc6e5x!pMnY(21Yg^HfFKEY-~b|d`wLLIGDK@ zi!?#ja>U2yCT8Zv$5-iPl#~=$>FdK1i(YX-YO-E=Mq){Mx?X-!I$WYy59D}Fu3PN! z@hSPq@$p6SAd}cii*j-@lOVp~_RKBFFDh{@D#|aq#RrkmD@rXaO)V|~Csw%apky2$ xe~Y!CC^N4F;uCOug9(UtY#<en9jNp#2Bi%a9u7t(Mgc}1Mj>VnRt`lDMgV5O_bmVb diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-39.pyc deleted file mode 100644 index 5ea0109cb3369e363f18fd05d2eb7e5182b97e17..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5099 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 VSU5O2ggJycI61^PI5}iEcmSJql8gWV diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-39.pyc deleted file mode 100644 index 674582f58a3b1ead98ea0a0d25e86af1322b89e3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2695 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 DxG5GX diff --git a/env/Lib/site-packages/pip/py.typed b/env/Lib/site-packages/pip/py.typed index 0b44fd9b..493b53e4 100644 --- a/env/Lib/site-packages/pip/py.typed +++ b/env/Lib/site-packages/pip/py.typed @@ -1,4 +1,4 @@ pip is a command line program. While it is implemented in Python, and so is available for import, you must not use pip's internal APIs in this way. Typing -information is provided as a convenience only and is not a gaurantee. Expect +information is provided as a convenience only and is not a guarantee. Expect unannounced changes to the API and types in releases. diff --git a/env/Scripts/Activate.ps1 b/env/Scripts/Activate.ps1 index e06da144..e4891d86 100644 --- a/env/Scripts/Activate.ps1 +++ b/env/Scripts/Activate.ps1 @@ -96,6 +96,11 @@ function global:deactivate ([switch]$NonDestructive) { Remove-Item -Path env:VIRTUAL_ENV } + # Just remove VIRTUAL_ENV_PROMPT altogether. + if (Test-Path -Path Env:VIRTUAL_ENV_PROMPT) { + Remove-Item -Path env:VIRTUAL_ENV_PROMPT + } + # Just remove the _PYTHON_VENV_PROMPT_PREFIX altogether: if (Get-Variable -Name "_PYTHON_VENV_PROMPT_PREFIX" -ErrorAction SilentlyContinue) { Remove-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Scope Global -Force @@ -197,7 +202,7 @@ else { $Prompt = $pyvenvCfg['prompt']; } else { - Write-Verbose " Setting prompt based on parent's directory's name. (Is the directory name passed to venv module when creating the virutal environment)" + Write-Verbose " Setting prompt based on parent's directory's name. (Is the directory name passed to venv module when creating the virtual environment)" Write-Verbose " Got leaf-name of $VenvDir='$(Split-Path -Path $venvDir -Leaf)'" $Prompt = Split-Path -Path $venvDir -Leaf } @@ -228,6 +233,7 @@ if (-not $Env:VIRTUAL_ENV_DISABLE_PROMPT) { Write-Host -NoNewline -ForegroundColor Green "($_PYTHON_VENV_PROMPT_PREFIX) " _OLD_VIRTUAL_PROMPT } + $env:VIRTUAL_ENV_PROMPT = $Prompt } # Clear PYTHONHOME @@ -241,159 +247,256 @@ Copy-Item -Path Env:PATH -Destination Env:_OLD_VIRTUAL_PATH $Env:PATH = "$VenvExecDir$([System.IO.Path]::PathSeparator)$Env:PATH" # SIG # Begin signature block -# MIIc+AYJKoZIhvcNAQcCoIIc6TCCHOUCAQExDzANBglghkgBZQMEAgEFADB5Bgor +# MIIvJAYJKoZIhvcNAQcCoIIvFTCCLxECAQExDzANBglghkgBZQMEAgEFADB5Bgor # BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG -# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCAwnDYwEHaCQq0n -# 8NAvsN7H7BO7/48rXCNwrg891FS5vaCCC38wggUwMIIEGKADAgECAhAECRgbX9W7 -# ZnVTQ7VvlVAIMA0GCSqGSIb3DQEBCwUAMGUxCzAJBgNVBAYTAlVTMRUwEwYDVQQK -# EwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xJDAiBgNV -# BAMTG0RpZ2lDZXJ0IEFzc3VyZWQgSUQgUm9vdCBDQTAeFw0xMzEwMjIxMjAwMDBa -# Fw0yODEwMjIxMjAwMDBaMHIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2Vy -# dCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xMTAvBgNVBAMTKERpZ2lD -# ZXJ0IFNIQTIgQXNzdXJlZCBJRCBDb2RlIFNpZ25pbmcgQ0EwggEiMA0GCSqGSIb3 -# DQEBAQUAA4IBDwAwggEKAoIBAQD407Mcfw4Rr2d3B9MLMUkZz9D7RZmxOttE9X/l -# qJ3bMtdx6nadBS63j/qSQ8Cl+YnUNxnXtqrwnIal2CWsDnkoOn7p0WfTxvspJ8fT -# eyOU5JEjlpB3gvmhhCNmElQzUHSxKCa7JGnCwlLyFGeKiUXULaGj6YgsIJWuHEqH -# CN8M9eJNYBi+qsSyrnAxZjNxPqxwoqvOf+l8y5Kh5TsxHM/q8grkV7tKtel05iv+ -# bMt+dDk2DZDv5LVOpKnqagqrhPOsZ061xPeM0SAlI+sIZD5SlsHyDxL0xY4PwaLo -# LFH3c7y9hbFig3NBggfkOItqcyDQD2RzPJ6fpjOp/RnfJZPRAgMBAAGjggHNMIIB -# yTASBgNVHRMBAf8ECDAGAQH/AgEAMA4GA1UdDwEB/wQEAwIBhjATBgNVHSUEDDAK -# BggrBgEFBQcDAzB5BggrBgEFBQcBAQRtMGswJAYIKwYBBQUHMAGGGGh0dHA6Ly9v -# Y3NwLmRpZ2ljZXJ0LmNvbTBDBggrBgEFBQcwAoY3aHR0cDovL2NhY2VydHMuZGln -# aWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENBLmNydDCBgQYDVR0fBHow -# eDA6oDigNoY0aHR0cDovL2NybDQuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJl -# ZElEUm9vdENBLmNybDA6oDigNoY0aHR0cDovL2NybDMuZGlnaWNlcnQuY29tL0Rp -# Z2lDZXJ0QXNzdXJlZElEUm9vdENBLmNybDBPBgNVHSAESDBGMDgGCmCGSAGG/WwA -# AgQwKjAoBggrBgEFBQcCARYcaHR0cHM6Ly93d3cuZGlnaWNlcnQuY29tL0NQUzAK -# BghghkgBhv1sAzAdBgNVHQ4EFgQUWsS5eyoKo6XqcQPAYPkt9mV1DlgwHwYDVR0j -# BBgwFoAUReuir/SSy4IxLVGLp6chnfNtyA8wDQYJKoZIhvcNAQELBQADggEBAD7s -# DVoks/Mi0RXILHwlKXaoHV0cLToaxO8wYdd+C2D9wz0PxK+L/e8q3yBVN7Dh9tGS -# dQ9RtG6ljlriXiSBThCk7j9xjmMOE0ut119EefM2FAaK95xGTlz/kLEbBw6RFfu6 -# r7VRwo0kriTGxycqoSkoGjpxKAI8LpGjwCUR4pwUR6F6aGivm6dcIFzZcbEMj7uo -# +MUSaJ/PQMtARKUT8OZkDCUIQjKyNookAv4vcn4c10lFluhZHen6dGRrsutmQ9qz -# sIzV6Q3d9gEgzpkxYz0IGhizgZtPxpMQBvwHgfqL2vmCSfdibqFT+hKUGIUukpHq -# aGxEMrJmoecYpJpkUe8wggZHMIIFL6ADAgECAhADPtXtoGXRuMkd/PkqbJvYMA0G -# CSqGSIb3DQEBCwUAMHIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJ -# bmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xMTAvBgNVBAMTKERpZ2lDZXJ0 -# IFNIQTIgQXNzdXJlZCBJRCBDb2RlIFNpZ25pbmcgQ0EwHhcNMTgxMjE4MDAwMDAw -# WhcNMjExMjIyMTIwMDAwWjCBgzELMAkGA1UEBhMCVVMxFjAUBgNVBAgTDU5ldyBI -# YW1wc2hpcmUxEjAQBgNVBAcTCVdvbGZlYm9ybzEjMCEGA1UEChMaUHl0aG9uIFNv -# ZnR3YXJlIEZvdW5kYXRpb24xIzAhBgNVBAMTGlB5dGhvbiBTb2Z0d2FyZSBGb3Vu -# ZGF0aW9uMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAqr2kS7J1uW7o -# JRxlsdrETAjKarfoH5TI8PWST6Yb2xPooP7vHT4iaVXyL5Lze1f53Jw67Sp+u524 -# fJXf30qHViEWxumy2RWG0nciU2d+mMqzjlaAWSZNF0u4RcvyDJokEV0RUOqI5CG5 -# zPI3W9uQ6LiUk3HCYW6kpH177A5T3pw/Po8O8KErJGn1anaqtIICq99ySxrMad/2 -# hPMBRf6Ndah7f7HPn1gkSSTAoejyuqF5h+B0qI4+JK5+VLvz659VTbAWJsYakkxZ -# xVWYpFv4KeQSSwoo0DzMvmERsTzNvVBMWhu9OriJNg+QfFmf96zVTu93cZ+r7xMp -# bXyfIOGKhHMaRuZ8ihuWIx3gI9WHDFX6fBKR8+HlhdkaiBEWIsXRoy+EQUyK7zUs -# +FqOo2sRYttbs8MTF9YDKFZwyPjn9Wn+gLGd5NUEVyNvD9QVGBEtN7vx87bduJUB -# 8F4DylEsMtZTfjw/au6AmOnmneK5UcqSJuwRyZaGNk7y3qj06utx+HTTqHgi975U -# pxfyrwAqkovoZEWBVSpvku8PVhkBXcLmNe6MEHlFiaMoiADAeKmX5RFRkN+VrmYG -# Tg4zajxfdHeIY8TvLf48tTfmnQJd98geJQv/01NUy/FxuwqAuTkaez5Nl1LxP0Cp -# THhghzO4FRD4itT2wqTh4jpojw9QZnsCAwEAAaOCAcUwggHBMB8GA1UdIwQYMBaA -# FFrEuXsqCqOl6nEDwGD5LfZldQ5YMB0GA1UdDgQWBBT8Kr9+1L6s84KcpM97IgE7 -# uI8H8jAOBgNVHQ8BAf8EBAMCB4AwEwYDVR0lBAwwCgYIKwYBBQUHAwMwdwYDVR0f -# BHAwbjA1oDOgMYYvaHR0cDovL2NybDMuZGlnaWNlcnQuY29tL3NoYTItYXNzdXJl -# ZC1jcy1nMS5jcmwwNaAzoDGGL2h0dHA6Ly9jcmw0LmRpZ2ljZXJ0LmNvbS9zaGEy -# LWFzc3VyZWQtY3MtZzEuY3JsMEwGA1UdIARFMEMwNwYJYIZIAYb9bAMBMCowKAYI -# KwYBBQUHAgEWHGh0dHBzOi8vd3d3LmRpZ2ljZXJ0LmNvbS9DUFMwCAYGZ4EMAQQB -# MIGEBggrBgEFBQcBAQR4MHYwJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2lj -# ZXJ0LmNvbTBOBggrBgEFBQcwAoZCaHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29t -# L0RpZ2lDZXJ0U0hBMkFzc3VyZWRJRENvZGVTaWduaW5nQ0EuY3J0MAwGA1UdEwEB -# /wQCMAAwDQYJKoZIhvcNAQELBQADggEBAEt1oS21X0axiafPjyY+vlYqjWKuUu/Y -# FuYWIEq6iRRaFabNDhj9RBFQF/aJiE5msrQEOfAD6/6gVSH91lZWBqg6NEeG9T9S -# XbiAPvJ9CEWFsdkXUrjbWhvCnuZ7kqUuU5BAumI1QRbpYgZL3UA+iZXkmjbGh1ln -# 8rUhWIxbBYL4Sg2nqpB44p7CUFYkPj/MbwU2gvBV2pXjj5WaskoZtsACMv5g42BN -# oVLoRAi+ev6s07POt+JtHRIm87lTyuc8wh0swTPUwksKbLU1Zdj9CpqtzXnuVE0w -# 50exJvRSK3Vt4g+0vigpI3qPmDdpkf9+4Mvy0XMNcqrthw20R+PkIlMxghDPMIIQ -# ywIBATCBhjByMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkw -# FwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMTEwLwYDVQQDEyhEaWdpQ2VydCBTSEEy -# IEFzc3VyZWQgSUQgQ29kZSBTaWduaW5nIENBAhADPtXtoGXRuMkd/PkqbJvYMA0G -# CWCGSAFlAwQCAQUAoIGYMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEEMBwGCisG -# AQQBgjcCAQsxDjAMBgorBgEEAYI3AgEVMCwGCisGAQQBgjcCAQwxHjAcoBqAGABQ -# AHkAdABoAG8AbgAgADMALgA5AC4ANjAvBgkqhkiG9w0BCQQxIgQgBrni4mcRv7sM -# JHsxpROjRopOz2wuQVrJnn+lD7X7y+gwDQYJKoZIhvcNAQEBBQAEggIAKBxtIIh2 -# APcTqLi9A0nTuTBMVUsNOQNQzSI9fW92jLmXUh0OGygpOMC9GiVVRnHNGmCWt9FV -# pMkolylPuI7wj08VFv5xvsnWo9EKM2+M0zZ1fN+/zNDvrRPKmhUTQ/fGIP9OWF3x -# qbUCGSXrzVf/wSvYmhdBXa7pTrivIx8JOS8fhK5dqSiCmtJOPQ45ZEFNzfgB5i9e -# 9lfNQ0wXKfKHo2zdqS19VEbuIUN8GjSlos7rGHP20aMjb0ZgKWBkYHHm4yNAgJCU -# AJ8K+mL2+KRJDyxwH1oFjgkFKAvEHMVo8by3TigZIxmIkNlYBYx3oh7S3wgKKtNf -# wZqX6/iDYOBmj49CxOEfoN4jtg5kg1slzbham+EPAE2pkNmg+RMkF0j9lJ5KTWrt -# tUZvWJI17UQV0bRlbp4bYiI7OxGDD3LNU1iQo69J3q8rFc+yyplD7lJzKb7h/mH/ -# oMBa6TVHNBuSBSMGLN6xOoshcwWMo0hhfdOqyjFNgdMHO8cEwXGhwJFPimXXt+NW -# KeKaW9i7dSzt1uNnqNXqXauk5A4upOxLceMFhmnoUwcsyxRxSFrti+uyUVMXOs1a -# Q8YyQZFfjy5CeOjq7ohDbBRarX5JwJrkB/BYya6TA9SKfRYwIxfiwYFf6yGLrjAy -# E0Qjhz5Np39AYpfcaWk31MeLse8NVtgVPPmhgg1+MIINegYKKwYBBAGCNwMDATGC -# DWowgg1mBgkqhkiG9w0BBwKggg1XMIINUwIBAzEPMA0GCWCGSAFlAwQCAQUAMHgG -# CyqGSIb3DQEJEAEEoGkEZzBlAgEBBglghkgBhv1sBwEwMTANBglghkgBZQMEAgEF -# AAQgUVAItwy7RQCrM4tGC7KCANd0O7DgaULOpzirVGSU8QMCEQDLPomRSCQZjdG/ -# GAILYuAXGA8yMDIxMDYyODE1MzMxNVqgggo3MIIE/jCCA+agAwIBAgIQDUJK4L46 -# iP9gQCHOFADw3TANBgkqhkiG9w0BAQsFADByMQswCQYDVQQGEwJVUzEVMBMGA1UE -# ChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMTEwLwYD -# VQQDEyhEaWdpQ2VydCBTSEEyIEFzc3VyZWQgSUQgVGltZXN0YW1waW5nIENBMB4X -# DTIxMDEwMTAwMDAwMFoXDTMxMDEwNjAwMDAwMFowSDELMAkGA1UEBhMCVVMxFzAV -# BgNVBAoTDkRpZ2lDZXJ0LCBJbmMuMSAwHgYDVQQDExdEaWdpQ2VydCBUaW1lc3Rh -# bXAgMjAyMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMLmYYRnxYr1 -# DQikRcpja1HXOhFCvQp1dU2UtAxQtSYQ/h3Ib5FrDJbnGlxI70Tlv5thzRWRYlq4 -# /2cLnGP9NmqB+in43Stwhd4CGPN4bbx9+cdtCT2+anaH6Yq9+IRdHnbJ5MZ2djpT -# 0dHTWjaPxqPhLxs6t2HWc+xObTOKfF1FLUuxUOZBOjdWhtyTI433UCXoZObd048v -# V7WHIOsOjizVI9r0TXhG4wODMSlKXAwxikqMiMX3MFr5FK8VX2xDSQn9JiNT9o1j -# 6BqrW7EdMMKbaYK02/xWVLwfoYervnpbCiAvSwnJlaeNsvrWY4tOpXIc7p96AXP4 -# Gdb+DUmEvQECAwEAAaOCAbgwggG0MA4GA1UdDwEB/wQEAwIHgDAMBgNVHRMBAf8E -# AjAAMBYGA1UdJQEB/wQMMAoGCCsGAQUFBwMIMEEGA1UdIAQ6MDgwNgYJYIZIAYb9 -# bAcBMCkwJwYIKwYBBQUHAgEWG2h0dHA6Ly93d3cuZGlnaWNlcnQuY29tL0NQUzAf -# BgNVHSMEGDAWgBT0tuEgHf4prtLkYaWyoiWyyBc1bjAdBgNVHQ4EFgQUNkSGjqS6 -# sGa+vCgtHUQ23eNqerwwcQYDVR0fBGowaDAyoDCgLoYsaHR0cDovL2NybDMuZGln -# aWNlcnQuY29tL3NoYTItYXNzdXJlZC10cy5jcmwwMqAwoC6GLGh0dHA6Ly9jcmw0 -# LmRpZ2ljZXJ0LmNvbS9zaGEyLWFzc3VyZWQtdHMuY3JsMIGFBggrBgEFBQcBAQR5 -# MHcwJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBPBggrBgEF -# BQcwAoZDaHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0U0hBMkFz -# c3VyZWRJRFRpbWVzdGFtcGluZ0NBLmNydDANBgkqhkiG9w0BAQsFAAOCAQEASBzc -# temaI7znGucgDo5nRv1CclF0CiNHo6uS0iXEcFm+FKDlJ4GlTRQVGQd58NEEw4bZ -# O73+RAJmTe1ppA/2uHDPYuj1UUp4eTZ6J7fz51Kfk6ftQ55757TdQSKJ+4eiRgNO -# /PT+t2R3Y18jUmmDgvoaU+2QzI2hF3MN9PNlOXBL85zWenvaDLw9MtAby/Vh/HUI -# AHa8gQ74wOFcz8QRcucbZEnYIpp1FUL1LTI4gdr0YKK6tFL7XOBhJCVPst/JKahz -# Q1HavWPWH1ub9y4bTxMd90oNcX6Xt/Q/hOvB46NJofrOp79Wz7pZdmGJX36ntI5n -# ePk2mOHLKNpbh6aKLzCCBTEwggQZoAMCAQICEAqhJdbWMht+QeQF2jaXwhUwDQYJ -# KoZIhvcNAQELBQAwZTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IElu +# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCBnL745ElCYk8vk +# dBtMuQhLeWJ3ZGfzKW4DHCYzAn+QB6CCE8MwggWQMIIDeKADAgECAhAFmxtXno4h +# MuI5B72nd3VcMA0GCSqGSIb3DQEBDAUAMGIxCzAJBgNVBAYTAlVTMRUwEwYDVQQK +# EwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xITAfBgNV +# BAMTGERpZ2lDZXJ0IFRydXN0ZWQgUm9vdCBHNDAeFw0xMzA4MDExMjAwMDBaFw0z +# ODAxMTUxMjAwMDBaMGIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJ +# bmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xITAfBgNVBAMTGERpZ2lDZXJ0 +# IFRydXN0ZWQgUm9vdCBHNDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIB +# AL/mkHNo3rvkXUo8MCIwaTPswqclLskhPfKK2FnC4SmnPVirdprNrnsbhA3EMB/z +# G6Q4FutWxpdtHauyefLKEdLkX9YFPFIPUh/GnhWlfr6fqVcWWVVyr2iTcMKyunWZ +# anMylNEQRBAu34LzB4TmdDttceItDBvuINXJIB1jKS3O7F5OyJP4IWGbNOsFxl7s +# Wxq868nPzaw0QF+xembud8hIqGZXV59UWI4MK7dPpzDZVu7Ke13jrclPXuU15zHL +# 2pNe3I6PgNq2kZhAkHnDeMe2scS1ahg4AxCN2NQ3pC4FfYj1gj4QkXCrVYJBMtfb +# BHMqbpEBfCFM1LyuGwN1XXhm2ToxRJozQL8I11pJpMLmqaBn3aQnvKFPObURWBf3 +# JFxGj2T3wWmIdph2PVldQnaHiZdpekjw4KISG2aadMreSx7nDmOu5tTvkpI6nj3c +# AORFJYm2mkQZK37AlLTSYW3rM9nF30sEAMx9HJXDj/chsrIRt7t/8tWMcCxBYKqx +# YxhElRp2Yn72gLD76GSmM9GJB+G9t+ZDpBi4pncB4Q+UDCEdslQpJYls5Q5SUUd0 +# viastkF13nqsX40/ybzTQRESW+UQUOsxxcpyFiIJ33xMdT9j7CFfxCBRa2+xq4aL +# T8LWRV+dIPyhHsXAj6KxfgommfXkaS+YHS312amyHeUbAgMBAAGjQjBAMA8GA1Ud +# EwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBTs1+OC0nFdZEzf +# Lmc/57qYrhwPTzANBgkqhkiG9w0BAQwFAAOCAgEAu2HZfalsvhfEkRvDoaIAjeNk +# aA9Wz3eucPn9mkqZucl4XAwMX+TmFClWCzZJXURj4K2clhhmGyMNPXnpbWvWVPjS +# PMFDQK4dUPVS/JA7u5iZaWvHwaeoaKQn3J35J64whbn2Z006Po9ZOSJTROvIXQPK +# 7VB6fWIhCoDIc2bRoAVgX+iltKevqPdtNZx8WorWojiZ83iL9E3SIAveBO6Mm0eB +# cg3AFDLvMFkuruBx8lbkapdvklBtlo1oepqyNhR6BvIkuQkRUNcIsbiJeoQjYUIp +# 5aPNoiBB19GcZNnqJqGLFNdMGbJQQXE9P01wI4YMStyB0swylIQNCAmXHE/A7msg +# dDDS4Dk0EIUhFQEI6FUy3nFJ2SgXUE3mvk3RdazQyvtBuEOlqtPDBURPLDab4vri +# RbgjU2wGb2dVf0a1TD9uKFp5JtKkqGKX0h7i7UqLvBv9R0oN32dmfrJbQdA75PQ7 +# 9ARj6e/CVABRoIoqyc54zNXqhwQYs86vSYiv85KZtrPmYQ/ShQDnUBrkG5WdGaG5 +# nLGbsQAe79APT0JsyQq87kP6OnGlyE0mpTX9iV28hWIdMtKgK1TtmlfB2/oQzxm3 +# i0objwG2J5VT6LaJbVu8aNQj6ItRolb58KaAoNYes7wPD1N1KarqE3fk3oyBIa0H +# EEcRrYc9B9F1vM/zZn4wggawMIIEmKADAgECAhAIrUCyYNKcTJ9ezam9k67ZMA0G +# CSqGSIb3DQEBDAUAMGIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJ +# bmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xITAfBgNVBAMTGERpZ2lDZXJ0 +# IFRydXN0ZWQgUm9vdCBHNDAeFw0yMTA0MjkwMDAwMDBaFw0zNjA0MjgyMzU5NTla +# MGkxCzAJBgNVBAYTAlVTMRcwFQYDVQQKEw5EaWdpQ2VydCwgSW5jLjFBMD8GA1UE +# AxM4RGlnaUNlcnQgVHJ1c3RlZCBHNCBDb2RlIFNpZ25pbmcgUlNBNDA5NiBTSEEz +# ODQgMjAyMSBDQTEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDVtC9C +# 0CiteLdd1TlZG7GIQvUzjOs9gZdwxbvEhSYwn6SOaNhc9es0JAfhS0/TeEP0F9ce +# 2vnS1WcaUk8OoVf8iJnBkcyBAz5NcCRks43iCH00fUyAVxJrQ5qZ8sU7H/Lvy0da +# E6ZMswEgJfMQ04uy+wjwiuCdCcBlp/qYgEk1hz1RGeiQIXhFLqGfLOEYwhrMxe6T +# SXBCMo/7xuoc82VokaJNTIIRSFJo3hC9FFdd6BgTZcV/sk+FLEikVoQ11vkunKoA +# FdE3/hoGlMJ8yOobMubKwvSnowMOdKWvObarYBLj6Na59zHh3K3kGKDYwSNHR7Oh +# D26jq22YBoMbt2pnLdK9RBqSEIGPsDsJ18ebMlrC/2pgVItJwZPt4bRc4G/rJvmM +# 1bL5OBDm6s6R9b7T+2+TYTRcvJNFKIM2KmYoX7BzzosmJQayg9Rc9hUZTO1i4F4z +# 8ujo7AqnsAMrkbI2eb73rQgedaZlzLvjSFDzd5Ea/ttQokbIYViY9XwCFjyDKK05 +# huzUtw1T0PhH5nUwjewwk3YUpltLXXRhTT8SkXbev1jLchApQfDVxW0mdmgRQRNY +# mtwmKwH0iU1Z23jPgUo+QEdfyYFQc4UQIyFZYIpkVMHMIRroOBl8ZhzNeDhFMJlP +# /2NPTLuqDQhTQXxYPUez+rbsjDIJAsxsPAxWEQIDAQABo4IBWTCCAVUwEgYDVR0T +# AQH/BAgwBgEB/wIBADAdBgNVHQ4EFgQUaDfg67Y7+F8Rhvv+YXsIiGX0TkIwHwYD +# VR0jBBgwFoAU7NfjgtJxXWRM3y5nP+e6mK4cD08wDgYDVR0PAQH/BAQDAgGGMBMG +# A1UdJQQMMAoGCCsGAQUFBwMDMHcGCCsGAQUFBwEBBGswaTAkBggrBgEFBQcwAYYY +# aHR0cDovL29jc3AuZGlnaWNlcnQuY29tMEEGCCsGAQUFBzAChjVodHRwOi8vY2Fj +# ZXJ0cy5kaWdpY2VydC5jb20vRGlnaUNlcnRUcnVzdGVkUm9vdEc0LmNydDBDBgNV +# HR8EPDA6MDigNqA0hjJodHRwOi8vY3JsMy5kaWdpY2VydC5jb20vRGlnaUNlcnRU +# cnVzdGVkUm9vdEc0LmNybDAcBgNVHSAEFTATMAcGBWeBDAEDMAgGBmeBDAEEATAN +# BgkqhkiG9w0BAQwFAAOCAgEAOiNEPY0Idu6PvDqZ01bgAhql+Eg08yy25nRm95Ry +# sQDKr2wwJxMSnpBEn0v9nqN8JtU3vDpdSG2V1T9J9Ce7FoFFUP2cvbaF4HZ+N3HL +# IvdaqpDP9ZNq4+sg0dVQeYiaiorBtr2hSBh+3NiAGhEZGM1hmYFW9snjdufE5Btf +# Q/g+lP92OT2e1JnPSt0o618moZVYSNUa/tcnP/2Q0XaG3RywYFzzDaju4ImhvTnh +# OE7abrs2nfvlIVNaw8rpavGiPttDuDPITzgUkpn13c5UbdldAhQfQDN8A+KVssIh +# dXNSy0bYxDQcoqVLjc1vdjcshT8azibpGL6QB7BDf5WIIIJw8MzK7/0pNVwfiThV +# 9zeKiwmhywvpMRr/LhlcOXHhvpynCgbWJme3kuZOX956rEnPLqR0kq3bPKSchh/j +# wVYbKyP/j7XqiHtwa+aguv06P0WmxOgWkVKLQcBIhEuWTatEQOON8BUozu3xGFYH +# Ki8QxAwIZDwzj64ojDzLj4gLDb879M4ee47vtevLt/B3E+bnKD+sEq6lLyJsQfmC +# XBVmzGwOysWGw/YmMwwHS6DTBwJqakAwSEs0qFEgu60bhQjiWQ1tygVQK+pKHJ6l +# /aCnHwZ05/LWUpD9r4VIIflXO7ScA+2GRfS0YW6/aOImYIbqyK+p/pQd52MbOoZW +# eE4wggd3MIIFX6ADAgECAhAHHxQbizANJfMU6yMM0NHdMA0GCSqGSIb3DQEBCwUA +# MGkxCzAJBgNVBAYTAlVTMRcwFQYDVQQKEw5EaWdpQ2VydCwgSW5jLjFBMD8GA1UE +# AxM4RGlnaUNlcnQgVHJ1c3RlZCBHNCBDb2RlIFNpZ25pbmcgUlNBNDA5NiBTSEEz +# ODQgMjAyMSBDQTEwHhcNMjIwMTE3MDAwMDAwWhcNMjUwMTE1MjM1OTU5WjB8MQsw +# CQYDVQQGEwJVUzEPMA0GA1UECBMGT3JlZ29uMRIwEAYDVQQHEwlCZWF2ZXJ0b24x +# IzAhBgNVBAoTGlB5dGhvbiBTb2Z0d2FyZSBGb3VuZGF0aW9uMSMwIQYDVQQDExpQ +# eXRob24gU29mdHdhcmUgRm91bmRhdGlvbjCCAiIwDQYJKoZIhvcNAQEBBQADggIP +# ADCCAgoCggIBAKgc0BTT+iKbtK6f2mr9pNMUTcAJxKdsuOiSYgDFfwhjQy89koM7 +# uP+QV/gwx8MzEt3c9tLJvDccVWQ8H7mVsk/K+X+IufBLCgUi0GGAZUegEAeRlSXx +# xhYScr818ma8EvGIZdiSOhqjYc4KnfgfIS4RLtZSrDFG2tN16yS8skFa3IHyvWdb +# D9PvZ4iYNAS4pjYDRjT/9uzPZ4Pan+53xZIcDgjiTwOh8VGuppxcia6a7xCyKoOA +# GjvCyQsj5223v1/Ig7Dp9mGI+nh1E3IwmyTIIuVHyK6Lqu352diDY+iCMpk9Zanm +# SjmB+GMVs+H/gOiofjjtf6oz0ki3rb7sQ8fTnonIL9dyGTJ0ZFYKeb6BLA66d2GA +# LwxZhLe5WH4Np9HcyXHACkppsE6ynYjTOd7+jN1PRJahN1oERzTzEiV6nCO1M3U1 +# HbPTGyq52IMFSBM2/07WTJSbOeXjvYR7aUxK9/ZkJiacl2iZI7IWe7JKhHohqKuc +# eQNyOzxTakLcRkzynvIrk33R9YVqtB4L6wtFxhUjvDnQg16xot2KVPdfyPAWd81w +# tZADmrUtsZ9qG79x1hBdyOl4vUtVPECuyhCxaw+faVjumapPUnwo8ygflJJ74J+B +# Yxf6UuD7m8yzsfXWkdv52DjL74TxzuFTLHPyARWCSCAbzn3ZIly+qIqDAgMBAAGj +# ggIGMIICAjAfBgNVHSMEGDAWgBRoN+Drtjv4XxGG+/5hewiIZfROQjAdBgNVHQ4E +# FgQUt/1Teh2XDuUj2WW3siYWJgkZHA8wDgYDVR0PAQH/BAQDAgeAMBMGA1UdJQQM +# MAoGCCsGAQUFBwMDMIG1BgNVHR8Ega0wgaowU6BRoE+GTWh0dHA6Ly9jcmwzLmRp +# Z2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNENvZGVTaWduaW5nUlNBNDA5NlNI +# QTM4NDIwMjFDQTEuY3JsMFOgUaBPhk1odHRwOi8vY3JsNC5kaWdpY2VydC5jb20v +# RGlnaUNlcnRUcnVzdGVkRzRDb2RlU2lnbmluZ1JTQTQwOTZTSEEzODQyMDIxQ0Ex +# LmNybDA+BgNVHSAENzA1MDMGBmeBDAEEATApMCcGCCsGAQUFBwIBFhtodHRwOi8v +# d3d3LmRpZ2ljZXJ0LmNvbS9DUFMwgZQGCCsGAQUFBwEBBIGHMIGEMCQGCCsGAQUF +# BzABhhhodHRwOi8vb2NzcC5kaWdpY2VydC5jb20wXAYIKwYBBQUHMAKGUGh0dHA6 +# Ly9jYWNlcnRzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNENvZGVTaWdu +# aW5nUlNBNDA5NlNIQTM4NDIwMjFDQTEuY3J0MAwGA1UdEwEB/wQCMAAwDQYJKoZI +# hvcNAQELBQADggIBABxv4AeV/5ltkELHSC63fXAFYS5tadcWTiNc2rskrNLrfH1N +# s0vgSZFoQxYBFKI159E8oQQ1SKbTEubZ/B9kmHPhprHya08+VVzxC88pOEvz68nA +# 82oEM09584aILqYmj8Pj7h/kmZNzuEL7WiwFa/U1hX+XiWfLIJQsAHBla0i7QRF2 +# de8/VSF0XXFa2kBQ6aiTsiLyKPNbaNtbcucaUdn6vVUS5izWOXM95BSkFSKdE45O +# q3FForNJXjBvSCpwcP36WklaHL+aHu1upIhCTUkzTHMh8b86WmjRUqbrnvdyR2yd +# I5l1OqcMBjkpPpIV6wcc+KY/RH2xvVuuoHjlUjwq2bHiNoX+W1scCpnA8YTs2d50 +# jDHUgwUo+ciwpffH0Riq132NFmrH3r67VaN3TuBxjI8SIZM58WEDkbeoriDk3hxU +# 8ZWV7b8AW6oyVBGfM06UgkfMb58h+tJPrFx8VI/WLq1dTqMfZOm5cuclMnUHs2uq +# rRNtnV8UfidPBL4ZHkTcClQbCoz0UbLhkiDvIS00Dn+BBcxw/TKqVL4Oaz3bkMSs +# M46LciTeucHY9ExRVt3zy7i149sd+F4QozPqn7FrSVHXmem3r7bjyHTxOgqxRCVa +# 18Vtx7P/8bYSBeS+WHCKcliFCecspusCDSlnRUjZwyPdP0VHxaZg2unjHY3rMYIa +# tzCCGrMCAQEwfTBpMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIElu +# Yy4xQTA/BgNVBAMTOERpZ2lDZXJ0IFRydXN0ZWQgRzQgQ29kZSBTaWduaW5nIFJT +# QTQwOTYgU0hBMzg0IDIwMjEgQ0ExAhAHHxQbizANJfMU6yMM0NHdMA0GCWCGSAFl +# AwQCAQUAoIHIMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEEMBwGCisGAQQBgjcC +# AQsxDjAMBgorBgEEAYI3AgEVMC8GCSqGSIb3DQEJBDEiBCBnAZ6P7YvTwq0fbF62 +# o7E75R0LxsW5OtyYiFESQckLhjBcBgorBgEEAYI3AgEMMU4wTKBGgEQAQgB1AGkA +# bAB0ADoAIABSAGUAbABlAGEAcwBlAF8AdgAzAC4AMQAyAC4AMABfADIAMAAyADMA +# MQAwADAAMgAuADAAMaECgAAwDQYJKoZIhvcNAQEBBQAEggIAk+1ya4KYmJwPdyhn +# UCoARJ3l7b9UN3AATHE7oO50+piT9AvRbtmqgY0Tper2DQmBe8FRDBu/52l6nBtc +# 30SBrwPvs3zgvQSfhtjozpOo8bAv23MQaNbMlzW07aVBU+4Vd0v+65FwIkBiCuDk +# CprYElSno9fsRpktxYJ9lsmdxsgyxdFg6VDzkwwp0wJBT1VVdtBNx3143gVExXE2 +# g+zSfMug1+o3Jj054gmK0BYYvg7T+qHRRjYmVvuXMLXRgY5so6vVHjv6oARFGQ9/ +# dEcY0b04c3jp/lSK+Nd0v3aY1FeguOnxPz32PHNg/ICygyRG+ivLyHkdLIJrGuIo +# Te6dAgLgCKcooQ9MVNG2F/gw5tVCYrEOAyNwUxgl7zX7fXVlTAgAE2vxawb8NCeQ +# f3InGRIkocO3hrEFVlCW58WG0utSkUwzknrkpMEscLEIZwO30gBartqyTajYsi4+ +# vSOTW6CQp2+CvwtDpF4ll40sxPmNbDX7KWkD/OhD8zwxvRpKrkgjIpdzlfzen9uV +# 70E2UV2JHWVvvdqERRILOQPbSERiPPaPwjjtjWa6HwzF386We4USv+mL4AZhmxgP +# 4ov0+c6qgVdmjUpTA8Q/RoX6WXHyhvflAsfhX/h0sBtqxhdiqoXtIH6bqAZfSpOq +# 2GN9KZ2WSppZy2nWeULuSvSwjmahghdAMIIXPAYKKwYBBAGCNwMDATGCFywwghco +# BgkqhkiG9w0BBwKgghcZMIIXFQIBAzEPMA0GCWCGSAFlAwQCAQUAMHgGCyqGSIb3 +# DQEJEAEEoGkEZzBlAgEBBglghkgBhv1sBwEwMTANBglghkgBZQMEAgEFAAQgnmxA +# vhfTXC1rhKE1Olq0ip2jyhXJM2BAt3lCUFLFnQkCEQC0R5Uki33yd+oDVBKaPX6T +# GA8yMDIzMTAwMjEzMjMzMlqgghMJMIIGwjCCBKqgAwIBAgIQBUSv85SdCDmmv9s/ +# X+VhFjANBgkqhkiG9w0BAQsFADBjMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGln +# aUNlcnQsIEluYy4xOzA5BgNVBAMTMkRpZ2lDZXJ0IFRydXN0ZWQgRzQgUlNBNDA5 +# NiBTSEEyNTYgVGltZVN0YW1waW5nIENBMB4XDTIzMDcxNDAwMDAwMFoXDTM0MTAx +# MzIzNTk1OVowSDELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDkRpZ2lDZXJ0LCBJbmMu +# MSAwHgYDVQQDExdEaWdpQ2VydCBUaW1lc3RhbXAgMjAyMzCCAiIwDQYJKoZIhvcN +# AQEBBQADggIPADCCAgoCggIBAKNTRYcdg45brD5UsyPgz5/X5dLnXaEOCdwvSKOX +# ejsqnGfcYhVYwamTEafNqrJq3RApih5iY2nTWJw1cb86l+uUUI8cIOrHmjsvlmbj +# aedp/lvD1isgHMGXlLSlUIHyz8sHpjBoyoNC2vx/CSSUpIIa2mq62DvKXd4ZGIX7 +# ReoNYWyd/nFexAaaPPDFLnkPG2ZS48jWPl/aQ9OE9dDH9kgtXkV1lnX+3RChG4PB +# uOZSlbVH13gpOWvgeFmX40QrStWVzu8IF+qCZE3/I+PKhu60pCFkcOvV5aDaY7Mu +# 6QXuqvYk9R28mxyyt1/f8O52fTGZZUdVnUokL6wrl76f5P17cz4y7lI0+9S769Sg +# LDSb495uZBkHNwGRDxy1Uc2qTGaDiGhiu7xBG3gZbeTZD+BYQfvYsSzhUa+0rRUG +# FOpiCBPTaR58ZE2dD9/O0V6MqqtQFcmzyrzXxDtoRKOlO0L9c33u3Qr/eTQQfqZc +# ClhMAD6FaXXHg2TWdc2PEnZWpST618RrIbroHzSYLzrqawGw9/sqhux7UjipmAmh +# cbJsca8+uG+W1eEQE/5hRwqM/vC2x9XH3mwk8L9CgsqgcT2ckpMEtGlwJw1Pt7U2 +# 0clfCKRwo+wK8REuZODLIivK8SgTIUlRfgZm0zu++uuRONhRB8qUt+JQofM604qD +# y0B7AgMBAAGjggGLMIIBhzAOBgNVHQ8BAf8EBAMCB4AwDAYDVR0TAQH/BAIwADAW +# BgNVHSUBAf8EDDAKBggrBgEFBQcDCDAgBgNVHSAEGTAXMAgGBmeBDAEEAjALBglg +# hkgBhv1sBwEwHwYDVR0jBBgwFoAUuhbZbU2FL3MpdpovdYxqII+eyG8wHQYDVR0O +# BBYEFKW27xPn783QZKHVVqllMaPe1eNJMFoGA1UdHwRTMFEwT6BNoEuGSWh0dHA6 +# Ly9jcmwzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNFJTQTQwOTZTSEEy +# NTZUaW1lU3RhbXBpbmdDQS5jcmwwgZAGCCsGAQUFBwEBBIGDMIGAMCQGCCsGAQUF +# BzABhhhodHRwOi8vb2NzcC5kaWdpY2VydC5jb20wWAYIKwYBBQUHMAKGTGh0dHA6 +# Ly9jYWNlcnRzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNFJTQTQwOTZT +# SEEyNTZUaW1lU3RhbXBpbmdDQS5jcnQwDQYJKoZIhvcNAQELBQADggIBAIEa1t6g +# qbWYF7xwjU+KPGic2CX/yyzkzepdIpLsjCICqbjPgKjZ5+PF7SaCinEvGN1Ott5s +# 1+FgnCvt7T1IjrhrunxdvcJhN2hJd6PrkKoS1yeF844ektrCQDifXcigLiV4JZ0q +# BXqEKZi2V3mP2yZWK7Dzp703DNiYdk9WuVLCtp04qYHnbUFcjGnRuSvExnvPnPp4 +# 4pMadqJpddNQ5EQSviANnqlE0PjlSXcIWiHFtM+YlRpUurm8wWkZus8W8oM3NG6w +# QSbd3lqXTzON1I13fXVFoaVYJmoDRd7ZULVQjK9WvUzF4UbFKNOt50MAcN7MmJ4Z +# iQPq1JE3701S88lgIcRWR+3aEUuMMsOI5ljitts++V+wQtaP4xeR0arAVeOGv6wn +# LEHQmjNKqDbUuXKWfpd5OEhfysLcPTLfddY2Z1qJ+Panx+VPNTwAvb6cKmx5Adza +# ROY63jg7B145WPR8czFVoIARyxQMfq68/qTreWWqaNYiyjvrmoI1VygWy2nyMpqy +# 0tg6uLFGhmu6F/3Ed2wVbK6rr3M66ElGt9V/zLY4wNjsHPW2obhDLN9OTH0eaHDA +# dwrUAuBcYLso/zjlUlrWrBciI0707NMX+1Br/wd3H3GXREHJuEbTbDJ8WC9nR2Xl +# G3O2mflrLAZG70Ee8PBf4NvZrZCARK+AEEGKMIIGrjCCBJagAwIBAgIQBzY3tyRU +# fNhHrP0oZipeWzANBgkqhkiG9w0BAQsFADBiMQswCQYDVQQGEwJVUzEVMBMGA1UE +# ChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSEwHwYD +# VQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3QgRzQwHhcNMjIwMzIzMDAwMDAwWhcN +# MzcwMzIyMjM1OTU5WjBjMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQs +# IEluYy4xOzA5BgNVBAMTMkRpZ2lDZXJ0IFRydXN0ZWQgRzQgUlNBNDA5NiBTSEEy +# NTYgVGltZVN0YW1waW5nIENBMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKC +# AgEAxoY1BkmzwT1ySVFVxyUDxPKRN6mXUaHW0oPRnkyibaCwzIP5WvYRoUQVQl+k +# iPNo+n3znIkLf50fng8zH1ATCyZzlm34V6gCff1DtITaEfFzsbPuK4CEiiIY3+va +# PcQXf6sZKz5C3GeO6lE98NZW1OcoLevTsbV15x8GZY2UKdPZ7Gnf2ZCHRgB720RB +# idx8ald68Dd5n12sy+iEZLRS8nZH92GDGd1ftFQLIWhuNyG7QKxfst5Kfc71ORJn +# 7w6lY2zkpsUdzTYNXNXmG6jBZHRAp8ByxbpOH7G1WE15/tePc5OsLDnipUjW8LAx +# E6lXKZYnLvWHpo9OdhVVJnCYJn+gGkcgQ+NDY4B7dW4nJZCYOjgRs/b2nuY7W+yB +# 3iIU2YIqx5K/oN7jPqJz+ucfWmyU8lKVEStYdEAoq3NDzt9KoRxrOMUp88qqlnNC +# aJ+2RrOdOqPVA+C/8KI8ykLcGEh/FDTP0kyr75s9/g64ZCr6dSgkQe1CvwWcZklS +# UPRR8zZJTYsg0ixXNXkrqPNFYLwjjVj33GHek/45wPmyMKVM1+mYSlg+0wOI/rOP +# 015LdhJRk8mMDDtbiiKowSYI+RQQEgN9XyO7ZONj4KbhPvbCdLI/Hgl27KtdRnXi +# YKNYCQEoAA6EVO7O6V3IXjASvUaetdN2udIOa5kM0jO0zbECAwEAAaOCAV0wggFZ +# MBIGA1UdEwEB/wQIMAYBAf8CAQAwHQYDVR0OBBYEFLoW2W1NhS9zKXaaL3WMaiCP +# nshvMB8GA1UdIwQYMBaAFOzX44LScV1kTN8uZz/nupiuHA9PMA4GA1UdDwEB/wQE +# AwIBhjATBgNVHSUEDDAKBggrBgEFBQcDCDB3BggrBgEFBQcBAQRrMGkwJAYIKwYB +# BQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBBBggrBgEFBQcwAoY1aHR0 +# cDovL2NhY2VydHMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0VHJ1c3RlZFJvb3RHNC5j +# cnQwQwYDVR0fBDwwOjA4oDagNIYyaHR0cDovL2NybDMuZGlnaWNlcnQuY29tL0Rp +# Z2lDZXJ0VHJ1c3RlZFJvb3RHNC5jcmwwIAYDVR0gBBkwFzAIBgZngQwBBAIwCwYJ +# YIZIAYb9bAcBMA0GCSqGSIb3DQEBCwUAA4ICAQB9WY7Ak7ZvmKlEIgF+ZtbYIULh +# sBguEE0TzzBTzr8Y+8dQXeJLKftwig2qKWn8acHPHQfpPmDI2AvlXFvXbYf6hCAl +# NDFnzbYSlm/EUExiHQwIgqgWvalWzxVzjQEiJc6VaT9Hd/tydBTX/6tPiix6q4XN +# Q1/tYLaqT5Fmniye4Iqs5f2MvGQmh2ySvZ180HAKfO+ovHVPulr3qRCyXen/KFSJ +# 8NWKcXZl2szwcqMj+sAngkSumScbqyQeJsG33irr9p6xeZmBo1aGqwpFyd/EjaDn +# mPv7pp1yr8THwcFqcdnGE4AJxLafzYeHJLtPo0m5d2aR8XKc6UsCUqc3fpNTrDsd +# CEkPlM05et3/JWOZJyw9P2un8WbDQc1PtkCbISFA0LcTJM3cHXg65J6t5TRxktcm +# a+Q4c6umAU+9Pzt4rUyt+8SVe+0KXzM5h0F4ejjpnOHdI/0dKNPH+ejxmF/7K9h+ +# 8kaddSweJywm228Vex4Ziza4k9Tm8heZWcpw8De/mADfIBZPJ/tgZxahZrrdVcA6 +# KYawmKAr7ZVBtzrVFZgxtGIJDwq9gdkT/r+k0fNX2bwE+oLeMt8EifAAzV3C+dAj +# fwAL5HYCJtnwZXZCpimHCUcr5n8apIUP/JiW9lVUKx+A+sDyDivl1vupL0QVSucT +# Dh3bNzgaoSv27dZ8/DCCBY0wggR1oAMCAQICEA6bGI750C3n79tQ4ghAGFowDQYJ +# KoZIhvcNAQEMBQAwZTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IElu # YzEZMBcGA1UECxMQd3d3LmRpZ2ljZXJ0LmNvbTEkMCIGA1UEAxMbRGlnaUNlcnQg -# QXNzdXJlZCBJRCBSb290IENBMB4XDTE2MDEwNzEyMDAwMFoXDTMxMDEwNzEyMDAw -# MFowcjELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UE -# CxMQd3d3LmRpZ2ljZXJ0LmNvbTExMC8GA1UEAxMoRGlnaUNlcnQgU0hBMiBBc3N1 -# cmVkIElEIFRpbWVzdGFtcGluZyBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC -# AQoCggEBAL3QMu5LzY9/3am6gpnFOVQoV7YjSsQOB0UzURB90Pl9TWh+57ag9I2z -# iOSXv2MhkJi/E7xX08PhfgjWahQAOPcuHjvuzKb2Mln+X2U/4Jvr40ZHBhpVfgsn -# fsCi9aDg3iI/Dv9+lfvzo7oiPhisEeTwmQNtO4V8CdPuXciaC1TjqAlxa+DPIhAP -# dc9xck4Krd9AOly3UeGheRTGTSQjMF287DxgaqwvB8z98OpH2YhQXv1mblZhJymJ -# hFHmgudGUP2UKiyn5HU+upgPhH+fMRTWrdXyZMt7HgXQhBlyF/EXBu89zdZN7wZC -# /aJTKk+FHcQdPK/P2qwQ9d2srOlW/5MCAwEAAaOCAc4wggHKMB0GA1UdDgQWBBT0 -# tuEgHf4prtLkYaWyoiWyyBc1bjAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYunpyGd -# 823IDzASBgNVHRMBAf8ECDAGAQH/AgEAMA4GA1UdDwEB/wQEAwIBhjATBgNVHSUE -# DDAKBggrBgEFBQcDCDB5BggrBgEFBQcBAQRtMGswJAYIKwYBBQUHMAGGGGh0dHA6 -# Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBDBggrBgEFBQcwAoY3aHR0cDovL2NhY2VydHMu -# ZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENBLmNydDCBgQYDVR0f -# BHoweDA6oDigNoY0aHR0cDovL2NybDQuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNz -# dXJlZElEUm9vdENBLmNybDA6oDigNoY0aHR0cDovL2NybDMuZGlnaWNlcnQuY29t -# L0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENBLmNybDBQBgNVHSAESTBHMDgGCmCGSAGG -# /WwAAgQwKjAoBggrBgEFBQcCARYcaHR0cHM6Ly93d3cuZGlnaWNlcnQuY29tL0NQ -# UzALBglghkgBhv1sBwEwDQYJKoZIhvcNAQELBQADggEBAHGVEulRh1Zpze/d2nyq -# Y3qzeM8GN0CE70uEv8rPAwL9xafDDiBCLK938ysfDCFaKrcFNB1qrpn4J6Jmvwmq -# YN92pDqTD/iy0dh8GWLoXoIlHsS6HHssIeLWWywUNUMEaLLbdQLgcseY1jxk5R9I -# EBhfiThhTWJGJIdjjJFSLK8pieV4H9YLFKWA1xJHcLN11ZOFk362kmf7U2GJqPVr -# lsD0WGkNfMgBsbkodbeZY4UijGHKeZR+WfyMD+NvtQEmtmyl7odRIeRYYJu6DC0r -# baLEfrvEJStHAgh8Sa4TtuF8QkIoxhhWz0E0tmZdtnR79VYzIi8iNrJLokqV2PWm -# jlIxggKGMIICggIBATCBhjByMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNl -# cnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMTEwLwYDVQQDEyhEaWdp -# Q2VydCBTSEEyIEFzc3VyZWQgSUQgVGltZXN0YW1waW5nIENBAhANQkrgvjqI/2BA -# Ic4UAPDdMA0GCWCGSAFlAwQCAQUAoIHRMBoGCSqGSIb3DQEJAzENBgsqhkiG9w0B -# CRABBDAcBgkqhkiG9w0BCQUxDxcNMjEwNjI4MTUzMzE1WjArBgsqhkiG9w0BCRAC -# DDEcMBowGDAWBBTh14Ko4ZG+72vKFpG1qrSUpiSb8zAvBgkqhkiG9w0BCQQxIgQg -# U63BaTxWvK6IjoVixdUxR2Ka9ngnAWl8TjG38EljW2IwNwYLKoZIhvcNAQkQAi8x -# KDAmMCQwIgQgsxCQBrwK2YMHkVcp4EQDQVyD4ykrYU8mlkyNNXHs9akwDQYJKoZI -# hvcNAQEBBQAEggEAmed9c1/5eDuMSWHIIs7oR1RWaY6OR4PjxqCkybJRvoGl8wO1 -# WmUE58PVZfTNtho02cKeP+HNsyohxFp78bBXwObFNC97vbmKR3U7ANBnu3iEE/hD -# V3M5RD1BN4SE8yzfRlN4DB5H8rgvArWpjO9JedbVrBKrEe4FwtU8vbQhdAyFMGv5 -# ITWLQgiDJOvAOjfC014JKRgnTMgY1JntNHO1ny2dgkYYql7kO7Jbgu3h/lox/lF2 -# 1Sfonu9hDsv1121CatHRMU8B3kDeiF2P9/ifu5e0UULd0mTsMF7CIUs1/TNX0bAp -# A6DuV3o0VVOjsfOSgQUiz/nMxVmQoWFv2sNc3w== +# QXNzdXJlZCBJRCBSb290IENBMB4XDTIyMDgwMTAwMDAwMFoXDTMxMTEwOTIzNTk1 +# OVowYjELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UE +# CxMQd3d3LmRpZ2ljZXJ0LmNvbTEhMB8GA1UEAxMYRGlnaUNlcnQgVHJ1c3RlZCBS +# b290IEc0MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAv+aQc2jeu+Rd +# SjwwIjBpM+zCpyUuySE98orYWcLhKac9WKt2ms2uexuEDcQwH/MbpDgW61bGl20d +# q7J58soR0uRf1gU8Ug9SH8aeFaV+vp+pVxZZVXKvaJNwwrK6dZlqczKU0RBEEC7f +# gvMHhOZ0O21x4i0MG+4g1ckgHWMpLc7sXk7Ik/ghYZs06wXGXuxbGrzryc/NrDRA +# X7F6Zu53yEioZldXn1RYjgwrt0+nMNlW7sp7XeOtyU9e5TXnMcvak17cjo+A2raR +# mECQecN4x7axxLVqGDgDEI3Y1DekLgV9iPWCPhCRcKtVgkEy19sEcypukQF8IUzU +# vK4bA3VdeGbZOjFEmjNAvwjXWkmkwuapoGfdpCe8oU85tRFYF/ckXEaPZPfBaYh2 +# mHY9WV1CdoeJl2l6SPDgohIbZpp0yt5LHucOY67m1O+SkjqePdwA5EUlibaaRBkr +# fsCUtNJhbesz2cXfSwQAzH0clcOP9yGyshG3u3/y1YxwLEFgqrFjGESVGnZifvaA +# sPvoZKYz0YkH4b235kOkGLimdwHhD5QMIR2yVCkliWzlDlJRR3S+Jqy2QXXeeqxf +# jT/JvNNBERJb5RBQ6zHFynIWIgnffEx1P2PsIV/EIFFrb7GrhotPwtZFX50g/KEe +# xcCPorF+CiaZ9eRpL5gdLfXZqbId5RsCAwEAAaOCATowggE2MA8GA1UdEwEB/wQF +# MAMBAf8wHQYDVR0OBBYEFOzX44LScV1kTN8uZz/nupiuHA9PMB8GA1UdIwQYMBaA +# FEXroq/0ksuCMS1Ri6enIZ3zbcgPMA4GA1UdDwEB/wQEAwIBhjB5BggrBgEFBQcB +# AQRtMGswJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBDBggr +# BgEFBQcwAoY3aHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNz +# dXJlZElEUm9vdENBLmNydDBFBgNVHR8EPjA8MDqgOKA2hjRodHRwOi8vY3JsMy5k +# aWdpY2VydC5jb20vRGlnaUNlcnRBc3N1cmVkSURSb290Q0EuY3JsMBEGA1UdIAQK +# MAgwBgYEVR0gADANBgkqhkiG9w0BAQwFAAOCAQEAcKC/Q1xV5zhfoKN0Gz22Ftf3 +# v1cHvZqsoYcs7IVeqRq7IviHGmlUIu2kiHdtvRoU9BNKei8ttzjv9P+Aufih9/Jy +# 3iS8UgPITtAq3votVs/59PesMHqai7Je1M/RQ0SbQyHrlnKhSLSZy51PpwYDE3cn +# RNTnf+hZqPC/Lwum6fI0POz3A8eHqNJMQBk1RmppVLC4oVaO7KTVPeix3P0c2PR3 +# WlxUjG/voVA9/HYJaISfb8rbII01YBwCA8sgsKxYoA5AY8WYIsGyWfVVa88nq2x2 +# zm8jLfR+cWojayL/ErhULSd+2DrZ8LaHlv1b0VysGMNNn3O3AamfV6peKOK5lDGC +# A3YwggNyAgEBMHcwYzELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDkRpZ2lDZXJ0LCBJ +# bmMuMTswOQYDVQQDEzJEaWdpQ2VydCBUcnVzdGVkIEc0IFJTQTQwOTYgU0hBMjU2 +# IFRpbWVTdGFtcGluZyBDQQIQBUSv85SdCDmmv9s/X+VhFjANBglghkgBZQMEAgEF +# AKCB0TAaBgkqhkiG9w0BCQMxDQYLKoZIhvcNAQkQAQQwHAYJKoZIhvcNAQkFMQ8X +# DTIzMTAwMjEzMjMzMlowKwYLKoZIhvcNAQkQAgwxHDAaMBgwFgQUZvArMsLCyQ+C +# Xc6qisnGTxmcz0AwLwYJKoZIhvcNAQkEMSIEIBa6X0J/pyxEP0qKmxfT51tQm4Im +# u/63uybfmuePN1UHMDcGCyqGSIb3DQEJEAIvMSgwJjAkMCIEINL25G3tdCLM0dRA +# V2hBNm+CitpVmq4zFq9NGprUDHgoMA0GCSqGSIb3DQEBAQUABIICAFRAXwhn3az4 +# r+zhZk2K3gibUwGFM4dHGKh1RD383PsnUii90EaBVzixPIppOs7v0iZOER2tce8u +# xgQ3IZtjRIuQmCh+9I6zWIH59MssGU6igexTAjc0dIfV66UeFlh2aSWWckxmaTI/ +# jXgpqx2sk4dlqJKrR/d084gyevoCkQNerED/FuwJ6bX8omhIikyHdoo6hbL595tK +# 4ekxek027svbPFC0WbAxZXLq428C5endJaAQV2RTCk0B1vgPFw5bvznldlQnRqMu +# vcd1GSoSVN16kw5UKWXEyP0e07yiXEPkFoPBSC/c5o7COjidK2VOlVY/gsorVMEA +# rx/apEwf1F70vD2caiIsUAhrmPzyslFZfU6o2fKXI/vrBTUvbzb5Vz+IGoXlwTH+ +# loWh4loof+pJjbpJJj26GQwssAl3M/m/3BGamnmf97CJShvPrM0w8WOLkXtn6/M4 +# Y15ywECiRhaQX7NUVzRBl1hGDDD0mFv/OHzMer3C4/8I04whBnfvMxelUb4YhlM6 +# e+F6DzvI91OWTrpjsPKOHE3ds9ra+F1yPkV1RMQMRx/xWd0D274R8W2baHxrYgS3 +# 2LYPSAYFMi3cmF6Df84iIG2d0qj0x3ioXDUUk72YTCUO1Xnz9jkHSCU7Bq2GL9uP +# z4sEyNDU23dEmfGD672vMRuZ6Ua/ks5J # SIG # End signature block diff --git a/env/Scripts/activate b/env/Scripts/activate index e642fb2e..83d829ce 100644 --- a/env/Scripts/activate +++ b/env/Scripts/activate @@ -1,5 +1,5 @@ # This file must be used with "source bin/activate" *from bash* -# you cannot run it directly +# You cannot run it directly deactivate () { # reset old environment variables @@ -28,6 +28,7 @@ deactivate () { fi unset VIRTUAL_ENV + unset VIRTUAL_ENV_PROMPT if [ ! "${1:-}" = "nondestructive" ] ; then # Self destruct! unset -f deactivate @@ -37,8 +38,15 @@ deactivate () { # unset irrelevant variables deactivate nondestructive -VIRTUAL_ENV="C:\Users\eldir\OneDrive - UNIVERSITAS INDONESIA\SEMESTER 6\PPL\a4-logistik\env" -export VIRTUAL_ENV +# on Windows, a path can contain colons and backslashes and has to be converted: +if [ "$OSTYPE" = "cygwin" ] || [ "$OSTYPE" = "msys" ] ; then + # transform D:\path\to\venv to /d/path/to/venv on MSYS + # and to /cygdrive/d/path/to/venv on Cygwin + export VIRTUAL_ENV=$(cygpath "D:\PPL\a4-logistik\env") +else + # use the path as-is + export VIRTUAL_ENV="D:\PPL\a4-logistik\env" +fi _OLD_VIRTUAL_PATH="$PATH" PATH="$VIRTUAL_ENV/Scripts:$PATH" @@ -56,6 +64,8 @@ if [ -z "${VIRTUAL_ENV_DISABLE_PROMPT:-}" ] ; then _OLD_VIRTUAL_PS1="${PS1:-}" PS1="(env) ${PS1:-}" export PS1 + VIRTUAL_ENV_PROMPT="(env) " + export VIRTUAL_ENV_PROMPT fi # This should detect bash and zsh, which have a hash command that must diff --git a/env/Scripts/activate.bat b/env/Scripts/activate.bat index 02e10db2..441312f5 100644 --- a/env/Scripts/activate.bat +++ b/env/Scripts/activate.bat @@ -8,7 +8,7 @@ if defined _OLD_CODEPAGE ( "%SystemRoot%\System32\chcp.com" 65001 > nul ) -set VIRTUAL_ENV=C:\Users\eldir\OneDrive - UNIVERSITAS INDONESIA\SEMESTER 6\PPL\a4-logistik\env +set VIRTUAL_ENV=D:\PPL\a4-logistik\env if not defined PROMPT set PROMPT=$P$G @@ -25,6 +25,7 @@ if defined _OLD_VIRTUAL_PATH set PATH=%_OLD_VIRTUAL_PATH% if not defined _OLD_VIRTUAL_PATH set _OLD_VIRTUAL_PATH=%PATH% set PATH=%VIRTUAL_ENV%\Scripts;%PATH% +set VIRTUAL_ENV_PROMPT=(env) :END if defined _OLD_CODEPAGE ( diff --git a/env/Scripts/deactivate.bat b/env/Scripts/deactivate.bat index 1205c618..62a39a75 100644 --- a/env/Scripts/deactivate.bat +++ b/env/Scripts/deactivate.bat @@ -17,5 +17,6 @@ if defined _OLD_VIRTUAL_PATH ( set _OLD_VIRTUAL_PATH= set VIRTUAL_ENV= +set VIRTUAL_ENV_PROMPT= :END diff --git a/env/Scripts/pip.exe b/env/Scripts/pip.exe index 6bf27412711b6f0f31603935323f7e96bd3683ed..8c12433cae8225bc3f158cab721375b9a87b84dc 100644 GIT binary patch delta 29315 zcmZ3rpY6jrwh1<jKPK9`#Q#btdp?^_6^2W$PE&n0n@{x*+fvnIV0ww_L@+%;_1$bf z)pw8Qsy+g%=U3eU7GD5WKLtup2Gc>A$r&IsCn`#41-LRWq_nXyF!H`jVt|4V3`z{# zOk4~M9~c-IHbDeyoF)q~>M>1PGTDjIO!SE!BZCb{VgVz=mtY14h6#)e4wHKs-I)$B zO;nVc{DG0fOz|B91A_nq#1s~gVgy!TU`Ws_N=Yn9WMFWy0Esg)Fjz4#FnpP;$0TLu z;>f_j;K0bhAi}`FpvMT3hhql@h68#95Umc}5UUw@7#J9wCf6}ZnSouifRTYAgn@y< z4@0YiUQudJeli0?2s6k;CI$wO%NA`u$E3tKiN#&!rWOOk3lC8S2A^IR6$6i6j|7ii z(FZ(?3@`WvCnvK+$n4ExV0dvw1XaNrkb+>D$=6wIn5K$N7G+HrG6-g5@aXlma5aA7 z)0t}VqJV#LAFC3#ixvZeN4KxVi{FZqceBdK$!ak$_;mYPxc1hlFz#bvWMFXYzV6w5 z)}{N{3sLFGUs;uWR5vj&cqIS#)c)(i{QG4)0|Ucu1_l9^?$a+;3qcHX?A^z}@Zops ze~<1Dj{F{fT#XNOUw^Sw6JoSW_hHZO>mJ?bUM!cIoXlqIxNIZXK#%To9@_srn18>B z<!4|3+uiN@0pvJW;{(jDZ#=YrbYFjA2sOp0`<N%#WiO1SCSPZ>6S=PeF&-iDP;#;+ zyED@o?a6uU4xEd485lfzb=iX_Z)bNC*4G3%HAE%DquWO%qWi{+ccPO8IP93-$xII5 z5UF1PQrsP*67c=Lhx7pt<)a?WM-1ZQVh^7=bH=0jjYjiNrV_5^pDbmD%|F@7bv(Lx z)BG73JX%kdDDdwx?eu44;PvTcE%Ik%aNIe8fq`KcCj$e+f6>U-3=BI!X~3iThz7_k zhhUH9HwqrzH~)+7ea*nodZ0wP`3F;JJ?po_%%zeLrQN4px({?;@Mu1w5bg0_RSn4u zg=ml=hZq>ncyz|7aD+n*^XTP$@&Et-7sApYPoDPZ{_&zm5@dP>PxpxznhGG%8?RYB znos}t=sy4AjTA`Wut#@{iUG)$_`^(R&P*1VCR_hPNB|^t;zis4|NlY8FoF2J9tJN; z!2&m4eB=j(sz<_$6tKVxkLLgXON2bEfAhDvGcquESpVQ}u>&!he}l#E^S9`OxYjrL zThu^|<{x13<NPh+Ag=Xc{uVw)28NyA{{R19|6jD~6$8W0umAu5_vwD|Uo;2A`vT@Y z_%9mw3goyCFY-Wc=sxk{l?DUDi$o9y<ia}|3=FQu-#o4VmauwS-z^m|z63V(zo^+O z1_s~mcb?XNKr(m0G9WAdi^_myo_SdRD`EApzE=;H0@?Rpl<5@%gJ<_QPwTh7{4Vc2 zt>5_ayFBx-e&@;W^3AvPZHbI$^WXm^VxHY+|BHTm$-n@&?c_@a2H(~vAO(NG3eNl& zy$VqPv2?{t1_qDTZzVDw&Hw(Fh<S9M`!Bi$tbltb#P0T&3=ESGOqZ|s=sx1n86n`& zSs>xjS)mZ>7~&Y}(YxZu*Z==L8sB{20)+=_xeg<Phw%}Q&ejK<pe*sw_>%F-|DpmQ zBTsttif(5ErPKo+ovf`sj12r!55D;L0~EWwWj>4yKD{w20lPs-c0VY|`t-6k_%JfK zbf50N?$cQxqoVL%bj1r$QYzuLj8O?FW$pF<@tVmPWNrl;Bg2d35TkT_7#SLQgM1hn z7z{u~6RS1Ml>ed{FF;8~G?R^yq5H&(vLFBd8(;G1^-)Q1>2=C@F)0ls>!XtJU)28v z1H*UMISgzJ45hW8xU2vFUo`jyG(mWDfA}xz3gUqR$)o$ne^GOg$=&BXx^KLw`1Ak2 zN3W<V#1bK}tIoejf{5xvME`sTdHeJWABd<UMD*GB|Nr@S<<8;o=q%mf(OJ90qciq^ zM=xuVH=_uHtMN%!;{zU@E-D@#y)G&Vp50d_=W~gv8=pMxqM`uG+5bfypM%1u)ce2a z{O1e|9?dB#1`Hm(y$=`}7$&dhlBw5v4hj)4-=kOb3@ampZ}$=7lP@lP135?ZvKJ$R zM>p>gFGhy{qTik|Fr+otE@CMv@#qd+;n8}jB-<m|ihsN7B9C65|12KX2aBRSdU==q z26?wcoaMzCF;Mu$N%-`t{PXF4;c0!R*wCZ<H>hN7wq_`i@ThOL2IaVB>whIY9^L0X z4*q0*F+&aH(8C-a&Br-Bt?v|F_3S?TqFIcA;l(1b!J!v+vND1Su=&pz82+EIWoBex zDChF%^}X<4^vE-ig}hUL{r|rU5&)~fBBI``;0P`NdyAJ9?4SA180<j4`{2pQ;A(uJ z`PBdaqC6nw-Mn`_K^0VpO2B_nA&^L~s5Zm^gKz);cl&_EH$7!wm~6+bz%9oL3ZtL@ zMO9x+&g3=>c*FwI>&@|B^aUu$yKi{39w<HI(R#at+mrd8NB8%a=NUk*6g|np$l$mG zR6BzTzGO~N^>)UiSM(waBSY%}pYG%QQx3kU_&WI&w<_0D7Dfi2?&B{!zfP9q2@e+d z@&CVLH%Rd&kZoYq9^D^6`RD4F|NqmP?UhP3)0(Z7Ad2>~Ff#B@IS4Xf8%WxvQ`w{W zFq22~aVC%EV@w{sqK{c7ALdczeF9QA6|6A#%jB;-4MO(nunatb4HW44k0-bD8Zt#N zPTs|<6}Q73<ONX849eABj~N)!ENvINGct5vDB<+!HJ#zk$ncumr`L3%J0pWf^D8Eg z-rfRc28J}pPLr@>tQBUA3;{2Mzx@B-ea@p-^c6FtFzCJk@`%Fc$xeL6T>F_J<-+4n zlk533C6+v5VCX*AdcdPsbR$T4@(+;OMV}@g;4|S`08%^U;ER+`lmGE)aLt2qjXq5_ z;5W;h22u|Sss|t~Z$5&`@fsC}?sLAapzOIEq<ZSX7neW&|G%3b97Vj`OrY}SuxIy` z7ZX^)IjP2{m-VeHD296z7#SFLf&Bg=K^_#LV1fUl#~)8V&o3{W#|ZX}Z}$<8Zm=5@ zKTc*8kYTESJXu~K$>lW@SlXlehXeoAW8LRoocr+qzfWh5iiJ;SiHd<wFE1lAD9R6e zbYJ%9KJU|6qoU!{nWCcb!V+Avo_`VeeezKOJ*k7rj0~lM9tRH!q<ug5|9>gd=ffTc zPYS#&RGQ2yXv)i`#lUc!L5zWc;l+M|$^L?>p(YxjlKBRx+z0?AP2LxWG(l=47#J8{ z?@x2F)GJkbu^uc0(&o`C3Q3|qDhe-bv=|sBOfWw1THdGoge%Bv;I<Q^>g1DxHhj*S z3=F$LdO9Uu{N|r5ETqCDs5#kED3o`X2FM1G)Qe*N$+Lx&lqYL4Fm&JW={^T4!n#9L zJV1FsO`CzC`-4aK_3qOz+_WY?5YkW%F=u2jzVu&o%RO-Li@(r^IRC$B&^-oFnSEV- zvbM0C{BKi;uUZe3N?W?9IFyLKc%u%g%MO%qzj&lRIYU^TsnvP%L}59_x7v&hC1TwT zCm0wQT3OetGcuHNyvT55VDRW<_ULAvr#AV5un1=dNSyOUp~d94!dbi@)!-gj#XC7g zq)<rOg@J*8JHJP7h>8OL_8Tv_T_!&liI=l8Wn?HV_ia5;QsvQlvQ+BDM^%JQp2;bq zlj~DWKv93PRN;lN7X!miIZ)iJbZ21L`5(l3?+o$?uY(CF_K$<SzVtRo<O3+KbSzn) zTQM?}@OgBfexc|E3X&4u*Q;OrQvq25il-N!;Y^S2W3Po?{PtvEcySLdXnbIDnV2Yl zq7);;VMv3on{`U`<XK{h^@Y)l3@<c%LE*sa>J4(^fl`&;01l7t)19&*AW3eBqy|)y zeTNh%&6I&_+|QDX3?7{#j2_L03_O|-a(MhdUBc<n&HCGmk>T|-P%QU~zLsQUaP9SA z_Uu04(<{2rgOS0r`+AFRy}<vk}`iCc@O2QV-+*hUyLGBA{|zW52Uuba2YYjTgc z1fK`U2J4$eb{@T~XJjUC64zpq2%3CPTvGDxO$LTD5Z`!o-)jCTQY+kiP~gS0z{vs< zk`k*yvS&br<xUAk1`q2~MW!CTthO?f9VK+M+5<qf%|Qc?|EeiB85lr%dHHu0N$@ux z6nL2hlI-;YNxI*hJYB+>>6Y~5I}*|ofl7#!&dJHZ@G_r~f#F4b$Yg#=eW`Q73=BTW z4_XhD+Q0ax$iT2$i-CcmQ{u%Z#mNzpwoIE9Cr_7jWjYW%`JSXDlcC~dNhxjF6G7m( z6!Pgl?$Lb>6uYNHKpEsU&x@A|lM|&jaI6QlC7X{}O#XOSWU{WbKJOcOP@IGF)Ka#| znbOWo4}vGJlWt<V6Fb>Rrci{JnSsHz`<PF6iAsiN_qFa5FRWuGZ<mo}S`s|@nv6Sp zeh>r03pKgPDzc?Qp92{fUaXRZ8<@;8dA00(-hVQ1k?qWr!{zjyv=|u}nt%K+(Q5wj zuSC@&`GQCHDUX9cS$%q0wH+B5njgt~WM7K#WEMH$(aX!J$jI<o(4&`^K@n6%Ui9f@ zWpkW-LQc;%2w^ZcGXq2Ox&N)-O0_^mfP*Z^+rHgrKq;m>L?r?wxHtw;E_{}qY%K4{ z#Go>{OkSSJ|I*~?@`{?EtS0)ROB(K6XC?-Q<`e&4Gj}`6K>IfyoxE37CZ`%Hn`{t) z)oBk{7#JM8e{_H9zS;cqe+lc0&@={y<`k6z22dlg#Q2iqjwzr_8RkEEkCC+G!Hb|a z>{1R;=b$%4#laKo%om$ZPyS$J!Blj5vX-%_mEuJP2IG^UCLsSsP_^Kr;_+Yf&jnEY zmI}1~FXaLCKG?fYzbHrr<?CLM8$689ytw&(@=Rly9HhR}PmgZi5@k@+>)r*B((@kO zH~x#B0<k+;qm@Bniri5GcLp87{j^=;EDQ%6dp#ImB>emT|G((E3k(ckF^}#Opy2TM zuR8ex1H<IP31Sik9^EfJx_N&oF)}!I-}LPM;nDr+zi9M@$-*Y7lefqV^Rr6AgLU8k z|NkdnlRsi=BmozD{qO((<`e&4MuD<G)1UwUo2xlM>A#kxIhljO_>yDy8JAus#uulP zC!bePVv4t!{8_=5sYiUWlVTtfYx3l&ibhNqlO~^3)MARYp8QoY%%V{YZn)K7u;H(z zUhMev|NjI~#$f;V|3Ao)r(f89{{J78Ut&}&z+J`3{FBASZnd7QNVn#lY{ke>9Pg3* z)1y~+u@&Rw9k*nellU1Y-?*i!$bAMBnl4`%JUV6AjSsvQdvR10WFx4P@#2;!1H)vw z+s6E_Eg2b#Gd+@Tdi3i4wq%@~a9f3WGauvR_S@=8QK!Ks{AKWH=3)L1HbNL-ga*in z3%8XtnM4^FniUvc+!BEq|Jt|pWQCzMuK~z#O^@V@9=*H{mW-37?<k7y5P_(k09XCO z^Y`SyJBA6@EEpM@AIp1W-;VI^HhH!m)U<7`G3H??HR<)|d~x52fnfrKFXhqeV=S<1 z0Y9j%#($cD;rk8gOUl3gyBPEA<N~GS&5jHVt^Z5-y}NmydGz{73j7ysI5qjv9Svqb z3&zR3ccqyePEFRjt1a&gQh1=0z5Ce9ZHx>I-KSqjf~+zA@6pTp+?;W8$z7lN1CAhz zt9cko6+L>rVb*>+2~O+WF1;CyE}c0l8n2oEJ43DSb6{X_ZGBss0#g59H2x$5!#8IR z#u6R~Kl~&E!)p(Z=5zl+itLX$b1-^z8vFFJ>X|b#cx%gi@Yu1qTW{BkMcsNH-(OF* zzo*Uo&Wv$#?mc<M7gnH(3p6g(dZ47(Bl)^dFY697Mh4GLmJ7|S6U`VWuf3PXl55Yv zFj@S*(qz$OW63qHpa#PKQi&IFf}jWjm!;xA{{NqRRjG`zcCwGM3}eFNOy!w8N&*ZF zKD};?9=*K&llfG%l;7|(Ff>~z@wfJX0`(q0sDOXj0AgPPmD9bv%(0WBRV;ZXK-86* zylCT}yg)@%CZ8W<lM<-j<bII^=76o0{`UX><cliF+8_8p3P56@@++(P!F%JkosJTY z%|94RIbW24`X7IpKY%jAvdQtPCVW3X{r~UMeH>iC2S!a^sOn>D4maY(hcA%)quYAB zgsb^CV+m{XZ>G|_FA`q;|3AT{`!J}kIsf9_zyJTcZ-7eL2d^e;sj1h8nShG8Zdr3# zP$Bb?zoi+}9&Wu|YV2VtD<sRvP*VCrItvuwtSaJ+3@@%{fTFyT^9382Q5x>iE&E#r z)P%TQ;td*4a03moolOVjnjaqB+@QfJ;}?5DeCy+7k{;dMY0Wm3wx#@#`j7bqfBNLh zYJn<itQi<47~k$b?9uv-f9iqO1Es<*-tZvm-X)*^|DWukuB-h&4HQ8MjJuc^Ktm&E zUUWVA|KFpN4b*57c`=a(6sF+jQ5(<X1?p<DTviMW-G^U`f`+OTARTGY$i#~@P$@I{ zfvn8r|LTeYEJ#-E`Skz)WCINyrW4$g<1|!!7IA~j1jW;f=uiLub02^0_RUeExy0&4 zh8f74r@Mc=D9Qk{Ufg^C|9|(17r~6+P-1O9|NphHN4K{IC>Xe2usoi8PQ%7j3Sl6q z3(|f3wc0mF35OE4=0pjG*B@TEJ%<*6rvG6D;OXa+?KMSZpkr;xKfBMrxB?n}0oBlv z9^I_g`izrhCd$_@{rdm^PEer%8jY9%Qel0#M6Ub%iyjcW`^10I;|D-aE9LqxI`sgk z0)EY8e7pPnivwRkouvDat~skCs0`{AJ*@{y6g;PVvu{T@9dnW7U}(Kv!qa{FMIINV z(q%F}fHZ#R(K&h7M2UJikfZ{`i*KBua03;!FB?G(@RJp(*0P>@j10xG9^Jn^x<7jy z{Kx9ks~V)o$k6;;-Xr^egl9L)7yf-d797nF8B5H&Proqx`v3m~kmxrT3l7E-?(Wks zj)Ri$kJo%Jroqi`KL5Y_^ovbjL6yYoVCffgIU(h1DO|-1y$}CEbr;CB0iY_xF(y9l zFnIh@05pDSu){YB)TL#8w(tM{5*FjzuPr>1Sw;7Q#y5B`?VDVoX;?pB3><Pw&9)^% zj0{XAtS`3eGBE6v0hI;b+OSsrM0Ey+7hhCiN<E=UyFf}o(*Q3N;7Zd#N?+zMFid#y zS{J0Dl53|l$h4JOphCTUKRDYt=rc0BIG@c>&*0I?`bLnE;l=4JsA3L~;#$yH{f=~~ z5Gc4`WN9%lfK$PX7wRDK687#BFG96IO&Zoo;*1PFovf3^K~XDOBF@Or&6@?v*)#8g z5?iN>ibCt{Qjmr>nhXpt{%bNYycX~N(OjdU;=oYK(S72@Lrn&TGcUetGB8Yl)X5&; zVd}%+R>_O*oXO|4WYpdYf?6~6`#{-(^@b3r$Kaw80cz^?hNvWfhreHB?wBm7tzSPw z5F)GK0~&Af>2?7%1w&L4j8DE0-@(A}TFIlkMWq8&EOoM`fK2Lza+?oucyzLU1ZnSP z^#aLsvhEfD`Kv_*G?wVm$+}07k>NP&BmqVSP8Nm($60#>7#SehgEf)?Vr^`OM>lII zlvD6uv}-Q|LnrGW0Y+#LehLJ&^8Slv?FF^*cvtTS#ZBm528L$aYXXc645eI<pgt7{ zl4#ir8g^%4IN$-wY<YVp%joPhZ_)wva^yUEc`J1o8D4D321g1Xc;LzdG<2J!!^qI> z%>rrCd3Im*WIq2Qk8LuKt_FL_9tMUN`D~l5b-5Xts$?g7=(+QYvVd|HxI{Yl>i_@E z^YmO91&;1!U~t?4n$Pj*zWic#;pETyhG9KmK~_-Ub)S9_cjy2A)&r$n9?gfj_;<Y* zdhO@YD_RLw0!m7ts>T|jM1X(Sd%@S*9=)P@U?uEOQzY(8t}?I}m|p<$1%K<!zyJUL zXLaPBe9|C9-q-+CjQ{VfQBknAjk926;O~6{(w6+)qnlMvW3r8*MhuHSSYyiukVLoW zSJ1dqx5%gN^DnO51r<WFkJUllMV8Os93+}SqlFi`&%dy~_y7NER*&u*uWSAve_8qe z|Nos4pwur6o>4jBk^JAIn{}1?<O7Cc4u`gbEGU)p=;mz)8_x6dMcNIp(d8hcn^k@@ zyjJn(X3d1i{_to%Xz*WDc{?bB$cCs-7Be!E<In>oU2v=0!K1rG1(wKtdU=ojWSCrM z;+}2~n&@afP|E4i%X<A60|RJo<A4CD)qNN=Tk}F5Nq#p>UIZ);>B4s3eDNDJ3j#G` zI$TYs#EVB#pn6WU{uje!9aF8z4+K~yhnXrdNo|;1Wf~Xn@fcjsyv+sql)q&<C@45? z{r~ULe89lN`bH^>@qyREFTULbizI+V%E8@*|Eydbj11qMC3rw7H`%9GbrvrpgGcfY z&t{uH45ivTK~t447ELxct73dUd6Sva<R!|&lXo}RusC`#Fiig4AjP5#Vn{Z6GEe)) zF!`&Qo3h~5|Nmdy`Sbt3tMMg|PS+hCt+z{cUY!2(|37p%s^#(Ih90rWCFUtiFOE#U zWv;+<?8xRn=Io4Ix}br&?$a;6=1u0cbYgnQG&#^xjOl0Y<V?#2OxLp~b6cHaN@kpV z-Kv=>FKcs*^<qY*#{ZN1+a;LpubnJyYsumAAC&3lt(_cWE6X7c=2Who+-R%F6qhx5 ziER$!hslC=GAzuXrk<glEYl{Z$pLoyOo{1}8|`G6w4El;w=-pl`Tqa^<QsNMOl(e* z|JbQAEkCna*<Oi}so7z(yF(l!lk|zn%N<RPVpf97V_(Q{Uy0^_QKyv*3^r`VQXbvB z=8T|O3>Osx$DN?5RM2RS%*x4pPDV_3K2COWQkOi=z{t=Wz~R$<{J*I73Q%+OK&fuC zZ9e<tCZ~AidR5T0(QS|3S^>viZ#GB%?T1}DV|jc!V_DKZulDG*<$E)k#W_({88rC> zo@FUu0j1B6-JUF<fvJH1q6d~wZgLJ_?3;Yq*@h`LbF!d|E|XdMWI-3<$-yoPOpNK1 zOI;Q*tvoVW($$pd)4Rz5u7;NT-!d?iIDtm2r9b@VE*10WWvv0t3w8Ub7<gEpC}Dk} zdJHr@z&h<M$nWhtz*&~H<L%^Ku5NNZ$Nv9sRyF*~z`)S_`(LT*aaN_j4B+DRzo^O5 z$#QOT@<0B-1elgGFucCf{QFO-h)1`Jio$W$JAW7^N4r@teSJ20s+$(m#5a=<y1D2F zFM%ZKXCSLULvG#Y|BI?Y1&@LS{bWGhbw*GxRClt8`%Y%>-wcyKxXbW`D1h=zNG^j< zudKoA$x<GNnI0dQeBYykX=cjgOiz{i=BEq{AO3Te3VL++f&AiWeFo&mL!cJqJdnVL z|IFXoK*NPh{H?zj7#O~>*1uw4VB~Lo%fP^}kCy>7B>m#61gPqBX6a<j|H;76?aa~1 zngwR?bh4&`7@!`>iTVHkcZR4aH2-3)74=9y#lPLfn_VEyv9raaVY0B7ul$1-Ah&RU z+`@b11p@=bEkOrCZjn9wVsgEgm`L>#kocVv(8$~iwS)ivzbJh<d8L=B=uLi5{uS8? zDtljW{`>#`IO}2l$)CL<nSQ*O?B_j)DeA@KH{PjC@gF7!`)GN1gBmj3-5Q`EW6uO7 zoNftFyTA2hiCD8GL#f~kO(YeS;Kpn>sB(KDh$POsfAUcurTT~aKuMz8gOPz@Kd2+* zp?&_vS%_Ew$WZO`FZMyW1|a)3LD&%>sa{qc&`gQ-i4v*iouE;5kkx;a!43i`c+m<{ z+*=*7j}08ttRF#hGM4TiN`ySR`N56oW_C-4Qq~u-`zGi5N-#O^o80az$E3V(@^W8C zCXJVqU-=p^sXd!4<7ddE{A#klpOHfT90rCnkoog&-d8U{BY*!(c>jxDpToe=%zNYI z<b{4pOu5@8ANA8`l6f%so1YVt#mmW7{#F84W-%~y^Zt9mzyKQKxi@=qi@&1zW$<j@ zh5w?vW`mr4y7fSbnDM0-AHbt8`#@sN-W>lsnP0QN__6!{e^BH4zv#T#lkfP4)X&%r z3OR2NkVjZwbU}C#5MB+0mjU7BL3jlaUIK(y0pSIKdEMZkZ#`MU`oa++umBQdv$udI zz(ILebNB!M`@w1U{0mtj&^%y(l%V@Pkh7uro9)GiU6XGG=x}E}XJ9Ci^5|t{d^TAy zP?>4UuE}PB+8pY$Ky4wx=aVx773AN8;-dS)f6;3*L0Pm!&iE3j#lQnfgQB-)PF@k{ z$`rqA^7}w{re{YdTLcx$ew_y@ouAJDmv$wR9=)QM=YecL@n7`RjL9d0RGBVMoBTe= zT)pimC}2*%cm+;*r(fKH(s`h1+3wSz27B~N$F#}5!437F*g%66H%lZudU>CNCV!3G zz|P_5KK)<x8c1MaAgHA#dI)51FYn|T3=A*o{)1aSph?Sa7Y2qGaiC1lE1M2hVw*98 zf#EfuM>n%a>wyxc{}()(4|8}}-!FRW(QMldvaUqlqnEb{WcE=JSFmmTuEqz9PdfGn zF#Q+JVw;>0;;7H}9#m4afXb!gtiRqt3O<(()%Wih7+P=hw_X9oPdD!iR#3}WYue-s zAz~bdz#N`wli!8d>71Dg3Y;4+Tz-Pe0QUcvJ-T@dzzQ}&WIVcgBf$JcQzu7+8b<q1 z2YHm&U^)ZCi|v0weHBq3h>$HvXvyFI|0lS%J}Kef32NTG5a0m~$vi1lJI?y@EyQ^c ziSOK?!O`<C4*vm7HlF`4dT;XNC!zIBvP&kXhPg7`yEb`En3}9u7HCA6k-w#sk%6Jt zkNE{FxF1r=+iW}O+T{0P5>Y$fFfcgo5n%?E!mKe%LB2Wb*nQ>2)eHas8=q`Fz~3su z2$Iu11X8#IG^3W*X}b3vs3U*%zv!t+3=EFFH7d_r50q;8^s>HM!oUDoY%^tYVz{{S zkwgFgp8?GgzXtWY{~z#Z{$W$*4idO!1~Qg){*uYF!(}59z(W%yqKMwUM`wwO!iyY` zexF{}kR>1suXuEyeX$nYZz^^40j&-Ki_C_INO|;%K3EKDQ41)5dK710RHaT9h!8gu z1sQ^FG6S+8#Im;s|NlP&T}knD;^f!}2c~5I$@3#5g<ebo1x$~M0}}%SXgK)ChRLTQ zbfiC}gM+t3d?%<4|Kc&k9kR`~1y?2uMk+~e{lLHgoyhU%zUk4;yW|5XcdeT^*(cJO zY378<6C>3HU;JZW@L*-&W?<+(+sV7{AH(F6k$N&KL88rvB0PG%zC&a^tWOjj?dC1{ z$1qtq%8EJqAH(E;C{a;)kiy;$kbaL&cIK;{qP+hYCRar{3m^XrnmswrVSTx#<275i z?DoG5lP^SR3C8t<vxBQg@_Ub7-Wh)xCUZyYGTrE(Y!$7{?EIHuazeDZ<jOvfk6(Cz zMk{<ldCUXcJ6hE@c|){5lVShlhtb9y1%E)^>Fb{?6JxJC^DP5|@mr7XkB-e}{)0x8 zOg4c^2=ENMM(h6)6;Q9qqMw1G+cxj*<c^q9sqb$X7|N7DjfIVU3=A&4^ItGCFt}LD z-hVS$JT_8y2e^^}>(}>a{a>PG$yx}}aqhpUHdx0zsE)`tljp`J=>Esl@#Hnwj&uJ- z=k<c@fay5%da_oWZ(=78BSUSfNAhQnZr0d8pzyN!z)%w4(arM#JYXd7!uizy|DZr% z`+vN%Mn$Fhw@8hlM>nehNO3pM2S`8UQx7P#c%>nNA7A`h1Ma$T|6!PXBQ8Q9WG5&j zf(2Z<k9VJVu`Fw{Lwr8x)g9pe0AKdx9r3Qh%-o=k7pQ{pNq+3n&3gG4!(@R3QSRj% zzynLHn}0D(Hb`*f&Hu%~;MFbisQdJb3mYcaB}6ev+?aeTL4ltQ)Clb5IpNXC|6i1| zYcgkIxc7wX3=G}hJ-W3$THlsPH&=5omWYBoujXAK_nv*>z6#XaP-gIGJ}ltz|6J)6 zk6zj2>mWJrAE26xyV;ttl<mJLd)MUEiRuD!ASvdP9^E`AJpQX*=$QN{QHe?W;bgWX zRi>lYChI0CGM&3PIUq^Xe0m2cjg^XnY8&U3|Np<3bP?3I0FCk)e|ydA*%|Yf;WgU} zjg?^E@xHhQN=Qr{lQ$&kFo|57d@o6lX-@lOzGN$L306>5^uJW}#i<J*Bfwqg=IxW? zlarYKGfh66JeBvz`Tzf+1HhK)lT%YP75dKq{|_Dk1}!>#(Qy9%|4xb5buY@#g9=>U z4{4LvrC4yAK@^o5ztEZdF-25L>^#VP=;$vem;<)#(ALQcsq>i_mrOpGn!_}?b+Ue% z_2ja&3c*Di|Nrmymheda@a<qzsrU=6$^X-&8Tlqlr#tDeuK<NCxMx?w_u}VrFb~|T z<L*B9;-ED+c))GM+=9uS>4r>ZNt5@atLUEjz`)S_P#!ez>XCgi!h@OT&}(*&Ufv}a z7#O}eawwFD8(-=^=hExM^nx{iGH-?k)9%F0<{7q(yjxCzoDX(!?#9WDndYK4c?=A% z**&@)1w1+#K?BIg*Zu!L`D~`H*R*wzL~R2S?F4iFmFR;wHS0i0^}I)~Y2Q20V#^yI z2Y<7^NLvRQ$G!m?WAx3w9pS?)bMG~~Pp@p$xydeB^SIJZ{{L_MztiG{?c_IEQp#O# z85sDRXRv|N(FdRIA3nXjo9q7n_dNKYwfUL6cX!Xv2a`3kWjL8n{s(Egb7Hbzc2?j7 z&>D+w@Jzb&i{uj^&w!H4iwZCkR2#m0z{<eT?dxHD2|Q=jp9QKxc<<DL^4bmW?v|eq z@<0P+F$NA`&ScIUW5x%QZF3YDA54zR5%U2_J2Kz$_<zW?H{pj%hl_!wW5Zv@Qa!Np zJVu5t9|J2#s}m)%t+z`gJGfxN5Dh;anQwvgSV25+AV-wxf8FHkIVwCCYySUtVSeP@ z-SXqXWcJ)ij1MNy%9Xd4t^-Fh*MHH8HDFenW$m4kM4w*PpVj~WgH`7-GJJC};P5Ds zYN(CiDv@{TQ1<Tb`SD=#ms~Bws0;=Mkg!iL>*DJF|4aBmLC!j(`u~5I4rP!3hkdMb zU+_2a{Qv*|wLI9g$^Loej7gJ^=P5HjnEX0VMjYf}kN<}|TnsIne=(N|b}>Utm&;dV zvP_@sn6GAdw2Fbjr5iLKF8W{eK^1t_#@i$R|2Loh|MC<g1B3P9?$`&Q8TqRJ|GmH- zoRL45@xf%X0tM~5YOuHX{)>L81hM#Ar!g=vSk~U*Z|P+K#SLpnCDfyn8w(U<K+frK zG34xWy$N<l9wP(DX%M&XEzni!OJ!i#1)2%->1DlE@&A9CW$29(vDZ8>u|pM;c?zW% zA52y+G)}IX_5XkK?|+W`E_b>QzmEJb`mzF48?%;5zu0^TlzPD9swcoq&}iCAN6>WT zkK9t0?)$H|cAt20_R#<TFLnO@2Tc)5y_kOpoER&>>cLtKS5Dqr=xFP82-GF$lz5>C zmwLI6fq}vJcI!$0j=2mB4A!=J&p;`DBFNL-&waYTdxD3_ZHu2xwl30=dVCO6{=C?8 z5acQ`(Ckup_xTrwYybbBTwf#~*aa2`TR9)BvibD??(;9^ul@hO`|xY27a;jgi5JNT zWil(^BjXXEfvyBlYuhp2G0rj8F(&@-WbtARKEZ?k|HIb%oLoNHw^&^Ef)xY9>(f5n zhm0@1PytOYw0<i&>S6u6nCHdC1Ctwz<tOu;HDpr$JlX!N=;Q^(`i!lU8yXTPPdqEC z#P|RIf6xC%o9+LX3N>46l?sCAg060~fAQtt|NpJu>Mu@~ZB(B8`m8e3u^p2I&Z$hc zDUnxpo&Nv-3xWNxVWtI;VW$84VBzp$$I{7lC7OP@CIA2Pw=M-YwokuMUJNRwMKumH zFgRKtFVO(4W>EG?KH$^K>r(Rnzi0Oe$L0s}poI;-*#{zgnOjbR64q-jpYB6Gy}XJg zlfRZ|NPvXCIaxH6=)CYi*vAO6Pi(VyX$B+L#Ur5d>GX@429x)exiWPfnaq1pYO-9p zER$r?WZUv%OpS*p^Ib~hu=8v_#_?i<&gQ&|G)AU94=3NhEF;b4(an4BAOizP&XIrL zACKg3pmDVSqK*ZVd8-^a<{t!AXg~8O$6b-&C<k+H=1;D>BExc6hk;@8yes8QKfX`q ztCnWb|MCC-WZh~hroG=MdsZ7V-HM%DQ?1Ri5j4QHx>}2|dGh_MD%M=z|NrkUQE>o` z*LAyY05!<?J-Sc4;OYklu1{y^hVB{_7tlz2Mt6uxg5z!mCQuIKeV8-Zv_^+%bI;_O zYf6(_Yqm*NYBDewe``HZqV3TgqEZ0bF5uwUb>>Cp<oxSeEOuZ2|KHqH%f_hiVhcQ) z7S8_v-@&4E#>;u%z{5v385kH2PhL<b6|!$WsABu^zf|DGVz7EpG6v0!2Dx;f2d(D6 z25vT5=P)pI|7ia4zm(&@=&~#ZhSyBS2U-u5aCV<~v3kq@|F6$@bf5O<J`8HX-<Zr- z?`Nd5<^TU?1%?+aa8qCQLuRCkt!=|^FfbHndvxFT>3;8d@Gq-RuW7=K$$j-wEH3l^ z|DU|3Ue0XZW{~Sau6eO}GuS9duG%yooU5c?%!P=)C`BmLn>DGyglUD+WV42%$v=t( z1Qh;&mrH{efpoL-t(lzC=&sz^_5c5ikWJul2gNxgQ9Ew}*$2wpFaFE`kDWegjAJru zne5V}%p};dIkU-!kt=xzB*|&3Oy1w@q9h9Des2BG-zWM1|9=+?G5!{T|NsB<Z{zdm z4V~~pRe7>%OAeE{;^fIK$C!?9n;hNR!E{!B^V8NQM#jC9Gul;|Zf^k(ty(67hgRop z0j0VhN#LQ?LNMoY5_o8Jhx}xtjuJ&D@bYHY9X`E2Dh{AkG%-Hi$GWeBmK!R(2n7{L zhIV3;?{=^=vHY0)tV4%so6O`!J5kOAa4LDx@O`pTrzO+cHIs8YRhYuRPoCVV%Jidg z^R7-aM#cl1KXxTCGKJPoUhXK%_hRC5cz}5IO>XG%<uyl$eCVBgt4Ep1yngcko^0+( zKA_s8RQ<)oWs^&LV<hvpGBA{aMovnlUZ^jF8}p!N@~hrOOjou{?(0(#4T}afPkyu> zD5>!1J`bK+esOQ|@jfLX`Dl=FB~~E+IT&AhvD$m`?>;k*`kMd$yN|xUHd$6gn$5tY zTUKM;<fwi-37)f{7S9ilPS$gqK~2pAC3`%&WiPFryrExJ;`|wKzaEs|Dtx*Rdvsp~ z<+_j4C%^5NlB!$_iOz-9pw*$OS!)>>d^**Sv!<S!tT@3~>_X@N|7Se9c||reFud@G zsNvW=IctIflU?-Wo(cLYnWsTkgPJ@gf<E0xJwTgXPP`D81sQwK1Jp5k95wm=1lh?o zlcbntRZX5TDUk8`<X4lVnY1G(vrkrLTC{hw&g4^!*_y{07(hd8cH2P)%6?wSz+n6z zlrW`1i+{E-FfiEImN5N44r-3OiGW5RVwf4bm|G5%KJRsB+y!b}c_g2B@%#ixJ18h- zu7?E00grCkr7Ia28mz&+qSG%pCMQl67heNX*vSqGmSRM(luhoRDk&2H8guVH{i2~9 zR5YkMtOOP7&FT!tS)GneR-7O)`OZ`^u}!Uzuz9wQf#HQAMCHwOlR2i<GhOwZ+&S$w z(+`iyY16yS^^QP%=DY<|DcH`~3hLj3Mj?z(dURhu#@e+FykEv56clE%il8#R)ArVy z$r>}lnN*KXZk%DjC%=Y)!SVlT;{z_8vixf%@1J496dE%5>x@uAz7S9vdeM5IBoH*R z;C*Cr^h_;{%fX=ZQ_2nM!_F@TRXAV3aj`fUWXG}B++g0+;K^%e>TtG~fI`!@p=7eu zEHxqMWPh)0JVZDGB&^T0e9C0+S+dR(rZ6zPE(0Y?ga4w;VAEn$4E~FL2m-aiZg?8s z{x2GX#J&&>TSR!lfG`xjks|>RH-yQd1ZhJilM|>6De20&-G}iUX(t5D(hobLPzC zAG0PgE%Kk-GkY4-F1N`lb6g}GW`f!_&D{TAh|NT_3eMF}ZkY3mDQWrSoVg*&GA;lA zcQS*DXvG(Iro+^4nhwf-pw-7OmQSDjc&;f^j{jt-dBI}h{-D_f*9V{hf>JAwWY9YD z?%k75&6Cy<^98pel|hyNy=njdcU!!i4W9Wp@n4k77aX?U5DhM14RYswKpMJlytp+D zl>U4l{1<%!DiUs&u6)rxZ8GzGRUVOs|NkL+Zta?EGCwh1{o()rovtT9?v;GOHtqla zMhnm~m=fP^?ic^N{{MgZ9<=6w+oL!13S^2lt+V#Z3&%6yF-7sT=GrS#r2-zwp(nbz zUrcrYH5~t!9O>o;4G~^?aq7Y5FY~z=g+XIfpfr94CUMeivfx5VrbnkH>nyZn_wM}v z|ApL?$vF!Zm<;Yu?pr9sBy@lBnuY4(tf0}Z)&u-4pTVwxnEJtV@~edpn1nnhpIM|M z+T#TpZTRuO)bzjT1`kjGyx2QwGVfwVmVGt<|4%krY|7+VF*$Rw3g7REh&bC^F?sgl zTxphVkX|CFhuF<>s3C=e<6k%bi>bB$|4&w4(ynlC0w~%*wcl%}){_-_*1RTL85oMy zJd#2CZ(O!cKD9)icRpOvi-_{c-<HTT-S3<%zEsX~cL^x3=^mH@YC));+yV(5Q&9JC zK?$hi_^(6*#F-3I*L~h28PZ8?DVcn5sqEzLrQF(4U}gVHz<PYa9H<@#R6T|uJsR5V zU?u-c3_-^JDu&ph0^+<a1|<o&9rubSi!9S)(lVXwvdn>L#lgvK%R>1LZ9usIG(K*8 z=7mej<X6j-1=devVAv1pN_cd0{}*+1oh-Xtj(=x61B3AakLHt%9+tc*%O`s+&tzgv zo4j>-1yj89Wc?MkOftQb^Hz8=U3HqgbA>9?t(3_RR(LQ?08ti`lUCkf+SM}IW>p2# z4Ts6wR{6->+VlUvhxP-H-WnAL&<NF<<Lqb7FfhCpe(@n?vfOH8CToYu!K+o7wm43% zTJ6S^<2d=yY8$3|yC<!YVfv6fS#FI9(=CU|A#3bRPC0-V(e`?OXtcb07hIP2CxBwX zA0bee@c)1JF^_Iv4iDqAFEZjL?^~xc`O_L9rY#AR+1Acr3TvFaV66qy7Td|U*1F5= z28}ssKk(=U?bU0&U9#~wGt_Mt6DQlQ(_%{9Jvnoov=xUfC`Xov`gHpyxO5-z=)UX- zs(3nWK`k~9WCyjy{Rgk;^ko3qUl22S-#R;{J#m}=t=q#~Ulj$4CvSllg%F0siwp=u z;YB=zq46RN!Z3K@3ubV?a0S!e4lisV438Ja5JtcYEeIpxg(8HJ@InH@$aujIVOYFi zgD?tS{Ee&!+g|bFOC*Q^o@jaT0>TC@LwRur!Uiodd2s>4o&lPGKLTNc=3!p!fUsA9 z#MeOBp!E(f7C_jbxyBb$AnXGmH60K(XzKAreGP<j0VGiXVc!6;Qy}aIAa(?V{Q|`H zfv`dQlwUYN*grtxCJ;7gO7?{YgbiBJ{6Yr822bz_K-i$^z!xkKc0FiI*^3_$VBdr1 z4BtT5;Q71<5Vi$qZtn_&4cepp;sk^ZnihPq2f_wT2fo+<VHbeZFM+TtK<pV1b_0mr z17UZ7*bNcj@b8`g;*>xnW`Nik5OxNL9Rp#n0I>rg><u8c3xo|?>+r$?!ae{J*MYE4 zfY=HU_5~1I1i}XGlzzbhVc%e^XJB~oCmig1(Du0(A0X@(APr9-><=LJ4G8-Oh<yga z26dEP9DuMnm>3vdY=N)^K<pI|wgiYh2f|hWu_r*-8X$H{`2YX)9^KsrAWj8D!UDw3 zfv`c71}_pIY!8rl2!tH~VtYW?5g@h=gq;9l8$j3@AhrsGT>xTBK-d)^HV=f|z{J21 z{(=F*=>SQ52?K}31Q7cLggpbqz5`(|0I@GX*egKnBM|lm5PJuNy#vHv6E?YPn`~fd zI|FFLM;lnio5RDJHya{S0ud4Lu;xvKh$KNoB0Q{lr$a;nAR-AK*1WwC5xcO-Kej2< z%RqRd5P1a;YhEFU2s1=P!^4`F10wP<6yzUo0}pH7e{Ep5+=qx*cv$m(fry-ih&Xsy z^S*+J?1qSVcv$m3fQYPwh-7$J^S-Nx2u+6w6?j<lK7oj|LPRP&ta)!iM2f*8;6la2 zn)fV3Fb*OJDqTFRc@IDYJt2aiV#dRocQZuL1SHse1iS?svWUo|^<>Fpu^s$;$+d{8 zT{>m5@eXY!t=i2AJ8GHg%fW4-4p4ytQqJ=K;%kN%+dxaFz&pZ0tCc)@c`yD4?H~v? z1U1H3*GvXADIojBJvw=pg1DW$%OKQp2(@A|0|Tg?=+VtP6(sUsRn8DJ*$!H3D*&1X zlL!ax6?U8)v)jJ@Z6&A~0q)c;OZfl)wS!Nusw_xXH?P=a28NfQ_0>MTs!|Xk;mHgP zuWNjIRhc0C-;)>^Ugx~{Fa;EOpiWLH2dFnv1X@+lJpokYdUT)iNoGy=W?-<4WGNB$ zXg(+a-gEST#e?~fhxKHsJ!%py;Hfv>+DQxy;HCAQHJ}~8d<K&v_Q>!t%>MuXOzZy= z4&#$Awk)6Av?q|S(~E(j`(me$ib6MQqu1nzdz2+2ycif>Uw(0O(*OUSoh&M?|4Z17 zPri^^Hd$tGx<%$h28P2PoxETg5<TGlP_LK7i_Qfgr=I}t?AQoeT-M2&1)2@-WR0FT zdG}s3h3sjN`3q(6ta+*)Xf@gck8WOWFh5jpvfw^7rj2ToE%zxg1umEzyHCo)6l7-W zff5^!ga4U5dS!lq2T0EAf@2UgoahPK*1aFhXZGj?ZB^X_=CCHu1<irp1Fimjv3ly{ z{rkM@U*&`5BaeXk?;eibFMPT``E<X0abyB$#L~l3_HsX{Vf2H)^(v?j*2}xt12jJ1 z3-Sqgpq;;EGAJ^7MXNkO3QznOT?n!Y)Nri=Nr2WvzSjYDLPR~lD$aRyvexy345<Jq ztOqGL4^bchSC9r)5CKvEl3x#zzu*qC0%U+6Sl$9A->(A-wHqFttgayEwjL-^^5_-q zged<nDgaZL4l<{cRidAP;kAHAH!FWXgAsTM04rNR$OKt-kap|iB}qQk_e)~I!D<82 z)6M%9Jem37zo?GRWUB+7yp15f_4yK$|DxBlCr>yaqMiX25&kc_RU6Xv1x?QUzu*B{ zde3Xw2lDf5?a8MPC^6Z4O@4pCkT0VIk#`lMC+i*bU=k{sTyfBw?`SbXrZ#Hw#e)@0 z_QjLE4=E}ws9|7ut=P>vqlST@lXnt`C;WoF7@o@xL{9EIq>&cp`~UyzERWVprR*<? zy#D`x9plmb>p{7*M>p^3Mh57?5Usa8_+4)JbRRdq<kNlnzbI%0vIjU?OY<#RlRFro zJ@&cNL4BSQZI9;P56bp}MgY1&J+r)`$uftfwE~MkN&Lot(Gm@CALM5ts2lkD>I(~) zL^MR=!Q{llW>OyuL2d=j%NQScZR^Ru{syRU;&@@HIC<k?EvAo4C*M76%5w@df~)<& zqnq_c)?~ROx|*?t|Nkpmyf6dn2A3!A!@)z?FAuVT;_kOk_hXM<)>%_0mmKk}7Z(O^ zX}NMA<Z%9$Q=m!rURKkopqWpW2aexd*f|>bTQ-AgsEi(PQtu5>iSg*}05!`zdRe)r zf(jH7uWp_Pp4~kB{8JA97wy*oHFNn}YMDSQJ4!emTE6kOfNIqLqB$B242m@>5uV+5 zJ6%*_TqipmRbpB-Wpc{Veezc7psx7?P>ui{$>P!NqY~iJoT8$@;L*!^cJgG$W0Fjp z)F#IqGiR!tJbCIdMW!&d$vck4G4aVwmN>4+^jdbZ^>GcRm6Il?9#@srQUNXBfBA-q zfuTD_#pmT~h|jVoO<sJwjp^~k$-F0(nD(no_CK+Qi4nrPt3288<T<8T<;jevw3#0C zPu4pnDSlK5<e3s~<`NYT7wdoZJ6?1A7mZMy9Cyl8>T4D#hCp4v7hKt(d54!feuC-< zPQ}S<Pss#2gSGOvZ2t5Ae|L?Fhw<&#OS(_Lc#-x0|H}%{B9?9!l>m=kUTIKf>Sj3z z4sC}LZpVgN1}Xj)qo4o(zo-UV0bWEuA#1YKX=$eK_LI#|I~o~efk#?jaDWwn+<-J_ z8{LO7Xq(ap9<=oc{r`XRiPLgsi!$ME-<}CJ3NmQBEfhLvyAUG!q7tFdC}2{9#AK5* zQcPBvlLO9(i+1)hFcjB%bl>;r{tn%)FsXNP%^9isvJm*r1PKnt67BBuFWv`(lK+YS zqQ4YCK?>Sq@k0(2NuW};^>&Hqi@O=1Kzy++1Lib{lP-mToh1BXE?nY8m_Im8W7)7E z5gHcmIQga-_oQ=tOve%@3!HOSc69(vj%2{bkr#l5>vUfHPY2lp<VfCfAinO`dR$ z-!E4dWrD;9)H4*-$N^1|97CNTkp+!c;h!Lpo&5G3>I4bGPDYTOVw;`MS2FS($OV<y zr(bm3{QrOQ{xZ?YcQ5EMRpw6Sy=czF!9CgS;xVRzoXLEb(wXL8-CTYtjge_}*W~+` z6`0OuO=i3z%w!-5o(k#90+pRFB*0T4X<*I?3D8ss)26GF=Uk~|dcFWW5hAw`IuWvF z0eB+hBpYZVglWNo$(yd~GA@|>;Ht9JPtfQ+mT8cm=96WwDKMQEoos*2nrV{h<eF=@ zq{1%!|Br2=!)@N=g6o=0((^XYzRtnOdo&gv;&m>QH{4L+UE%>6x%~0JRPaS-?Bs_x z<h5l)85lZUR4hQlO~U_0TZKW11w4Dv7yJMJ>yz-=i^GkR`Rc_cJKi)m5{Lz-;1@4q zK<0xp!z9QIMwzv(bt3~qaURMHhD+n*zIw6A2X3;kXn24!#7%jNM!4P=(_+BJfsW$o zKL270$cf#DU(39xgNVNfLn!5Uo-BV$k-rDLh4m(6eYkbYWdB=ElP&K%%T0+!R8Kxm z;AEWQ(H-jG(d+x*#q!Cs?i&lW_y7O@!Y&%*aM1qf7sk<(@837zVT}I&zc*f~Q{u&L z$H~$U3Yj8=Cigv%W|}N8dG!N1;qJcw|6e#o{r|rkw1}cp;>9nA$#)(kF#YJBZ1+%# z=}!0LsD}znhXg0rJdEcxjRctvPU!FKC%<?o!^kq3^^v?lL<XqD{p-j-<+z8nX;8*w zlSdk&A&sDH`U6_MarAm{zSvncx$u#Z-A&LowbpO2*+bTypfy<kOFTitb}lb=gGP-z zS&t+#FuW+=4605lD_<<z1Y(pFyfBQI{P2;ftyBYOjGxsXY|?>}!ycU)9^Iw^VD7h4 z1;~24ub>`oC#w}$^gzixh$8Lu$-$3}nA|r`ZhvgRbTn=9&c~WexAZ1IdF&z`k_H;8 z1`Vyh=mgo&dZ48Gb&*H6sdd_9=O=;j8W2JL7LR|RvCZ>7ohm1MI&)5N_;%`fbh4gI zWngfz%u%T*DfR3=^J3nH|Nr-a_Ro3r^00MZdvUK05+bb!N<u;MbsPTw2Ono~-lJE9 z?ZtP`$)BGnY2@>O5^5=5^XdOD-iLw$92A|PakXCE|NmWE|CexsG&fAPeJaa!%^JK` z@63zH$th2D7&lCw_;gl^>37iT3dlOJ0GD2OCeZSe7xJJ3aX_o0Y(2W~dT8J9XuZwf zcMv=hF9BMZxF579p*Nhv19T9@@&BUA+@PZ51!%*c;fqNjAcuh35HH$6r6}mcBFV`s zo~bIWegqo%`(MK2F#}>~o%HM5FMLBli+NZ}xnC%UOn(1NqCS@k)Mhy9(R~86X1|<^ zf#G#%Wh`i;Quo#Fb1$qw=g2hw_|M-G@*i|~$%~hEps+geU(|*RwCC1C`oG8b`yT(# zgN~poReiB57~~$%qT3he!PUWy|Du;T85la5K??X=Ky%-&#s@sXhTr}AU;aO6(3`*I z`#;dqftMf()O+IaNj~V&EBmp0^3vyLrRD{J3<W3eaLfPycYs*0xw=`Eawhk@&@eb+ z_Wyr(FnH<Ep{7#F7d~L+phBYATS8&S|NjgOFG0gK-wrvH@V?Lsn*8L2qmH^Rs9b`r zDUyWn;A@H=9snilQc$z?Meo<ifiI1iLZ44=eW{}Rx)d^6eDDV=%9^6Xp%`n5RK85U z_ELxG+Ox?lue6kY75)DYS%&?h{o4QkpghI36XcT@9oPQ<|HjH1H96pwXtuNI|NoE` zki8%c;I3)w$x_J|lLFv@;B5|a`-%VHtu#K}2R*uZJK{lyUx5TX{;M8l1NB1Bq;>kJ zaCkJovGC~TT@VTC&i?#Y%JX6;sQ=Q<+ZQ?c!Yg$qUyjK?UukREtor{SJn!ex>%r*J z{o%!Nbx=J206A07qc@BZJTrCT#T@6!ey?Sij+su*d2LYdp#<8tadH;}1A~JLXzSd6 z(O7nH=WAI6$i5>UkX>=04l-EaCn!BO|NK|N_FuG{6|6+#@PE}8tPBkQRbPQg6^P@{ zID|sZReR;p?Hlmooi?a**nC7G_Ao+*-J{#r;l&m0$pUXAn09GTc6=wy0onYWUNgDx zouraa4MNu$5P%!H6Le<a3!R$Dac?A<1ZzNA`8>LP4PNNOESlW#M$}^KYJ>p@y`UX* zFZNYqlLDvw#nqF~zLB);z^x(|NebjHgr9bT^RjRCWaYO?Oq$h`-QUV`D}g4!x<yXC zXw{mW|5j1+UKJLrJ-T`Of<Uc<70e6_6F_rVv4<z$f9omfQV2=0*(X8!OAkQiH@IG0 zwV3SqPA0@0n^`YHv$5C!3hWLGtP%k)@{uIA7tUt9&*=HU5EM`h4DX;cgAs(!2c<Qj zv=x*Ng3?(~x(!Otn4I`Qy#4`{_YF#OfR0XKU|^7d(mGJu21@%t=@=-T1*Myy^eiZ? z0V*087#PH$G#iwDV-9ic7l^ug1_sbpaRvqk9w@B>rEQ?JAC%65(j8EG4wT*irB6ZW zdr<lvl>P^$g-jt9t3hc$FkR2UkN{>dFyuk$7AQRlN-u!YYoPQtD18V@UxCt(p!5eQ z{R>KSnL#X8fYLfp+73k5GcYg&ffx)73~^Ap07`d2=?PGJ0hC??rT0PU8&LWal;(g2 zu^g1PfYKgNIu1%#m@_hjgAVF!g9=Q8(o3N97ASoTO5cLgCeXM9=>_34kho;n2BmKp zGfsZUq$;~W6@1PpgGeHTPPhc2&n#zfV4SEZ%**i`BG915-~iGhuL?UU71WIIWnf@< zpv1`VKnxOqAA%V{QvwVVHb;KGEXAK(l$uzQnV+YSmYA87nlfFPkI}V0H!(XiFI}Oy zBqcLXAu}%{wJ5VBF)1e%s)zw0pI=&nO##S13=Bx>Qj3c4s0(GtV@PC3V#r}gWl&%! znSP&-(NiutKd+=HKSv=WF)t-2wMd~jwWI{(Du_e3tMN0|F$+ws(cXLaguCm^Z@jzz z-H$SuzD0<!B;}4X18A_HVUYp@!%+nW28Z7e2c1%2V7Q0G7nEXQkTMc05KRy<0O<jR z&`CuGhR=!&3{g-$jFMaok|n$hk|{h4k|Ep-k|taXl0~8irq>8FDljqBOrIyr=oJ9d zeL{zU;h_!#LkUbb3nK$d5(9&v3@d|-lf(gtT?`B`^&Pql3~qV|7cz1&F>o2N8BAXz z$|%9cP{Y9RfOYyi5k@H?n2wLe3=F@G85sWmp8iUPQ4cPzWyZkZZN|XR_j|gQETfzf zNIfY2J<S;y3d|W8Rzh9$!Hj`nq6GuP$=}oWNifP!&lF))mj@{ZdEV28fg!>MWH=<i z7}=N@*n*g*pBHA7tOqFqnHX!!!0^SEf#C_%L?$~125~zCUyz@Lf!~Ckf!~O`0Hg<G zaI!rE1L)L`|4==Gf@}<eCR_}HM!W~O3%C+s>Q*~2Fr0T_V0aJOxX8f3z{$nJz-7Y8 zz!k(M4mWIvBLhRY69a?f9}qp=Nt7`N9t_t!7#O~JGBB9`nSM!>(WstLgo8mOg@ZvP zgq=aegpEPONT5JcpOZnZWGjPQ$`%GWlg$irj2jpP0vH%T!Ck=0z#s^=lpPcia68vU zGcd5mFfauDK?<27CId-%4h8`e0S190o(o(DI11Pk*aAT2fKCh+l;oOzS(s529CDyg z5J_NQIFNuaL=Y6bMojRuSD(VbFg1mNAs1>1#35{Ohk!!gEtP>GAeDik1F9x9m4N}& z0bBv)gQLudDL_z|g+bVaok7@$-xTZ%kmfgO3=ER#2+i8*3=B!>3=DA1LM#kICcF$n zlehz>hln$(D8M4-b`}G}%WMXQ!>HC6OrIdmC<Dp{>%<wY>IM1P82D2-8Td^&82Ez_ z(Z8yMfkCbm6f2O>69i`}9tO!2Xod<B{UCfn@Bqj*kUP`L7#LQSF)%!b+NN8^z;L*X zfk7OaEEq*O7(`1r7(`Rp8AMIk7(|T(4+x5KXrc>V02v4h`Nb6s3=b<97>u9>Ourz> zC?UXz=G^HYBp5^VVR|-nFfcsoU|`_*2XQo`1Q&xu3KxS!2q%Mt2?v9Ok;nz10|L|Q zB^gEiV4CJmV_-Nx4OtThgG34kgG2~BgM<kiNK=8N0XKuZ$ub6c#yJcEANU?1r5tb? zyudPjl_aD3bU`Ub6-{tj<NzlDPEcXugeW}1H!v`CZD3#s_zR+^mq{_I!Slh~9SjTy zb}%p${hhu}icty_L#Lz|<v{zN8K!@bVpIW%h)FY=foMNzMmI5-5B8pCU^sXlvIXtn z`RS{qkqV#Ciwq2pFETLf{yY7eG^3mgOwX}P3=BP&85nLtgI7|HgMoh%_XExg><3s2 zSQ3~6m<&L<!h->{4G)w?*ctdu*uX`^bPX9s84i%Ff;0oe^ae>r5i6LvGaoQ8oPK}^ zO<cuB_Cp4S^$$VC#`IY-j7lIs?UO-r_s+Kr3~%3p%$c4g%c#!}j(2VbeiJSR{vz&z z=`&;*J>(>Hm>8rOJHb(4z{0=);d3&AoMyl=T}zJ9ZMudCql}8AF*k!!Nh+gKN(!Tr zNiw4nV;mzmDL~7R2V4vc(+lJn70f|eC$KXxFhXNa0d&$aBsDRt0N3-33<qE>P|&IX zV@8GrOpFs1MMoQ`plr*)Fxo(+Mguhzl;)`3K%L&H$e5{L%MzSg;sI`?dFG|%7v+N6 zlMD=;tl^27C2sje!I^pKIjR0hS*gh-t`*bGl^A=ce^O->;_qQ{Pb~>a%`FH>EXfFG zn0{D^(bRVe$hhE=6o`oo48IuNQ%l@3b5cVp3sM=ZL9)*IdByoTsm>)uIS^Gv4AEfm z(xRf&yb_npqSWM){G!TmhUtpRj9aJwQD&Sl{g4Wyg3vjZkkq2w%)G>s)PSP=<kaHg z=^qps#iq|vVbqZC0oml7pPQSQm*SI|m+Hu%$`VwP6Pj0^nU~^PvHhV6BQxW67B$8! z#_4tHj7{4MEEtzC3ON))8q}a524RQ7?Lr!ibwXYRKOyaM%IWF1tQh6$JCY$5QA*cC z!IL0}c|A~b3D8^&a0SyFtr^?v74#SxN(2}fo(V882<R~~ybxeu@E2rY*rCJ75Fp6F zFj1I+!9kCaVTv#VL#+q{gMl6+LxTtd!$}bahC6zU3}-|b7<fe)7#cJf8AL=G7?MO8 z7*?n-GNgzyFldM~FqG&qf@yy#28IcGj0^!%3=A<c3=A=Pj3Bz6;f6c|!xlY8F#Sj# zVkm<G1B1K*14Do^BZGnh1H)eh28Ix2Mg|5&28Lioh-D>;3=FJF3=9*L85uZ0qeMy! z3=Jxb44@ICP7qszk)cP4fk9UpqTWE6fx%6Mfnkd>BZG$u1H%IqkX`kRV8%36h>sVj zGB7l#K{SBq<!T^Bj0`K(7#O(KA>ush3=FnV_6c<chRvYUnv@wCwrDaifDUu|0&<WR z1A`W5@K%M9K}U;$Az6okfddpOIt&clx(o~oDvS&~x(p1O^|}lU0U$-X3=C0v3=9z} zj0`b)3=D_#Aig=G$H4GP58{X~dJGKq1`G@xDvS&c1`G_<29ThxF<@X=YXDKR!GM85 z-jIP|j}{|?f*}Kgogu`02SWyi|Ar7X3`PtL+l(PmQ@_KQfkD88fnkdZBbeT6!ocuH zjgjGi2?IlxDFed|6-I^}QwD|yrVz~_y48$<;e`q#!v-@3h8-3R3=*o0VEU3J14D!= zBf}L-1_niI28IGvMg|pY1_mc<h$CFA85q7<L(KnS&A?D(!%)xAp~}cmV#C0oZwrY6 z16u|LBRd9$9jc5BCUy)A^X(wPzQB%wLCPNDV;Oq}h9-Lkh99bo3@!Ey3=R$uaS+Yy z$iN_@#>l|p$iPtT#K7R9#>i0P#K6!8YIEr^GE8t{V7TSXz>uNF$Z*HGo`K<}D+5CT zh~vt@u+xKqp+}98VUGs`gRmC^!wNM<h8Qmfh8i!3??Ln&C>umS@`5;y!JC0W#hZcQ zf*K=(fj0w#hc^Sm4K+rF0B;6{KyL<yJ8Fy!3Em70iQWth57ZbLQoI=$Onn#_p46)` zGFbR9Fy#9%Fnm#CWGL`qU;wSUmeFEl-~sjeBN!M;KqtjUFffEgKpYVf!NBk-0^;K@ z5ey6sk&qw-(FM^A3<Bzm3?N!7hJnFAosmH&hJj&E3<E=mIwP1ijAvkoQD<Z@iDzJ_ z7fNJcs8DAF4NNfDBtk66Nn&7lnhc4K7s(6^_9+lwI;1c#Y)xTcSfS3ya3qC+;bjU$ z{hJg9hJ~pN3@6kX8J46nFleMf90#I((ja<4bbUGl1B(VDLqj?P10!g=qy}R>14{-2 z!_5o^1`7>FhC3My45FD34HB6Q40=$uM<xS9H<aCz$-uBblYzlSgOTAtCIiFIOo(NF zG8q_FXF=F&vKSaZo0tML7#T`(7#L>dK+HUm!@!`L&%n^3!N{PI&%ltKUk~v?Nj?L^ z@_dM*75NMdRYeR8Ycv=cYKj;beibn=oX}uo_*2BdP+tsTHxx54u$DmB93>146G|8u zKv4#wtx6df9%wK!*pxCbY%PU^;*L@V29`32`5^j383O}{CL_b2dXQi_1A~VqBSS+u z0|R>nBrX*y7#P?p85m+T85uY#85n#jAwC1qMpck(W>Uq#P*cso(4ol)re{?{ve}$! z28RFD5X(SqSJ@hfClzWK7;0-67#3(UGHj?}VE9+Vz)-(IlaYa;mVu$Sj)7r^CL_aw zItGTWdIp9Inv4uR^$ZO68X!J+(7?dJ+`+(bMU#<%rGtS%zLSCBjV2?5LMH>m@=l1F z6`c$W?>ZqCf9PajaO`4WNYG+raOq-TxY-2>p*vj+3>{M$7#wsN8753+sAo`{2GOiB zje&uEIs=1=79#`4bOr|d=@5e)rZX^1oDMN)%5(;XcZ(o7;=>{a28ksM3^TMC!StFX z5MQ2H!obkGl!0N579+!ir3?&5mq9}4#4-j3-{p|d4Oq^=(7qgGemx^Y$8rXSlglBR z&n#zPcmidE=q)QD8bI`uRghv8L~mXLDL%KXVPIIbmVx1d79+!&wG0dk)<G&55Pf4E zB+5Xvz<LN9L?2$y!0<qeks)9M1H;7n4Gau#v=|wtY+zup*}=fTqs<7W`F1iesAw}X z2<&8FaM}rp*Mgl44Ci-39C`u7-p#<^q0Pu}VK)N<+a8Do3VRqBrtW26NYQ3wSg@CY z;ptvTzJIZofkA&Cgzd18f#JnI28IT0MuvJ2W79zfh8Ar`hAjsf7`zTKFs#vLWbiq} zz_98t1H&F|Mus(q85p#VFfcsPW@K<U!oW~+oPps7=;Zg~3=B!985sU(Gcu%{W?;B* z8d7P2=v!wX;&;w4FxZ|21vMi>z*z<chI0%I96F2)0_PYQuAgJ5XAsa~WcYB7fnn)+ z1_lWoMurvV85mBVXJC-gVPrUSo`C^$#RI6JA#;I&!S50SgN+U&L&7BnhQ*g4hAz3p zz_9Kz14E7uBg2Nv3=GFFLqh1pWd?=|R~Z=Q=rDrm&}$I&5!V<P)UQL>8rSO?7&5Ly zG=OO98<50kbAy555R`r71_Oi20|tf@I*eeN`5^<t8y!XlmWK=sw;wVvNa!*$+<C~r zu=))oRj&aZz48_k9WHMf7}Vb}Fr?@*GHASGV5oivvAE_P1B1f{28Idsx{P2($OlLq zgXmu$ASw3G2L^`iUl<q`=rS_w_`<+o{FQ-Whb|+7$5#f12j3VNPUtd%>2=>37@p`d zGHm$Hz;ORN#4``RGce@;WMFus%g9jklYwE+Plz~({t9LP_{qRf9|$^xOOKHu<QD_O z$zPDd;mj`v2KL_!3><ol3>?217_@#vG=oN9K_jYv)EU7etDx~w5F14I{bpd;pvuSq zqF4TAU;v4O=p#_}$={H%MUeQD-;lw{4XTXw44}b8&=?>{0z{ktfoKNNpm92oIEV%f zr-9fY8Z>MMVuR?#Q1zhEFVMIaNE}3iMx8)x5Y7J=VkT(h2{d>F5(m)%e|;empuv|S zs3H)(`!B>dAR06r0@47YK_i+VHi+i<2hj_n6(Q`&51CHZgGXl=SQtQu%os2*H1IJn zFjO!wGzc&-Fic=zXaH@`TEW230P1FdFho5&Xb%Cy0R{%p`f!FD3=9n*{T~<@8bI<K zj0_E|3=9kkj0_E+gS#vk85%&RMFudUo5MK0-h+|VFauM9A&r57p#h6HsE<Bl`dkl2 zaTd@L|LF@n7)4k>i~1p~3ycg55Ef{yK7<8YoeyDwhUg(I&<cDA3$*4Q%wjTNnjYuL zC{_<zR3EU2k>Lds1H%)LhZq<bES54dfc8GX_zBAx8CGy0<T=(eGGwqK_yt=S8CIww z_!74m8CD1&_y=AwGGwqI_!{pS88R5ad~r}XGfa5T$iTr2769{SeA@oYlhMz&o`czh zfq@~6A($baA&kM5A&4QE!IQzC!H*%H!IQy{!HvNmtYI(9`+uMzHP8vCpjd^`_F!4i z6>luyScG!HR2maVM=(PPLlHwJLmopqgBwF8c#g!AA&()AA)kSvp1}#M$bi9u!GOV% z!GOVpAqjN95`!0mC<7ydGebT@E<*uBB10ZSC4(PBB10}iD%kK~hD@*wWXi>dA(5e! zA&()MA%h{6p@>0&A(WvQ%mOKnV~}QGgj?>ykjhZZkPLQIeE~xWLncE$Lmo&S10h3Q z87df38Il=F8A{;uJs^!n44g<7gn=zCMl#osL5~514Zt)g#2FY27&sUh>lr{nQ3BQg znnKD!@?!~u8G{Lf9z!bFQU-=B24x0D1|No0hIEERh8%F%6fjhR{gKX)!BE1$fJID! zL4(1WL6boNtLN%*1(^lNbqxMc!$GkJvJw`5Ag4ki0^N}g3<3;{3;_&94EYQx45bXo z3?)cjVnBC9JzBgmFqnaZ64e0o00jjl2qOol3ut7PA&eoBp$Hz+ps)oeGX@3*74R*D zAq+*}v{cNH!;r{O!oY`!drp=OEZaS%GiERfgOV+%sJgM}!J-$7J}lx`EU;a87UO$n zOBbt{fB>JEL=)Yd{PfJ?lFaOw)V#8o;N+srf|BBxg36MN{5-wXic~IMt^jXl7SQF2 W3=D2_Bc_+mWBkMnVr0!{bN~P)(KJN> delta 28157 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 DUxhe& diff --git a/env/Scripts/pip3.9.exe b/env/Scripts/pip3.9.exe deleted file mode 100644 index 6bf27412711b6f0f31603935323f7e96bd3683ed..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 106410 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 W1(gBNJ3bg07#S=X7#Kc-RRRDGix>(3 diff --git a/env/Scripts/pip3.exe b/env/Scripts/pip3.exe index 6bf27412711b6f0f31603935323f7e96bd3683ed..8c12433cae8225bc3f158cab721375b9a87b84dc 100644 GIT binary patch delta 29315 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 W3=D2_Bc_+mWBkMnVr0!{bN~P)(KJN> delta 28157 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 DUxhe& diff --git a/env/Scripts/python.exe b/env/Scripts/python.exe index 7885ec4fa9f470f967a2445c36924fecd95b9ca8..71092d0867a15def9214a0470984023b72167726 100644 GIT binary patch delta 123815 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 literal 543464 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%0De6loq^yzm~gt= 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 diff --git a/env/Scripts/pythonw.exe b/env/Scripts/pythonw.exe index 5ffbf4dbc0de6fef7706f73f84e6702c5e62a547..4710dd54c335f620716f1c3b2cf5c281cba59992 100644 GIT binary patch delta 115053 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Ðv^55XrQzXYu<lL9TF7Jczl z8J=zDDKRj-T*=J906N>{nQ!Zpl7}A6znJ)&rh-;!cFs}p0CmEriyUMMj0A1j^|k(6 zR_fhrqUYIt*Q5KNr}g)8Ezq?Oy9zq*#ZBE_IvIS@>Uq!ZBmYI!nHU*B1DO8zJ(>S` zTK_M*=?j{UyzXgzzeL4T`+gei{<-Pv4l>CnO#$V01&`*JjNp+*{*E>#P{EON#=xh0 z&lv?K28NeDppC{CUwiVezvtC!qV0)f>ow2rvtV0iFoJBY)A#K@=hJ=6$NF7~3hbJ@ z>GFq|WKH0jJiD*MH2FX@89*H9YyG}N)wlbsul9L<c~EJ>Fx~JllY|ArKJZzp=fL*; zX8_x04AJUo{k=rPr~90*_Ia4^7$CZ*?>NN7Q?KpGe9y!BUa>O5EbyUhr@>~;f|zyt zwI;v31A`~?Jx}ZV<+50n=0lZwbieo1{^w!+uMAxsBof@g>gsQJSpP1v@SU!5n8`Q{ zG>Pb8{k2$Qf~WR759@bj@@Q5-LJ~3@UUK`js;BllPwTfBHb9htuC;4DP;z_v?88i^ zob$j(1H698JpJZjCMB+7F!%4v8-J#=9$_*Qx{v`r1qhT@9pfBh9b*np?>fRHtq0m@ z59%xWc7N~y_1_+X`XExEPLC)k;i|tlCl61v?Q+vkA7PRTZM|K>XM72CiJ0g2Z$8#1 z%CtS2|NSo!^65TieCfsCYS0-4J>ZiRKnLruL{?fp8&q$uJix-hP{P{nt?-(4C+J#i z&+dQI9gi}})q_qz>2?+YUGZB#0ivwTC%IYxbYM;{e}^yVI6v$6F8oe^eXalUw@ZN< zciqCit^Z5Rd|NM-$ar?20%bKW*Y4vlbh`fke=X(Pebo5Ui-79?|6g2}gL`FyEGUVG zs3^E-RttD)zxQFZ?(R{UP!H;uXup5C2sA%^(8KygQMQNmE0^xSF8uDlT2Gd68DDbj zKK}iqi}o+a?&F@;NBP@9XZ?T%t30|-gPSg$%r6*>LA5}LibD4ZkUMh0RRDj>GSE#e z9iYPqKvseK|DeUt$v-@`-}`F62OXPGfBMCQRM5F&|4VXwTi=%0`*efOnEQX$^Z!}L z{h)bF#}1}$Z-q|C>7TyL*L}c8WVgQMZw0j%eYzpx?%93tr533D2#Ob8aJ+!7aP_JB z|Nq5hSx_i|%E6bQyB)xdC=czwptU8(`8~gX10VMV66JXPayrj(CRd^BmH+?0hy!Z_ z6~!;aWu_+|XHwQ)^#N4RcE+eEfHEGay>cD2=z$x2?EVi>t7r=NMBL-Aw@sgTf<;2s zqnqnRGFVgh`4>{4Fa{qU7V`mAGf%$vSa$mB6HGh?1|Hp<9?j4Gd2|O0yjbxGJhsaL z8i!JG1_dl=;WEdE#zYbMA0R1biRsEGnN&1Dw}pd}tV3@gBWP$N)E3;a>HhH|Tn2Q> z?Eg~k|Ew9e7^ml-WD=7pQ1Ixq@aU}Icr6KuJ%$gB9wH5l3=EwG(-)p(lCOu24(vpX z4jgA_wyn4WZa`j#4-g!4{SRqC8lM8yyzjw%-TOYBzWFYlpq@IY=k8k%av5ke;P^4u z@9+*J%4oo6P}mxud=ViD9u25}o#WX2gQbMm6@2q;^ACp-j@SDgn}0Zz@_6<-{`0W? z`~QD^`C7;jfG<C2NWiDp7c@Lj@6qWi?$PP0?$ZkzCU6Dyef2$hL&c#(2j(8VzU3ah zuAm_W`xkFPw;TLusC^Iaf%+bYHV+b!M+T0+U^oeC3Me$x{s%W#e|z-$9)I!r1V|8d zxZup0Gsj(2K+P`DRR;nuH%l>qZdC`>n4k^`xVfj$Y-@a*ar*tcOrnxAjx#dwZ)b^U ze!u~0)<N5cFM3U<-#^17&U8X%y4xcr6Xrun4AU>1W0Ic!=P{FRJwL=yuz`qSO;^x; z9XEWsZ~3;KEHwm$xFM)85P8ueiD-M+NH8$CbYBMB<=A})G%92PSy&J1v0d?Py<Ku1 zq#tz3n&9gjpyn`yxzj`YrbqWh-|oYn)2p5`iRZ5NY<|I5`s%eY|8^E(kM8ejolG9R zLEvV`1dvn-n@96|#!^s;>H)enoZsabs6EV*=F%zT+j@Y%6?El?XY<ehrTl4bogtC` zTzdloUV_f}NOS2Fe6ddg+86>~+%?&NQ%v|%_s<u8rl13dPJ%WGv>qstpC0&(Nt8#y zqxpb<r}cr-&yaf|L@hvlyeB^04jiEJ{I+NF57tsHpH2@B$6kj&ug`jdj&TR~+7E#y z=sh}%Ihre2IQUzSOyBv8X;r=Ft^(uB2LAGMx_5%sLwa@}_%G`Jje()FTHv)5$QaLE z1;y6`JlhT)>-Jy)OB;Lx9gUaG@sbJLM>x~XI`1kY!{IZXywkw6M>p%&L!fTFXx~-P z<-i`s7eGf>UIvxd{8JAc_UPm-1u69CW<6_nh>-!b^`cue8LSqh(D;G}SZyh@@qxph zy9x?JBA&5#-0%bqcpmcjue$Lo1H&1gZq|v17^lB_#U#Zda+Q%`@`m}Mf&~hW;Xd6l zDh9^iJiBjtb{bFT`@kfwv>#Li`gC7RbFs866?APm>BztRxFi1*&|W#F*YckKnWwva zU{X*79R#FM!Uj4HsB{}BG`Z3oI}84Sj`u$0(Dl!8-}JT*Om<=5RVLlXUbBH(rT-7O z@Nef#bG1HK@*&OD`h2OmW6PmZ8HbktCA?`amX%DPJ97^*z2<Ug`R~$w&4GW)@ry5B z3;jO<GM^*OwbKA}fgQ*RQXiS*g)fx|KqMSH8DJ7VADJW=nWv|IWKv`=QPFUWKYV7o z{bwd;o_(f}a_`2A10vJ=J~QdL`-2X9a{S-?gRxBPMY0I2+a@c_z|j5sr6H&e?Ug-$ ziIKr^2k2&ZkM7H$13L3QfC^jF`Ii_OJUV3yE-_B;{>r3doC$7N)H*;;R`uu(^#E-n z`VOjWz(?zqO1!uw%)qdl2ecyTWT(W7H^S3jePxpO6#ol4#^xVmsaUtG!~YW=ow8pq zGBR|s-oFSsD)V)wM{lTwM`x`CsNT4q#K6$~q4hwCq(`@}#fu5x8_!RJWM8xhPe1pC zNm-#AtPLdO(J9(@k&)qrFOn)p;pu{3nPif|gZsw+JuGdfUS?z{VKF}N+Uv!qJdn>o z2NRa^7@vIcUkK8#GX&Xe1{yVNJy6OD>g4lzbh4&i2Kk>g>@vueFD`@bNAEuU;xuSs zALO{g=?S5X64MQSGVw6K?LIr*{TGuGqt5iKUre&~zTk!c*dowif|n5JI^@@tKHa|^ z`M0xy`X|XA&FB7m{6CiFXsJ_H`VGWt{$X2U3O?l%REu$ejR23Xs)6rQxCT0<cFCLn z|BXS1n7Mg&+Iu!1=Xmi>kb%Ls*QD(AQjjk|M_L)56nt@0kb&WKoAJpP7X(3GK0JN> zOC~wq92Eud2=t3I0S1QYb-$Su#Ogruz4aU(-QYg^8;|bOFR}!u7yM?@tGB`;rv?%O z<ta$f3GGjT>TPS@X%`t8N?2bcgZd23M?hEZfzBa?$Q424x>4jTKuaIM$EbSr@;ZQ` za{Yf$%c7Up`XVEP#fyDlUN^5DNQxJvwVPM#B52U>h{a1sP;v7z8+=6R8INw(o993$ z^YThvWSp+Z#Oz-0VSTE^8eCC;(}D-2uiwoKDj)?scNKWt3Y%v4vGu>`^LL;wIr!qw z()-}*0pT}LKO9-R^{En7(12R&ff5nVT?Ga~aqjA@m;Z|{eh2CWmvVzf&OEH|zrJZ~ zdjQ!ea6q)4EERvz20F(OawMcZ9|OY<Q04!cyPI{@4Mv6uos7nyOM5g9Pj_HpmR4-M z!N_2I;I-%r8-%8>yiiS`yGf=uurf>5=U)PqnkQVkFL@sP$=3Y9-f<rT0}F#!x5#;) zUX}w+{M&pES-5q@9J1`b+4vaLy>e{)#o)leP~rz-G%zrfSUdJMF);l9zw-b8fB#D) zU9GQ`x-^_@aO&_mWZ~7#a^C5f%K=Nq*9I73Os{3c8Xnez6}}ciNb{VZuEEA^HT@4e zvs6MK2WXtKS2hn6cfF?WyFocC26V#<Ycfd4`bLSQhox}|AEamY;$1nYN?`^C=Id+S z{4W-Pj->BKA0+{=0BUEgJ;ylxA3w9YSTrbsK++v#FuD8Yi{l#8-G!LddE-FGO+rFl zoM(Eq5VMRg$6-c>|DZE5!Q%>N&YbCHy?2(8VZvchTs8k>EE9bpgwS=G8&XzqwDayb z%gE4u5ET4}L5JF}J<G^&7<5Ligoq70$e-QkUj&1jxZT_@>e#27XfbQZGQebxgSKz| z=;nUm1Ugv<T95>0vB=wbbTb;i_38fU(G5C2jlTtSuAfi0sO%0#2FLDGp5323jE$Nf z+WU5&^0<7?$JmR*v-_5Zag>1P<&z$lPfzF5VYYO1Edx~nKHVQ)d<Wge)cUPd!=tyF z#Swg-A?Wb$?sG2`;c6~J)bO`}mbv?Mi`H*voZg|sY|ONsar#~zW?c~dMu%B}X&d8o zK3!%R5Ur!jtUi597K_;Q#)B;4(--J6b6A4hTMD{d>E%su=Y}<V8_3NkKu7u-TY>8E z%jZF3<;GDQ9+yvh^t%7|X#Vk+zkTKOhq}yC_3<9v%%0ZAO5S^drd5nRz$aS6bEoo4 z1_qyQR+ep`CIp)!_}pt>P~9)!*?qvrn9IZ1i31!2Cw#5Xm$G_TA1ztt+x^oM6p$}G zx^KLm;Q>0{ogZ`%H!~O5tQ}jyW_fgT_;fOQOfS%5)(ZyRdeX}qcZ!kWWiA7_L2<{k z6SR%;jfLlN=MSJ$ay@&UIY8Sc!J9`qT~q=<rw04>dQ15BI=}Gj4OZ~%^%i)s{12!E z18w@4F0aol#w@&*ak_;*v!BT?&`@gg5r<gNJ<Yrz?{u=NodJzFfridOiO!>!xAi0= z!wb-*CLX=K6HhWu-=)tiU4Q-if7s=EpfM>Bh9q#0ZrSiHAitb`aU8rX=Jbo~5>R=6 z`bBgplm_3xa{5L0RHzx?3&GA9pL}^W>HmNDjS#%?7a2k4DSzNU$Ovj8%6oM4`hc=# zuPkr<4n_tK>(eDXFZ4nAuv6CLBFNRCLNXehSv<OVEl)Etybu6Mck`N_29?mNs;3zl z7+(AVuLI-NJO&n%1dF|Zh{;04c#nb9T>*(Tt8#!i&@s3(Adh<Viq`x7W?=B><#qeT z!0>Wo5$M{8<~JHGCriXUnr$~61>K{|`r_$5sQ)w$d-RG*Lv)Dz0+sAXG+y!-gZm<& zKz`A!1PU1k2~a%%I)@vc($t<YFuZ1Xk<0)(&m0;u#<x9M<xZCHfVvaxzO4sJr8^{F zaIqtL6^B@-=NL1~x;+7pH@*RlXx{9Qd~tyd+J=991hn%<<3)Qhs4IG)gli|Lz<+U~ zn1SIN>(R}O3``|jJH^3wLr!?iF#WYLvkYG;69dCe(1ms{E>Hgde|lyR^CG2##~2wv zYbqdDA42a@tk4A2IwgYtSudSnoUR+ptZGvQ3e;Yn6CVFn_df!A8j@7HWhb0qgj}K+ zevFX;`4UC*hYSq=c?(Z4PVWn5mZ(=lm{1HcA=RUsMHRF(+N0Yep}TPp0|Uds7aS^# zpmd8O=h5w`(Cxr+@P$0&aC-&g+n^oaFF;54w;U+t0!>dCypYrY-I=Unz{o%KFzj{_ z@DdyFN~SQ#!Yhw%Lu1fA@1WBLt^bR1J!Amyp?0vS7AWQN=&a^A<}APn+C^Q>0V>ye zeN+ry{8WVPqyFI0$^2h*=|fOVgGQsfk4@J%WRkG~O)CEK=>BLCB~U8yUv%CB@MwK! zJO^lB_J7g1hYSoLGov^>dRgv4>Tmcui0PBVnHB2~tcMQvwmx8CU~ugI(fz6WCTNu} z>x;j^|Nk3b0{OAPaR+F0=!JFyM8sFXaR=xa?iW%Cpw${KDg~e!7Z1<{@gBXd0w7Mn ze^K8Dpwek82e?@tqT=A$ea;nhF}v*pNYXL$Xik}K9Ko#5%=Lg_dTIo-S-s)|P<h|| z<G<+j`=C7HqvG*j^vHcsswfp`{a?z{{QG|id-v%V9KoOwlU|UUK|2^Ky+O;5=cs&O z1uegb*6{2u1~09Qi;o2#IDhddXv`bb_<<hhUjUv+YqoVh3?2l5&Z5;LPow?Y02&2> z&iI4oz(L;9@aT3m05KF^c!ACuMW60Qof=Et@E@`?0eNc74=ktx8m|O3T|AnP6o4HW zqrx#=as?CjbcJIqtlr%(9lLLW#<Md(wNCe^7jl39{|9ApcaQD{&;~&e+uCzifmXPQ zhy0#vAf*YQ<_2hD6@2H$Sr^br{Ief0Oi$d%ELIP?jUvONmv_?<Mur!<;J%N9M>lKm zT1EyR;~U^=$n)}P(5L}F!c@=h!>^};cF!lcbc1j9fK0qz^XNYNLJ?H0cr?GUfDQhD zwg-b&ioK`@^`SsD26zjm2Dmt2{V&RRk72r16tj%lvp@g;{}*Ms3rfu=c8RkvfZK>3 z|5Xp(WnegCe88udxBd&m^czvk4$$jAyKlZQmj$PqQcjOv*4b+rLFu~rfJ*o2PKg&2 zK<DG$cp(Z>(aT%47IfOcff5#vUJr#%Nl38{E&e>ZZyj^8VC?iVc>!u&bvo-Db2b27 z`~a>+z{Tl#@EF?xusz0WGhr5in@3;;>yZ@j!yE#+6dN?~Vg{b~_vt<e8i(W+I|-VP znQ<4Kg2n!es@(zQ&=>bXv#~c`toi@{f2Rb*h0`CzFw40|eFD$Ss)D*Lb=e?Ypq?Y| z_7k8M@nPdj|3z&;!Pa`9<jQN_7a{-u|3A(E?x2E#5bTL=R;|^H+f7TDFEc^|&!d}l z^8rw;ddtI-sYI;15wtL)l~sN-BSR_2iwkMcw&@YDc3435verZNcy+TJK+*Sn6IkC2 z?E1P{<w50bH^{C?gk_r{nkIzcu<Z3wumdqHtA^-{K+`u}K!;JfKA^ir1$54`tMTpD z11=p>j@`d~yD##4{_yC&<<tGK*PYuZ`Gl|a!E$4d?jDsBpoKZT(Mq7XA<zmY@S>L( z6$Rr<pyTR0BXx{VzK{k@tsZ{K2%5U;X59H7REZyaVd9~D(8Ky5e`_PCPu<-DHp;iV z{uHPn@bK(D*WIE5ItRMbMa7}JMFn&SF=)4sM|X<~Xm_|vM~sR=XN?NvD*G2lAeRMm z9Ajp9Ig^QjVOJ{H)YC754}eoRe@i1114CDj3TWL@!$-yg4_O-y26S*7b6{q8na0Gx zutOI#xNj*}U&{(w$9}l01+3JkH<{6d(Q*HO(1u9<Z7&>mfT}ph?zbKw2Qe@(e5gP8 zl+|<Re=y)@Xg<pB*~(Tb;nKnE+0Evue9+_j4PWX1j*ZX%fwrhKA7eK3>@87YZ2e!# z>ezJ{bQQuJu+LpAqBTk-J-X{pzqoZAwEO8c!cf;<X9LKx!Vd8I`)<ZA2FDH-72j4q z{x;AqRY(5q7d&?{fB`=P|MpX@|Lb(X_8$T{;qr?#N9F@*ptG!))0mHTu>C*p@&6e3 zAe`nye=5(v_H^m)0SC4VfBp7@p55m>yDz=C!44Wqyxnr3#K)u8?|+wIuhXs-_e(jB zF&cRMKl%E-r}dc<zJ_0xrOXaYSN|RA5PZ%2&+&ij|2kP0&|v?$?)%`KQVw0$U(5{q z|KEf8v#as#*Q{VcR|^>xPkxs#jt8EyIyM{)aOu$V>Gfms>}Ip{IQYUu6_iH0Pk3sd z_vpS@$p*SWS^I=X>m~4RQs3@_y#Y-89)~*I7#%w-JsN+$U}j*bF`3TQ#;jn?BJSA1 z=#hCy0yOK+3`(e=!L*+#HO3x0xUVlRu;seG*yH<459W&=2Y<17bRY6K_`=?U`9d#? z`1I5^W)l^V0Suo14|rrB`sTrW!hz|$V+V(8M+76N2#rw*@a&E@n7&YnNvs}nqzQ*- zXSRT6XR(B5XSD)&=}iDAje=?+&+ZT1YalaSpm7CGM{sA<v(x#4Z>RSO-(K$*y`hXR z4(5Ss^ex~_=hEv6y3qu*0K=fUM#VwbrTYRj!FzOH0}Vfd4vjEA3ED)Pq|o}7fBr!a z?Ten;7eP~O9{euXJef~=FrNqCLi%EF2DqqWJ;u)P+SH{BGAZQI>!RWSGT*|b`{*$j z6$1uv{pO;g;n97*y9Io9IH*2)A<e+RFnyjBt29=BLT<Kbeq&&Kz%%)UYwH2mu9rR_ zPyXchKiYhN(_@B*^@Va@P!R!IVG5qM_w4k3;A(u*vpM+&sFjLbL`?kp|372}NC0SA zW&~*5J;9?Jbm3*Q8ti(l!wq}Di-{OOvK1v-#+RDybor+o@?gI1+InDmUI(*8eRI<P z|IK!~9^Lm#*^ja7di2IKw!W=1>~d!G>D~g4iVkLv|A!qL>Oc#5LGw``4}&hna+C1r zhG#C04sOuxdY~xu>1Dn12Gl?J$mqd**Ms?{hxTvKS=P<}L3gy;d-A(nf3f&IsCwaV z?PFj7-DKs><l6Ff`u7gzG`Sj;0;W=t21|odevjTjMn_N+gW*L(;{X4~2VTybKCzQo zq@Lv~Xwl4>Gia#^G@gW%kbXd255CHolRx|bC>6OH9{?q!?rWf=1lnKZ@ZwQ6X#T=Q z#l_Y5BvJwb&EbMtz};)W5e!O5phVM|qvB@Z!h8&rs6ZWHP_k0+?B$X4;CHzWNkq?5 zp^1nY)Gq*SI0B2ibRRqBqN2b6HuUrhiRlO0nI)#n&SqktenWs+xL%>5MkN8Xrphzf zlf}3Dqht4r5^2y`Xx0Zxg^dq5He2fQPdVVhd^qj63*&zS29Q80+c9QckN<}~lO0(= z%N|<~)O(ildUiW<G*}pvf-a6>GCBY@w}h+ZKna^iZ!zO*c@PP@%k}>Orv@8lhSG1K zyju^N!a4WiMg0H&$CwQ~y6?Sa_F%pN+C2<PjaaonbZm<UO;6XTWH>@LO@T(QoeqLh zh&x&eaqM<uX+2PB{rv{mNu?~-M{Ak7Uw9<n_4t2Wx535^yfw+45tO}pd5mAgf=xaQ zKH(fRbXyw$YHY`-I2a$8p126TIH{KK?JQPsL`wxPK*OZnzq+9p5ul_3L>gG12}%Ps zpfqp*ng&k53z4g!d;qH79r>pm@YKElDhj~2Dc3vxKkou+=Xx~%{qNZ;W8nh5R?>st z<tjMNLCvQX$>8L`ag3eeWix2}%0<QH|B2=we`@TkA-7Q0nz~s3sO9MbWwVw8rQbW8 z|G`WGn*y>>1AIs2c~A;se6jZL|NpP8T!Olg3MiNkkM64=^%kIg1THEDkf~ARQflij zNGK+Nij53ViBaIwT>@Sg7vMO#;DN++hj&bz(|P-tEtu1*8K!&mF&}`f04z}v0Ee${ z_YKhLZQVaX{c>=t1{6NMQDWdm4YVDD(H_@-4=S==<}-m7>D(@r1{L}sec)A0pf-%g zF$V+2&Ip~?M?mW(9{6-aE|&0Z^*B&+89Ec+{L`_7x7TrZ^ADynRtKYRubCaTF@icV zpq}Bk!yNpr&%o^%aY#i4sTe(MLDeIF>*?w1`<X-PeXMU3vpF7PVtAeI*?i)E%cT-w z$74*op8pSl1bwY<lrVe#KkdN3?V3lgY{XLrhUQO<%$K?kc`zUJ>E=1?`Tu}(gAF4? z={Ms8zScMRryX$VWnuE{zU;$%(6jrLUpLF)7uQ}uN;uF}G@u*Ax(~e60(C&UFE>1{ zSMWIailzAxWAiDdZ?~myE6)M9&zfI4^0%A=ZAE{{0=Z)Ww3P;Yl8<onODX;q(8BHJ zmn<d4%|97SY+<42(S05ib|5aO%<7C$ap(+DvGDA^1l~FYDyV!w)st`c;TN^P|Nnov z7_=w@q#P9Xp55T{xIoFJy9Ip7ODCw6=%S(l*ChG#|NqxTFb$+w_y6mE@C{s$<}qAn zJ=`MPF4YCEQixGW0M%Teo5=&>4`U>#hPRN406ZH3-VB=t&X3Rqy$;5=J-c7{fVQE0 z1SM2a(43!u2l&z_70|*2$(NwJe?VJ*nVUKPdvrr8OOM9Cp#3{#T>C&nN-sf&Zdt@@ zl=69WpMSx>`~QCz(18sV9^LK|-5xxRKVSZ3U???p<llY~bXQ#l=)j837|=b*=U!NX z#@k!Jl`wU(HUD7Y?_1Bnz+e$?P+!8_9k0_3YRX#9umCNRjs`6~Vn}nbK2c@{TE8ab z(fYQ8*9WxH22|l{dHw&tLyLidq0?RGn7aWZXaohEeG5FAk2ru=34?TTfOJ*5c7QI| zC~-f|23p?o+8)$=$pE<slu9f>Zmh2W1(*TkPH|BEWPAx!WGK8S_5c@Ef|fBV8KwQ8 zaAE3XGd}Qo!hg{PCqb)ds`y(=|Ns9FvJB0M9iIRH?*mN$cb4mb)_a2b8Q?iFkb6PP z;bT-3UOa#G|9|(fmn?Sw|No!fIF(Uidc!+rmU_@6a`y`lP&|PO6#f>_aZ$dYD@Q=f zkz6c{N`*W?yBvf;7w5Qi8omTwPUmV-2-*wSefmW%=svdYU<sG*ARfoYU*Pyq_vz(b z3K~*^ET%aMs#3bozpyJ~U}!%1zx4pW$HAA!K!fU*n=I-<F(Bdrx{G@WXhqRBwzN+6 zm!NZw__y(SbTg&7Sekg$Cc1QcaX2>rWUSM6w0>Em=GcAAqxHW}_px1|^N9GT9&qeF z1<GrnWzq^Sy4*k^St{%S+S-)t!Qo;3vWVZsqKpxA?x3?ow*$v(Z%~)N`NaR@j?Oxu zxP5I6y1fQ`6AZ*)$L>@7Q$dHwXgKx;f|p+_yf6lvTXGcKEPl=D(`kBe9V5f^d>t0K z`sO#FwXmh4FOpt^y5pe4`$GEF|No!`-7MXX5);5<2WLFGd1a@A=D$3ePcnK~@)oRP zWZ<6yS}zczA^^IC4RpO=^Bd5?KVPRYLXNrwbts)gJiA{Ue8J<<{fmG5N6<oD$z~^k zfBYR{;Bt+rKCRQhqnU~6B`DHBc?C4w?$c{pITN&c-qvUxBLnE91yhhzAZS0)kAEeg z7W4}j(EL*J4Ug{g9tVH3y)XsIJ+Sxa6*=H>@DZ~ov&enW(tvASPL}^p*f8?9fmUyV z4B-JO{PDlU7{vMiuO7Tvr9=(H1Kmmlx)cy<<l}$;|2IFd_vtk`;Cb*FvoEvBedF7X z7I7A}!7lvU&w)w~1(#lDR`Br-pn*n%7ahMr<#(x$WsHhJosUm%iHeCM|2{sS?xUbZ z$Z?=j`p5qg-v5U^{~xoCQ8B1_SpQmW$N&Ef46l`%-39(t@<Wt%pL=nuf`Q>RuSYjK zIDpuh__rSejgo<nJjpWxRmO9`&1{e6BLU#8RNy@(%~=AB{2iA-B}g|@2ZzUhCjM=p z4IPkSXOHfiJ3%+&ylCC?|G$UzjS|hBpk&POq71?Z-Ar^EvJ&aU3$;p6V&tEC;5D1k zf!9pnX#mI|3#c4`EFkjezWHL&f6%T({ua<+0XQAL(14o8>CtN&vWAi2wHU-!0jPMT zN3X5R8b*fyta{5$85!V95la(4G<u7G4})yBXDAf`uStBN{Sq|E?$OEq;wgCFI=@Hj z$?0CxnH3qmr{_#(R#80Da<aq%JZ{zPB;wJ1>);DcP&!la?7jeMNu}+ZzGgbJ;`FH} zSj1&I9)aeAy4gWHL%JJ5ZPX9{8M?V&9C`Hr|8xs2W)%q!hzfqt02t?sWlRhVpvz+0 z9!+m3W7bgMfXKRYfaV3e`8~RYKnvpHpsMU3s+bNuoc^hdSw&H4I%uxuL<!pqm*@Zg zgUq=D+8~ISu%FId#q1+5x(YM{>-wNGP{X5_*Zc-(WYP78M<<6zFYnB0jMK}im|bGk z{(%OGeJ}X*g6?Duz2ed9EAaw!xjHBTfOaOF0gc~Dfx`h5Eqvhi%;^_ypiSA}NmU2v z=&^$b=<e1|-xrYUT}3;tGfWq*Vb-qy2D<pU+xLY>w`akNmk3V8i#rHT!i)0=PR5Hv z2#&{#tq4xQixmh?#f#Z+PA90h_o5rY2VIc)qWbCo|3*H&z6wz9X@I?V4K&c(>-)f` z*Y$@-Z|D=Spe1N189Z}$=FIf&I%YYS*Wl&;{h)S?hc&P73Py$!agSbBl}V7$=WebP zU?^pMal{)md^aDgto3#Y2Pko<fW$!YG2Kv(MYLYwzo_^@28M3lixU|cjK6i?0L>-H zzHkRmrGZy}aCtQU`0v5*^6zy~H}C3+pn0@Y|6k~FfbvQyt4H_0*HODpFf%YfazYU+ z$gmcWvTl&}QqaL-j2xh8f)`0o{{Me{4pc6DU<d0K>aORF0@-`%#eLAwUHAFdw?V}c z*I!TucwzkH|9{Y!xcfoSK-+)NeizWLB+w8Ld~@gvwY#9U4J5aB^YTn&WB~a<`b8Vq zK+qDH5)P0LN-AFGcJscO0Cj&p*aao^$w+Po9p~50dkUlkvZ4s&c6WBL+gE_jMl<v1 zzWl-rtg}?8n|HwkMh4?cFI2%cod!Am^oxK$V5e7tFTaM~J^!Nl4#<t*IVPl2R{o35 z-(L?3tw@kL@Ss1>2FeYfuq#0cdSj5gnos?Iv5gHJco;$d3v`AtFAqo=BIrBWz|Md5 z2p04e5ZyxEypQ@B8MKWry+{XJ2o3s4zrpU`{Rk5D=l6pg0}1u%f`%-jknPjmywm#` z!CT}$K|-4cYzElTkkGCKg?3RtG_=36f}C8Ef)v<xVAlqKR3Kb?mKE$;J&<e7K?!9K zSR*K~)j$?rdZDx$Jkbnw?X_QE*Zv2UF`4&3snCP@{^a~1u^3P#-^*M2`~UwJ0jvxR zovhdT!1Zb=ixFr+O9*JnqxC>3r}4=bpz-+EFTtffXw49KzO<Wn8A$!l|0O&xBv=_3 znt7-8F)~1B!6z3!keseJgPDg}Z!g1i+ZoKJ0<-KG7_4m*RxmQ~``bpYV4U7GgIQT{ z^FFY*wLH3y`t-7@E@7O$Z3c50^P0ts)AeUEYcO_CkC@4<Z6dk{6v!_;dOa9DKnp)~ zJ-Sc)7u~-XtXYA7+X0WxockKhKbT6{8+`6tIJ`D&{xN;`OlE23YjYW=-<-)T!(#aV z|NqH>BGS>2jIa}QXyuC|H~;@PzHNN+#d8~wQKdXDp8fs*|HZ|B|Nn1hgeduX^Z)-Y zXflPQPf)*A!T7dEuWjuj&=^0DHK>&3dJ$|hJ%1K+uyfx<P=ya_k(_?934HWGiHt`# z@9X8@84vKz&HtjgARo0JD7pBW_eJYHP%8@*$l$d_3ekrrE8dr{cj^A=(`%~4_5VL; zK*qQGA-D_j%D;QczkoSR3=@31WqG?88GMZ|J9eLLerWG``IL|Kb^aF6eRrT0_Z*(x zhhBm%!t=F0!ruZKq3$ka@a&%RZNY3Nh6$kc|9l?S_xW3YF)%Q^YzK|NcW?Q&;Q}bf zdUl_4tlt6J!~I`0X*VeBLB#}rD`)`!zo^D8Pzyf1)U`KagJ<_Smu}F6KJys{h8Oz| zgT1Z;5lXlZn!7yrVg*E04BU$M>^}Ejln-uZX@W=hai3mO8_xg#J=<HrZu4k9%HnCQ z@rJ+E_djSvNLHg0v|8oxPVmjx5A3y1cw9d3Y5d!}eGe!krrRxHRxtPIKJ3$LdWQqa znAQWJHuCBJqGh{44!P<9Dk_V1fr`olC4D~KtlK&mr+-|`EL#r>&)1!hlmR+~y_fgM zJqCuIpsQ$odRe#J1I^ruZoJ39@InTXElLzTcNHACXmU&Zz+TYyp5q69f!dy+I@RO9 zYW!{nh8?O*;8{S0=))fWRb6+17DfD54TaLSD0Dq&9v87#+OhkCPcJX`JqCvETRy$4 zzd-Y2-9J5gMIW4EVA#nI+9*8@RN=KAD3S8qRdDN)QGnfoCYSDGpkcK0|3x3}Vqkd9 z4dvME1VtaXe1caA;KmxLtqPvcmk6J}U<EUO*i5iJFMWDh+d-^e(T=+e3_Aru)`6yK zeZVDtNxbK-f=A&2N%9LHdvs3$4>!1Up9YOJgN9AO^R$q$7SK_B4&B$Le^|jRFL@T! zWmNF&KKx%)5#%}}P*dvc3tNWix+|I0m{@mCKL{GbjNQP@SAX>m$i+83dPPs)VPM!P z4C-9<vTnb_!0^HeG_lZnphVnrSAo%u5M{Qzuez^;qjkbg28P$*>ibX@NIS^G;LW+9 z^^cu3pfhk;L)t*=4{fI|Vr1AU&%nU&*<&?m(28RN<6-C|Vav%<eNB&E*~1G#8JioF zuLV3n<u}`Z(f!*&L($3%pfztEy{sOK7^k1##w=P79>+3hPEk={0I$e?k$>g?{|UR9 zL7nUv6%}h)`5BB1C3zmnzdgEHrDuQ)=J^3y0nY^9t~lY~3(yv1Nsn&cf1sveH_y)( zjhjI|kpCqt|G~S0S)W2Aet>pH{}*lF3i2TD1&Cn%&lj6-f|~xU2S5VNDnA(hAAa2i zaf;=Y|NpzeX2c-&E<%!dx1)$h_sxTljglIWt(u^t`(!=3Jvm+^-2DIlLu0bY{(qq1 zau3k?@14w@&H|8`-7{y>I(<|)JeuD`?5GFzRMM<Z@V8tAwJyQSJf^P!W!n%H3&-6I zpcAedt9ZbDX)VxrM}lLob3>Z-iQ)+UZ3lgNS*0E_FgSj5abRLBVddX;^0g}ewu`UJ z__v3sB&0c7UoKYX-*(8Sm-X`lxH19$ZKpiDn?Q$W@o%#e;dt%IzwOd%7tiKhpdk>3 z5-ZQ{E)WYeUQuw|MMVQNd;uD+NPrAffYYL5_vIG`nGDklcQ9*DpLBvnc>3EN%<L>7 zW(*9|6NFer>Jw%&GBiH|^&T&IcC#G#=5oP;u|)ZWp(QBvPy84CuobigzV$$<?0-?4 zEes6ZH(so~4x0Ubap*dzJO_2=n@|7m=6`Vubdm@17TYt>(6jJJzS#WhUn%d4ez=y` zIjtuvBCJLEAI@WBC=T%GKIPNPdUY1#^srsbj`e>*8@z>IsKJ%LxPKMgFNYsu+<gSp z^9FB#bPV_C%~<Kt_y%;0rN?ns&`R+C9-R>!9^I@5nxGwWS8>no4?dl)`+br>f%f@A z&dXTt*?r8n`<>^(zid98xyL<vdE1%(|8K4bb$x9Pcy+hDoG_h<!K>TlhlWR|>vPxc zhrY}Yd^%I-{})}pg@K{db-VF@pYG7*juurKr97V9r(Q%X2BnG6<(}PM65XCWoxZz` z4|ssm6o-#x>VE#_e$a-??sK5^u|A!?@4K&ev30oich*jZoK5P}E6c|8zy5zCc$AF4 zwHmZa^SV#>cduTazjh1^4BpH=r$KIVu&^xQ`+vyu|1ppM2R)nrvDUoxZT-gI2dW6Y zyIWp^)PUC8{;+f7-?v0kp_z%n@&6IW?jzcVI$hU$bcfFO(7xuAe89*05PyFK_=NZK zUcDj^JL;LIfGz1_>Tu!x4>}?3{~=H7b2aaMTMyJpdGz}J_hdc?x@Pr^1H`vJy|RIf zpxk-gySoQ$w+Hhnr;eJRb{-&|*J@sPbk?5t=ye61DRRC0xMTAl7XB#*{vUAZe&Eu5 z0KA3Fr`PwqM{nqL&`BbbUj)a4ilHC>`CAe|2XeZu|9`?G`Gg1a$CseHbNRQi`SI^t zBLVhSuP>udx9fZ#?PDIv2R*G1@b}*U4X||9uJ`CHz2AMj`6tY-4@h>c_vj71@6qc! z`NfMkm{ngvoBNo*y4H6;^Xbk#{&FG%1A{*_FrB-6e%O9H$Wo%{+~xAauEUib6muL6 z4}Uv%`24ViZbs-0Wq<AI!oQ8rv)f4mbP%MIrHyB;p-*oaqmOmzeE#MFM$pFGQ&8pI z*T61_ehw}O`CCds4(R??|61C&`-n&PHP9MckQ1$83PM3X`+p2HW@Z5*3_$rFbj-L1 z=v)@isI_bN8J}L)$;OwueYd~h*9T40d;pCMN`rKE)~G1>^!iSB=|14m8_Ms~o%-Cf z`^<mQ{*9n^A%Dv|&~(c+?fTID%)uO;!7MJ8rPKMF9)cH4^>dZl?cfEUj_2ABvKwMj zufrFQ-q3!qF`iIkK;z`iwbL2-n?O4b|2uR1cV_7hX7K=rz+_NG*B!dtr`z{^x9{$k zjNm%{Qk{yY_BUwisb}zHKIhcMV&>H0^3(4BaZoBxKJH<CsOCOnFw5&uP%>2a=)UgL z?R(t28<HVBm``=F7(q37{6FN8eB9IeK+OXeMrW4S%I+OLKkVT7qQU2fElaNxW2ZCA zYmWb-#_JgvI+;B{lf%B^pjBzYS<;}yJVymo_IflP0TnFM7s|4TNkNW}4BHVP!ocui z$y5dg5A6pY-K;@%jMHNeG0QXWn94Z4{t&bB^mzxF{h3#<XPExsAhV=|{yGMRPIeDa zhqXt=L4<(;WJ{9N|LKZ{nDu!VOo5r>R|_>~%M`FVoy-%~fsGKEE`OMrRYGJf7IWMs z!RAO$4?oN-$=fg)W|&?L<Mi6Y%<{}rCNoZ-f0%hb(<ZIy4o8>`t<=|oqPs+bxkSam z`fJhI?&FTy$2*-_Jgxt|Gy$zL5nZ|(9wa>~2~Y>$5dS}Y^$})S*yI-GsQ`<>$Mj=6 z6d<-1X;GdJ=tvoVaH=A3D8RWIEDQ1KcY;N+p9-KN0cw#6fU2G_M_B#P{Kmku`=%>s z>hxptzkj8=j>jA=7#*7vO&A=HIf5<_chmt_WGDWErV2o_1O}jyMbI|oxWla{EBLKV zOQte16tnMO1l_^@n#uS;>w!{Z9L9heo*EdFFDFj_|NnZPNB1$G?th*K|Fe1Y@+yKx zDIVDS^r{^2>Sp=r^v&gg1!Kv|?sG35Ycnu_t}^%NW&JaOk-@8*<p)HzRP<QAvjO9A zXRw1oN5wTKn=rf<_31wC3L0w-QOW2&_d*nO1a9|-?sG4ibwH~_kG)g_?NT`dI&mrt zbW;;#aYgqVkLEWO#{XTrKlmj7^aL$j`~<pqqvZssMrgfMY7X`xXg;p9(!}@@IIxWC zPdXlV1Rsw9p16on(Et|*FJ7Jk*U>Ngm_YpyP;Kfwfsvv4fxU0{bI*f+*nB!uU-<Ou z9PsMqdFa&T^3t-ybq8pKx}4Lo``GsjD;P^AIel|^X`ukx-0j$X-lf-x>BXM}ko(Vj zbk<&Ykq`s!q13<a2W`CPZxLZ+0ENsWCySaF7W}=ej0_A87S$T1{GjnIkC~t)uA&FQ z0}IX)9+o>mjipk4uWlBw221{yD-0n0JdZqjLmzl``@GcnFB-H8lr<nzhy43|cYvl* zK$Fm*nMF?Uf!LOygD?DgRm?m(YY%{;()vqrj7xXv5l8;*?EKqLq;<OPcoC4mz`(!V zcSoA_!BR8F=3`7Qoux<8ntyVY%I*Y}p)d3k7#P4TkO~pU|HnWI{vY>jKF;K8{im4w z^~V3A{3}3Bi~~O1sV`oF`n9gz=Rhe-q28za80h>Z$L{Md3cmdR|A}9Kp}T_P<s5L! zRP<sWD82B2Jo(b1HVER25;KqwK*tR7w}OTtL1y*(9`NZt1~O$CXvT5}s@S?;|Np;U zf+|+^<NyEH6Y9ZX<<skX#Q1<~_c0GeaMSymN2lw7PS+FvMR%?Mg<&b@e^LMCU>|hX zp7_Ks;CkQ_zo6>{k6uxOK2Z0-^@7L27YeNhN@KcRFSH&g(E)7{6$ef7ASLcjXOov} zK>LGzFM!6}{7(J<|FVA0-~a!?(fG~fg@r>2YlEFsi99G9KsC!SFff2}#!Ju{1l_Jz zw2y-_tVi>a3RtF&kBg2yd<NPb0<{O56`|dlxko_5<ly#w5GXvm89X|{TeZZR69gDM zniDh_L_L}nKr9Z1W)F$~kS@sXBh%GSGHXG*xH+Iws6+*PCzgUox9!_@kcU5dB<tP= zv6_!dcr+jV>(Q(8-oyGY<S2HJZh6pHg&k;0;NT116^y02pj7;O&j0`Xyxt<+&LZ6> z_;<bJ{lLG`Tcq^!!56&WE~qe;Mt~GOngbd<InMEVqv);(1_p*+uaz&NUx7x%KywGN zC#U~7$t-7d_YJ60lLt*SFerdp_orX9fi!l?y=L)fR$~B_d<Gt%V_-lhz;x%RI7~N; zXOW)XAk4@%z342nD068i<Mytz%&!@_tS^ELIRE1In(6iDnXSD4Ux4tlqrp+n#=lEj z=(Q7cyHBs^2dK0UM4FR-m$qPUfdJ^p9?$@lN3ZBTs0yv<=`0tRHF^1ufjSr9DY+9z zrdwTLR-PRBkazmI%giE7*ZxfRxXf(CE0zYfOzl7Go@U1B?U$LYrpI1k7O&4y2Je1i z_DJUN>Ana#5bL1F!5?fsy}TtIj0}#=kL>+>SwQ`rgHGRE4p=ajaK2~;wX|=%=7XNN z1Fj9g-5NF(@S!iDk#bPCF#a&CTNB}ve9+bSq$B8LHVM$`WS34alVeT>^^C`zz=iY6 zUIqq+){_+pF4nAnyBQgZ!#%rC`1Fc?Y-eNu4P<p606EH|m*=EsH_M@KE+;G)OH4q$ zxdc!Z=HSxlqEZ2xVKV@+419WhR4PE-I}1?9&H^;+R`B8%sH3C<vfS190LXshlgH|v z3>ZNMXh59-nymIwQFy_B2wXgSG#`loZI}QRCE!U?)HAA@ZI`tmFRgb)I-n}C2&obW zA4r9*60c`q_=~!n{!$^9T6`~95Jx4BG&=5){L`cRQ}_87OH?53^ime%+pnWMx>;AZ zF*1Os*P8z`mU23@>;SD4F6Es*_bM}AcAg4!Cc>lp#*0LdR_nth`?}A+2nDf0<El0D z!O3UUf6=7*pnh%l`4_dypk#dAr<c{e4bm+JO^E(v^XL`1<k`)0;+V@t3x?L)CHx-U z*Sb%?sDgy(<onM>>(89=_^*0$0ciXSG=+}bJ8gbr;FJ8*r<eCpD<gv^=%Bp!%@6E7 z4*q4^3A#7P_#0@&MX${P&u*5NF1?v-KHVWdG(bx)c+y-fwMyAIe12HGW^G9MVe#9q zm&M7m`<}1$2mWSJ(3rz+P;KJcn_T~ue>+!N^G_-M7I{Vn2A^IprZh+E(<L09-51k3 zxnHaMTAwI3N^`Z;^z1$Yw$_8+<)8=i1;_5AAkj2Oe%Hfkoy?xyM?9Escv@d5TK^Js zrGrmz4|qW&XxL7{wfhJtJr;O&pZYKQ3><v?EufvgmRst<s!FPTdRhOqfPBgF;+xA4 z3y%^<(0NP+X^z%MOF^d?XunQ?RC}Proz}_i+0F98qnGDLmy1b7hl`<=$NyuV)?aE~ zfW%!oa(>vnHb`@^%uy*QW%abaSF+dR_#x01I7sV&`NgLY1_rQveL)E~)L?E;<~yF+ z_dG8C?q!h%Ep!6Sb%KuSLKOb7hkbfk!@=$pdC}$a%VLE?=`lyHBONZkEM6amoU<zd z8aY$|H<ln1{02VBAANddC%pOh-xGA2(K~1)`hs@&)qnB;#~`HVjflYpD=yGr{SONk zcntC|feYDtkRHFM^+*0@(30yejs{Tdf%+OAy#b63KY2^oJ-QEdaKD!Iw7yuZ3Nnf7 z7&8|*#lL1d#?0&4ea3_NAZRtC^}+h011~p&>MQUF9jL6xfW}q=IJRu&ff9R3R&$L? z217}*Pp|B$*C2mD+zW{+`7R%ogodA7rL4!8xn8G&ZGgyk`24VX9RgZ}$OYQjc(3Fh z$nfS<{~f!}y(kQ3U}&hXQAyzP>6I;g{qKK?-Z5t0*J{U@d3}0iQ(pi3|60nkdkT11 z02<aDJWSxAX6*n)miE0;cH;vtEx}!5h=q;~H9ssFO4+*)zf=NsT$4|GFrV}2jr`wW z%}~SP(S7qJsAuWeedV=4^DmZiNsoH#dqpCi+IJk8ukdeUc52uI9vfgNdBnes+lhZ) zizH~Mp!Gnh@C%0hpqd4=fTa1v|CdKWJKhdhA1Y-Btya77I@l2s7S^83cN{_9ZvMqo zB-jOVrYCeHpu^{fb@MOgQWVj8h7O+}Hr<Cjv~Ro?_<jo%Jjs_pp%WIwzyMvAr+p8! z-UYlN=a>(uD{g#gCuqR%1(PHLgG)E4M<MiI^z1C~PLp$c|Nnmp+UueXns!il1v(jd z$}7;Y&i5NqCmS9zb-DbqRr$+x!nv1)p~I*Cmo2FNEj1fAFi>ArwZs6PWg>aIY- zr!zqTbOr~c`QQ9T0o3yEe&mr1?iLxmI0`z!RDt2e-Myed0#|~NE|CXlSy_NjcZx~` zs1}4|C1}q`q?M7O9?~^p05!B)50py1sDYX^1#Z#{-#!2Tzuth-0lL)y?jZPpdj;SQ z&<hL3l0%M-piEw0Ci=n@YK$+~7*KoQ_4e*_FY2Tj7@AN2_vmGv(Ew`gvebjRM=vZG zOGRHOgO!5Z{^G};|Nom67+&+cf->xt?sG4MKqDMCy3f5(l>t@jFO|UEB2Zlj={KU5 z+X+6&FF{v7cRz4!{`;>~^2PE!|Nk3*>oj<=Zx1YhUVda|U@)%#)_Rh^;{s?4hqW$S z3nK%6^I>LCH|S_@7$c~l=nPTu@C8l($-by(Wbi!rf(^7@&;hi>#=D#4uv1IO2Mhj| zer5&+$41aLtNJqW7gl@z|L-(-5e&8q<oB12%nS^!txxz{l9(A7oW8kyuwdeE4P$0t zs0S?oJ@3`+^FhO-`<@&BzK{==`$4q}Xo0DPWA`bS4#+Hq_Nfv>>r<twj@?JTUjQ8m z^5W`lur2R)gM0+C<;C({|Np=21642GZ+yFdzOI8RF1hU3{pR9Z>-YRl@4L^wkN^b+ z=p2|Amv+~KTAMFU?*@$r{stXcBmH6?*g(*H--}`}6LgTvOHd~abcWSgmtH5v7k2&( z3_jhU?E<~Bm+BZ9T)H5x1fON%-OY2@tJCG90VsgF|ADehfa6Zk-FIN0dz4f<b-8@7 za<n>Fl3(BYwj|rJgZ=+mkYXR^U){glI($A@xwc#?2?hx{b@_a-cC<QK;@bMQ#L=;X z-?6vy2S~z)`PcumAhp&mR+mcEK|&z4HXyZ<t#3<2A!>huB;aao9J|lH=mXDsLTW&6 z&}KUak6vEBI>zZ2A2CZXZ=S(0{mmn0ZI!t*Kt*q<{D0BI)4*B#$j<-&o6r9TwcJy8 zfexN}SwG$SF|(eIGgu{m%NJ1Z-ExTvX#Wp?J7{?>^Byn<v=`99r&rdimT~&j$IQx> zM?5aR@a(?s*bSL^dU53k=-}m-G5`Pn_q_PR!J<UPqofLSgjaxP_aV>jU;e#3PQKO` zizBChe9Wv~zZ;Z7Ub8vw1}%;9WImkM$?wza&g9ws!_)d;(f-$h9=*H^YCwG#mWxge zJ|8TYJhgv$T>Q`c|K$zP3}JVON&qM%YQFvd{}OcE#(&Yusi0X?)>7#g%sW8|3Y-sb z>;N%A<CHH!XSX*0$mMVC{r6w-fA_za6TovXuccmW*#S<6XTfU0+S;~H-}r=Ce)@V@ z7VhbFjEvm%9^D^3T2Gd0zi0xh0;g8%?a<(iQ856Gu+^x5Pud2bspJ@U7&7O>yMnRg z7KF*Og0b{Gh<WkF3dR!l56zw;0<ZUhC`OPd_{_Ib))x;VKyAS~(4}SFaS9%tb}#0g zssH~UH0RrWz5B$Aw?F^??{pLB^<ZrN$yhE9xh#gG`2fcUPB)R}Gy#T}8KCWrZX(U+ z|4&%KRvHUhksovB|9|V_B{m>-z!}h}@4pg#5Xbq<|NkDzH+*_cd8<L;eGa^|PZy*F zX=z_5v&g;I>>j<MnrVy-T}~D%O*T!XtRI^FL=+n96hJq=l*)FyiA*^70yM`Z1YvTl zU@T=n?xp}b=FX#=jj>LEf18EJ{{tSKY%fp#`~UyU^fxb=Wu?C-!KO++bbs<l{s~$` z*6VxX#q_TK(^XzES2FoaPoMva*@Btz|G(+CUNK8gcYMbzGQIH|vts?VM5x|Y(D<0E z@e@%0BLH-UMC+wei5IuG{{QdT8>0d`s&(=f@S64rW(EfS@B==bN*>*y^UA<iD}iQi zyK7VoKxbMzcz{N&IYHx4y;C<ZGB6x(1(8||_6#1~C(>Lxmu>+y40eN-6gh$VvoE-$ zKtt>19^EHAS`U<JgW5o#!=FJ%a-Dmj3Eml4qhbI$)Q7({8l)GrqxvOiy}76LvFXv@ zndR!wl|JO(E|}K*%c_*qv)7Hu!}>(2e_Hb^{j}y^y5-#b+Yfp0FFw41v548R>xifJ zInXWR8Xgyag1Ti19{&%59Io)~hOhKnSL2gD$}hoo{}&YijmdW30IfbM)d9Q9xBG}^ z_Z84mWzgIU#7*}Y>Om<E76>n=fSPmK-#rfgWA^EOX8b>`xwc2IRFr?aYai&~9<8+I zA9|&1X_mDUO5~u19`yvzDD=Eg22GlP#{I#AJ)lN=0(kzoe-gMX+5)Q0EkLuv1|Hql zJhZQS9Q?)XV_pBKMBG#RidQesbDv(`JAeQGcj<NDc=5U)G;nbGzo^qB(008ipyPf# zyV+m5f{TFr9@aG~7W^$oK+f&ve(`fNXfOhFicO4)Md{m@Yrx{C|BJFr0(q|nbgK|d z4|qXZH}{L95IyxA9@bz@ud98!zj=0F@zMScN=Y7`2mdj9bc5#stpAm$`gC)6G@k@b zOr^P6s(6A<Ejr}Ue1HSA<Ieh6=>xDH$P^1Gh$H5K+z(pXQEFs-@<k-bvhMpH*8fTb zJ-WGHc!K!NAP3jqD}4_-4XOM53)9WumDlq?BZR#?AAGvMdvx}K5};4_Ly*oepYGQ_ z+V6e4**u%i|2ID1`TuyDvn5MK={Har?E&gWX&?0bf868Z58v+d9@-Z`rymN;1l5wQ z2TDsky1|C|cdF=lHXq~g?^UVsvHs>%x&c&;1b~)*OT5^;3FK^qI~RlaV0YdteGgh4 zH)+%V|Da=TdqJ5FG@~H;``>iQU(AYpKCttZBsPNbx1bEOf_U@U|DN3+jsJtsgnb3_ z#{Z*fmNwHl{xCZ;oxC*N_Ybpp{hR6kL5saxL6h9R+W)+Id5S$j^DJk5yN|p$50wN} zOFrFY0xrE396pw19Q>`IfesH#yHah(?(4lCEH5%IfjsKb$@U_9BghkMpiS>i9-VHW z>);hYSGm8A_0cx-0A05Mns2BFMX-<chx&3kk8VEiUL7-!?yI0%Ckv&)%UDXqj8DE$ z1RHgFKe$C9vhn}_*Q#E<JRdwd**rS^I6QiJUU+o+2^gPz@nZwXPCpKhPDvleIu7HL zFP?1xSF<<&fp)!~1dmpOSLqm^e9^xiyd>{s^RNH^&p1N5evnhnK?|T9JV7V8-00?d z@nIEcTo8O<x<@y7`K(9t0SVAhOoT@_Z&M{`9jlLu!t|vAECoV|Jpcc{c(EQ->4B@L zh3lrP3$iE(fZG2a-Mlv{AgT?f`wFte3mxG8|Nn(MLN&v>>H7p(l=yk#85uk*89~c6 zIbUe6pZ;EuMW=r5N|5JbR6rL=IK;!oFde#Y8eakp2`Rh?X!`%ZS@mT(=x*cR|4N09 zv)(Fa1g%eC_%F)S%fRqjwE6enQjz1VhvC9+dqCqKuf>~x|0xv$r9h42tV^M?-4Q$u zH7XViB|M-t*b38ciLi*&$Ed&;L4(d#Jt*P0gAsIi$}%p<ITO`9{M!%t^zw?ufjk<_ z;?sTDqjNIoAm3guwzSWyJ$hM%;}{vbfB9%1@apB^_xOLj%TdCy!-d1Zqwzn;sG1iZ zy{sQV+O=<Z_406mZUAePWMp9IXyG=h2h|FVzd)X<c?|0IK+kLhHRA<9u`3bk(Yr>a z;V0<C**6W~WtptSk+3?d0K7)=XSXK{beg@z9aJ6khNuMm7k$zVDk1q>Oc+5&rGbL9 z0KB@RgYo|XkN*d)4;Ovyn$9D}BBgn{nCF-aPl3Y!gO1iG%07T@VC-UQIZ%41+nohe zArv&Hs2DJ~bf2E?FUBHK4_ac>oTB2u04l2sy4_j8Es5!%KrucE-ge&WS^(Nh1WHpH zpfRKua)AsCC|V%b$$506=xPPcDWht98UPvsaxL)DKJL@o3zGM#*FNvjJGB55a=q@7 z-<TLnxEeSF9J_oNp1&6S#>52TDmZreFg}0HWOTBl0~EL*FM%2g&950t&%U+?r7(X< zaA>&nI?Z?Nbx>&jAz9ARz$wt{r0`n65z15Ob$alc$>=~wBgl~dhd{x0xxVO(M|Uqc z=#9_3nDyn~f1lntDxkRW?2eZ3?5<Yu?0y`37}{9{AC2zQ>7n4$=^zmbx^AF%MFpt3 zX?z3nf=kz@?wg+77d^XAys!pUb*En(0j-(p?p**H#{J;~$)S$c4lLlIg@23;E(|+0 zm>3vdoLmjcKj6xM-}vN<y4B!8(U*5YDWJO*q#YFJ4!b}tW6+(J-QeqMTzb7~_yrgy z&w6iY?or^$e2`zzF~O7hB)_2N2hd5IrQ7%g82AM|1U$MO6!--h`2{@%JUSf}Ji1SV z26P>udh5~kf)DG#p||_IqA+OA!<-3x9BcOn>*J+TFG5#=+<*Ew<P5R&Rp5f{I0FNN zYs<G%))#4@5q+pXx;sE4U){$+XDKlsFO~P`u7`LKBH_`?`WKWZtWT7%zK~z_|Nn7j z&<Y|CsP4`gAl*=2cL(_F3EnmFj0~kA9=#BAI$c!2!_q1qy{#)i0SHRQprmiG1Ju?B zH9Iswp{da6qM`yS`@&!R`0@Y0Ys)uK%?r`e&Ee6>D;B}XV0`k$?3JKO7nCkQk?h$G zyHDh?BlJ9&7!~MJK9A-%3LfD7Pu;AN@r=`xBw3W0dKOP_lVs5ld=&v|LHno}c!0ge zzH<70Nfvpgw#CyQNU})RKU@eZ$(!G3G}vA(1Z`#V@#y6}5e+J-csCY;*3Pk3flTP- zT^t1xWL*Lh?Bwk&WMp{Ja0Ij$fp=mdXqD@MO^iE1Ti;%^{rUg@7;AeWBLm|G(5WOE z;Nz%X)E@><L8gH8cb@?5CVF}1A81c*XAEe9C`Sc(c+tV5oAq@tw2X35vGC~r^g{n9 zXyI=64^UG$1au~Puc|=|BZEu#XV2~<z1fVG7W^%4(;cK)B;-^XK{Jl$|BH&YK?*R? z<me92@RIe9Qnl%2(kzNvFK>b(sTXuE^!fjyFIyoB!40=wKMCVY&{F&Y^Z)55rCFNl zXK!R+0G&?E+67_=cyzN?f*9-`-K-fK85le|+d!q)Yo_kkop~HDh5!HmZz+2{pOJyT z^&e=z&x!vp8Ne1Inf-(5|9{8sW4^sUDgr*evMZw)865Y4@|sVtjf3aG=PbU==RLbG zI$B7U*iAnv!=lK@JpHu{ixT7A>3p&*D)pN;K%6AI2*eQZ=$4%bVz7I3%QkFaVDRj% zQDO1uoCk83C-Z-g-Y}k>pnFI8x3hcn)-yp5$o0@ZTlyB%>w5Y9|NqyZ9^MQ0?~t~X zkBSATC1vvtR6fOk&OVBE@a)d^fL>-(?+6)EJF{cWJq8Br6XpITE<22mfSK|omfZ)N zUucyW=`tN*U?|aUe!*Cx1|k%je=xt6>OQDz3KAFAO%`HcDDlu0;sBjN4m#zG$@r4T zf7OCU28Ql~x@+$-FqFIl>3azxo`8t^AmUc@i+aYAt03kDT~m1mhLV#Y&BvM_alAeV zs{1&?dmAN~{{MIFzS;bP(X;yo*p-g_(+(N`w?0wsSW<y-Yc9mCX%M%@gA9!V5uqTr zdcfT34sojk*sZU1x(%StGXN<?_TUS~5*d(~IEWB}xQ@H|2jldKN-QocRZXB{K2=yG z>eHGS7>wUS&kj!Z=>D8$sZk;YI?3JR|A9119k<f&9=#@Rpc~iIEcHsCd1!wIu{|#S z^I-l4in70pLFFHKgMlDu9=!XqNB4;r=lMXQ?~PBsSO}H}bvK$o-HoG==0SH3C_|N~ zOpgy`WS?xnDZ;(W13Xds<3;e1>COf$noL)YP0ur6v1j_cX!?2s77yXvI?!~}aSspc zf2Hp{x=+8Dv1mG%A&U{8%cB4PcZ0?!IwfBGSuowpkVQeJX%1+U)BSGN!c0(+5u>7D z{h`Lpr`I+ym2rBTA&Z=*Lnb3b^8trWR&$Vw|A${6+zFcce9<xoRD!?m@<_f2S|ysw zIQ^_4ixlhKItGR_pe>)0RvyVWJ-UCjo~+2Wmc5+8$WWXNSp<GO1w3}@(f!%u;5#;t zULDW`(l?Lhnim@XOYL8Xbp4-hZ^WXdez_Jj4$1P(qqF9PhVg;dVlP-1f?B2^FTA+5 z06aq4d;+{{fa?sz8Ad4(XR!ROWnh?Y@6ISC2664rS^xigHlO=%eA}m2^+_`0bY^1~ zL+17AjML4HSzLrXYZ(~6xmz%nh<J3L|1auP%P_sym?eeDf7bNR#w_-do6;B=inAcj zUzUXA{OR5%ERxJ`+W${aH(}9KSW^vka<k75jsIXb-<=0{^QL*zH<++!8Mn;?yZyyH zxYTRE){_-R*1R8585xSTJd#iP^s+tyjZJhP1fBkP@WpgqQx*w3YpBLxxW*Seb3wh< z6aPVlG-!6To3$vNkzpt3aMIQT{4NJOS(DO1dq5ALIWv8>9gAdrKrr}>Sy^!3(p$m9 zn%4~?!VMA8@UZ5!fr$JBnceMe;9<>c1QB@-5wY;F=GB0RT!n}@cv$nwK|~HiL_9pK zc|{;18zCYY9@e}{^$?-?5TODOYhDS6NH0XB!o!-E4<b?x7U>49`tY#kWrPT(K?K27 zyfyEaAh2fwA%fsuxi#-|h@cHf5VYbSG%wbAvLp?>&#oS{Xri0b!<yF+qD%~=tlOKz z!<tteBEkX@5%93)m4%3W0yj>)BRs5mgCQahAR-AK*1Vn&k#issuyv3U4P4Xr+FS(L zXMG;jZs2~gYR-SL|KJ7c*7reOVZ<u<>A}7%D)mc2n-qGzExND1nDzhv|K3to(6ESi z!HXWSL^o)Tt^3-GItUMRi*s-2?-!t}g*>{uK{p`3&<44pyBl=f=?i%XI{?(d5eBh) zyAwdI%&RYKAqLEV@IcpZdGvN)U`%6R=)U$s5h7^-YMx$u0jeB5db=kuF))DaVgX5Z zcP{|7NDs^gm0jH{K<q6L_687p1%wSc<@3cHFdO7ga7osDL?Q0*bb~+^lj(Z`S(NnN zxq;dZM?E@SHC(!1xq>DnFZy;r@aXmBc+r*j|9|&hP(-)>FJ<@Wb`_Y;6U3szAM*A8 zf1l(Jtp`fkjsL&AFx@_gMU0KVWiIGUp70<RMaLPS%a^ntc=Up-ZM|KRdz|^q83u;e z!Y{VX0=XE}hA!bc&TtpBjiULm0BHG&rw`}`4p3>i>f68RdxKacRn~n04Jnk!_;mMz zk|1d5Y4>Hv?z8_zbt)Jbx_`XpG`>Ck!ABMmC8k;b|2NbsFqCk6bh~mu@1X;Y==y4S z7@vJn{^;Lyy<irZ={dnHzRaK98K>_FW=UdJ^JAQ@7{a3I@oWajRo$Su)EBdUf!QxW zV^6IoOT?Nj8A=6T96?gi0y+h?yZZrX-^Usx@dY!cPYPjCGOU4!fmVR-2f5or`}~Ux zh?oSZQKNnSMI?j^YU8}{oiY7s2#cc4GEhudx_>B<^5_O_*DVnOS<U-G2&|Ux1s8~J zu7AM*+QjG&+8|NF1yaHK;=}amPN6Isg2$%+|9=L&qgBSEmvv4r!}RJ<7DanQaJKX4 zWzFve)oV9FZCi=%#u!Ehh6$|)N_k)02YdPSi|py3k_>z(9B5;Qlt(YCO)tar+o3EC z%z>_q)8oQee8rZ6#!`BBfO0ydY2VGN=EFGsU>J+A#fk}__Hnmp2dHz<eg1_8C=k1E zfENwCxIY1On&EBG3CYMy{a@Jk|DVni&f>}Z-idK~L^zAebe?7wp2-fJEYnxyvdHSB zPX!g<prIS%1Fs!HCna#bNVWp`<i~3!<NqG~>+gDWp96JwI<2OE%w>^bp8WCObb&k; zS<p89|Dx*(!2>}aovb!-j12r!LC5BSTG^^Paf}QMpsg+7;sUfx0lZTM+B*Q9y`2Fn zI=Y!bLr|cjvKPg~9GN%e{(sTg#S9EBpuJO|v}=8@^tOlfy%K8=>-!}}9?ge;cr;i4 zU?`FDP=ja%ozQ9>X;->z=5*te|3%}AL9K(=0v^5293IxkOD|17m&c-&tK!k^`~zeY znsOePa_jr0cfd^&a6dr-G=SsL$?F@-$Z#0!0nnh6f=Bny7kZ%6>u-aM0&RX$xGZy@ z|LsL^t$Lsc+-{$Gc=EwO(R$;PFU0%65yo0?54zR>RMB<IzK#Kv2sb<~pEf@E!mAII z8&G!lf$#AHTjtsQvzzP1<z9#x)<|aThnvyO|AGx_24WqQPxl><=IMKjSQPa7LB$#5 z#A}aE-dK>nPTn{O6%U~jVnBB>fXCOSA5dZvsqen&YW&|tu|}oBaT}vcM~O;7_r>N{ zOeN|dA_zptf(Vc1SIi~O&97KW_?lm_m2fuyV&rda0(CE5GV!-;0W(<mTR<tf`6VZR z3+Nb%=9g^zEugJ_pmSd;jsJs((qD+I2Te|bVy9HL`Gm@U(6yBgp537KeX$3$eGgjj z8-LiNo57=-x3Gm_`t@QKg?g?@ptK7f$U8g%bn~D`Zv}^|(KoQ8Un_yO`bRT@I!e8^ z&LD<>N3X3Hh{5jBYpWRzIxqJvsL#vg*z3#uLZb&9(&iu$A&+j>4qI5P8GrD&e9oi! zA0y;28_=z!Eo_VoQ4EfI1UMNOntyYbn>z9@zEiC4+nvwh)0v}U;Mttc!O;AhqcrHn z(l!78cRPTF7%MtmR1{uJUGx9{aR-4OPze3z09^~s+Skm$;BoK)izhR?M>lUrGsE-; zB`gZ{Z*4$rR`%Cy5PLul<ANOfyS*D!mi%J`52DNj9SZTAqg45Y!kYj85f^lH2MB<6 z#vSwNX5F37z~K1*!fOdn#O)lX!K+<F7vwWA{J#Y9!xpd~*7<hkbAVjFRQ<)p)&Ku@ z`>0fOdI-Fp4zix3*N^#yb@%`O5NBMJ{r`W$nduXAS;Xs`Yg7Ul9J_xyg073Y<<b4J zl)J&olz;Alm!LZ)U&Km+GDoRFgSBa|2V*@~O^HXZGw3Kp_O64kvpkp&b_q26GAQ}h za;fy4hxOf(&@SiyN(WyD*fKCNFqA6p1dV{S{x9JN9p-hji`mAY<a^7364vH_x~2P! zPQKoyVGAnmOXYDWyxaUww`AJuYeomA2Zl0=PF`?Zto|o-($Z)*C<%FVyQma^*G;>q zXn+n<1~1qF9lzQcp#wV3>4jG>c!q2hsMu}2RC3bz0O-i&)&q|G{s;aafSh{A4nFPf z^(K$j|0OFtyFEEPdgB;9x-TAMGk7fu8ig!j_4t42HPZ%zjug--S&sitxV9dse|C(S zp+dXcMJ2<f+eanArJEg`R7(GW&ao&Fdd&<v$?X5>E@m6ck}v-bbTBvA8J4pCcV~Gm z2Rir3^Zx<Ih8hD#hSIN~6VQ6Yz}Fl-|M~C#^a+PqM3@cY4^J<c&LXV@I@;K^^%8$e z0t*8}w-xB5m@v>O#s5$B=Klv>74>`i+UYD>^#{eki!dZuK&u)qmD+Y!f=5nWIyFHd z)O?VoGe^Z?*BMaDYnm7XgYl*A<Bs3IbRTcM)EUO&z(4h<@g>LaUpn<(UIVS0*bkaY z@ag{Q(f!xe`g)1AZ}%B~dC>AS1_rlomuW1<mpl$WS8!#%?!$fD^WZZD&-(5Ip5H$j zU+O;L31;~)fAr}7<!XJs^n$DLNs!&3!7P_fJ+Kozdi_{l2#A5|tn;09EFK46DtLAu zYdzWN#{qK6|D&CHFa1I8uztng?gCn<(S67>`I3wFQP=KMp2;^ntS{GidNdzo@#tj% zwXzs|nY!;!-#3HBtbRI6F|*_U1K_3ix0x6iT)TbNv-G<EbM204XEA>3$iMfXOXnOF z(5P66+-}gOPRD%;3=9m~H(azoyL4_*0d10My<Ot>ntwM)ymJj$#HIVIWA{NvP;=|t z<yYOOFF$bUKIM4%u?zPJm~qYjnaU*Ud)@y!cAs<Xc4=q1{KAF%229qqH{rhrsGRZX zz6)A*(gDgPpi_6iK@A$Hws7n|=+n7IMFQmNUL6~dm<GSR3j>3z^{aArr|yt-EU%fm zuXavR0nKze_PYM>_Gx2r>~;O;(jC*r0$QG;P~RD%qSAUBbTEyNiiIm^BaVxTg6HKI z-KRY+Kk(r`;CT75WAk6;B5}uFSCC7)UD_ZHea#A5J)!`bn$Q4EwjS^R#itKALOs5J zbm>0iYkj^<+ygX2#sEqlp3Db9^Kty^5Be}4@U=c(Zr43UMGO?MKHVR?4|(#hKM1=s zkYRe_EEZ8;U*==J*2l{pyL3Z>*%!1W0CF|^RhRC&t^Z3>e7d)&WH5o&aP0wyyJzz; z7SJ_*j@@j&y=5#QLw%SpIQOzBPv1C;MZ@Z-Yxj4TPKa7Za8UYm&jFjz-2x6K&*sA{ zp4NwoEnK><w*D{C^XWdCHo>`<MQJ+gY!;n*@LfWV|Id0Je5?Qpf94yG&2JceKyv{6 zo%*2DQo12A;`sj%Xz7o&STRrc!T$$4bJ|#}`HH@{bc(sQUMi7><qpT*p#Lu2mn?Ip zv6QlPinU%UeG583n#uTpN8=IDP#So-S4@0dZ1iD=(BSF$D_ErJSDS)b7)LxhTOY82 z7V&HiU<b{=KLo{SK=&umxNm_^XK9B|r|%5V0_Kz#C-oUXH*ys~?vZPLAa5gI%6`m6 zrGnu#KUnz-c>@Lpmk!XKv)wT&0sBEox%;?pXNd}jN9*lge_no%gW!2P$4-`D6^~xu zh8IHmp!|4v*MHC?59q{S_%XR2%7;o7Jz8&;@P2m%HQ*WfTMmOx5^hdWVPWv;W&JRh zf#G$6hxH-;*43b*w)?Qh^z4-^*7YSWj@rjd%s_;OqxJF9XrErzRdYesOpRa%jZ2(+ zQQipZ)9|;-3o<agd@2B%Y+<bjnRnZ#mo*Q>xa83dR_)Wv8a5ZA$qB0Il>lfK{r}6g z0t^g@8BkCFWOyjwa5XbN0BQ*a7+=~g&%nXZ8KaW(;)gCMak;4EfK)kjUw-jimx19E zzkrKM!2e^8;Ny;`KU>M7F#SRci$1?guL_$h^Me;v`V0&&mg-HnTE(KoXfQo?6-x}G z!}MLNSf268Gec*VTzluJoSlAP70Yb_&>EnZhD@M+M}N%tTU@5kT*D%-20Hi6)%bu@ zw@d31C(D*rP{GFE%E!pS;L3d5#rjz3Q_u|6^m}VqR182(E?47k`^;Dv7+g9_7dUEv z@#yUZ>FEAveCgnOR*znpy`U3>eYy|7(0llAy1`l&Lvv6UW;dve_vq~{0j*uOKFr^) z2I^z=P6g?GvGV=D|1b4H%h7t>{ySP9=5GOY)u%_TV^P(TbLwRQ%|0`5pK$Cx;MD0e zb%`rTg&t__P3VHxyT0G{kUju*;?uP(nv5>f`PZ??8X!AF@xj0U&Clc=yN^3`oxA*? zvqctU>&tilK#Nwu7M5%SS!P*Z2{m+|PxoQtOE0$G|M&leO*5!*2s+5^#n(pA@}Q-l z>9%ek6@wjT&zv~}S{3+$g@NJw!|p>Ky`qoS{ri9L1vBW<j_wnkE-DtFk$p8#)wn|q zlsK(VbRTr&cR$eSqT=!YME4K=Z9PpvFBlp4w{2+(u73eKw8EoT2JGQp7Cz9lDkOY6 zTOF7g7+$E{|M%acm$!D^zyBTwpE2=oZ`m2}0yLvB(cwOb0>=et)Rg(ON3TfJiz9FU z{dei^1?hFQK3^W)4UXQ{1En0U#!p^?`nitQ$N5`yL9yNXgoVFFg>m}4^(-ceFIR$Q zoUEVow}*fRKjwns&A0oY=fMX|uH6q^I(w(vZ(@<P0|n#@>9?R2z&_mvj4!>gzxVI| zi(`%OAggbH2U+WF{uZbI|NlE$-!G|lZGBQwHob2HixD5__Cbs0y`WGnE>@f_znMkC z(WMg{%CALTjh`4DfbqCoy1~MZUB_Dv@V9D%swCqlP+5=e(hiUAd#<hD_*<OVr~7SY z(Nhv)XJBZqT~N&5{FIG>q1$zVOQ%cg5*NnW1uws|foiZb(@$(*k*~iAD$^qPCmraF zQ8Dr8oeJ`;C%^NBmII)bCJwIru4i10pST)da_L+u06M7VHh&9fuG*>FWMb>LQbkwm zEBvj07#J9w6t_$jVP#-&?M-5Ys(twc6q3fbUAqstf@+q7pk&Z}>-%lT<{!l+380G| z6i&NZA1M`TUa}XYm%*{ufw8j{WRGL_0axbZ%m=48Z)7pDJqTJa9-`v#dX{VJ?Gj&* ze*Ttza4L3SbnL$1YJJ3|`#>pQ^AfNd7$9bJw}5%mKW$`Dk~4v5vIEVucKfJAfY!1& zxH4aNvA)dT`h2?4CKmnr*jI??Y`p#N{|k<Kcyu1Dg-2&MXeOmsbpNV<|FwNoJRHI4 zyVFO-g1`02@Bjb1T~q=<nWUGcf%$;;3I3MVfB*mQb^PDm()8j5WOrXb=(;vg@|*DY z|9?>Hqow`t|NqnPZ(=dy(}E@l{$|jbSl~oq@=_kOU<r~0UP}G_|Nr|<pI+8KEC2of z{;<<W#iRQWB<DGFU+8pEF#+YgsnbtwW|6B0<uFJ7ZCe_G!I=ej{xZJ>&R-K&5}CiQ zzd*@fp~(5`+e^?gPf-5iX#w>qz$x=P!}Q86EP8S;r-M?3^>_aE8=wWtu}k2Y>!VAj z@AP+DSY&K$UmzkP@#eq(FJ9EZBVu7SC?ZN1fHD>6vH?)0N^oucRub)Me88vs^7O_n zESel8YM|6#EIR$*b{1ii*Zi)=-$1#kbir$Om+sO9(0p_hR1|lYb~L9hVDRX^_p%3+ zudL5`^oA~Ro!+>WMWo)9-|41Dr|$&*Ne5gyLD!u0hAu(mj|f+O*K@AM-@y4}D=6K% zf}9091rd=!uJO12M9CmUj4qvE#V<kI&k_0K04QL(Z#g1mkb1}N)2`OX@a2$hk*4kz zaQ5-wUw_Sm`9k+$4{(c&*`xbb=M=DvOE=g)kAtrj9Ic_5DdP34*4riCkZkb^IWHYU z<Rw4Q87SZk+1&%qOd!KgbVAs0Q(r1{-)ucuy49sSM#TbR;4E-H^PK?7W)ZH;*Ihx` z?A7#p+gLQ~8J;0xSLOP@|1VZo!DBb25)!-JAu1+5y{xIr{{7buQ3==yszN$LR806= zEB=6c)S%9$13Zfb{RC$*$L^K}SRVTd%VTCgL3!*Oe~T`NVSIqmWqSP<7HysqB~TLK zZ(ae)dIz_&i16O}0kQn$#UKCwPfys%A}^5&UR5#`R7899`Yw2(`TGBV&^pfPYCBja z*Mrt_zZPsgP|E74{r@!wivg&w+QH`0?K-2gf~DI<C870yg#c(Qy}q2Yxke?0p_GaF zc=r#F?p9EH%j5qE59{L|{7yeSnEyE#eFGil)ba^bO6~*AV7YYrE&vytk3k8;_<*bN zC8utesY^UEPcWRCW$oB4cEE%AgirTDaNEH1;0sU((AE0lbl06MR`sAmq(IAJKuH|r z^7Su4p1bbTeZWQgvLkqFC%77S{QltJE9S0K2Ocu@vIsIAaM3#8*y~~7(tXI)`eHd( z!%u?}ZpW_guh|^C4|ecKG@tnI!hFKT`b6nL(58Rw!=Bd1Jo){Pc`)AqIloopKgb&2 z1+K@K8C+XWma;mud@ErFjfZtZ8+j?+Au1U!N@W=s8fsK37)rob78SgBA<Mwv2pSUa z1vR=sGu3tn{!MS+#iGLEUiSb0^o_@vv|LQf|NjS%HFQe6cv}h@On7Yr8gUf@-2~1H zYBY3TdlB;J-~ZR3t6_{Uy{NeS?>|VvQ4j0i#XK**f=rS>!2~`b^@TTR|087af{6-f zO%!NPW$VdOPR~w;9iZWo!>yM}SvnYBzyE%y;s5{tr7RtSub+KC#PH+)|57gSIEmxN z1Fy}$9|GO$S1R7y#Gvv2zb&Z2Uginj%;dQ7!D|VS^n?GU=8eDp{}*5=*9VRK#4|W< z{NU4lv+K~oS8OWwJPpnrEW)0k)ktq0xh^_(2!YN%>AvuCq8g}$4O$KKvQLeH0lKf( z0hIa+K!d-a-MpZVsltn9HPEo_50-MN?hqA&>48-&lFSa#ho|RPv54CmcywDCAAp@e z_RFUmwAP%z<vF-_a1(sKF6d-1pYAm(pbmuvdnpIxx`o#=7VgvcRk6srfd=IiJi4!g z+UW@|ZmEKL4HrB>$GBD-9{}Cml>-`gY5WN~O{mP;qxmmmnP=lcP{26uV7LLA{_pfr zNtiBG&7v4(d?2lp+k^R+NAqDOkLI_G{H+oH|Nr;YzUSF#?{V?BNB7~Epus(l?jLEL z%&(t&cG^20a|NAc;0ie&H_rp=P>=2#m~NG;@61sFITdvOC}>M0$dTZ?$of2*f3TE- zMvXj}e|Y>qY<%GL3Xs9aA?AYT>bql9GC*663Q+ddfo2H1k9c%O2zYd6NO*J>D0Fzh z77Cv71P|D~Slsddf48^D1fSUC3*QbN;BNsPveIo0S`!e=p<T`4(d)$M(aGHHtnmLt zr?Wuo|2jDz(BW&x9lKAxNMHK@Kj`3NZw~ACT`npH9gMH@9DALZntw2sDS>WY?-i9W z2kkyQG(Be@i$uMp5+lPmCkus=U7#%|r@#jatOTw8YyR=SbQ$Q1ae)ntuVs9?&w<t| z89-taWYL=?|Nl4tU<BPC04lCQUIlL|@BnRoiifRIgL^Zr6T_dY+W-F-0eckcPtbC1 zkUyu(?PHNLS3r0wcL~B%pv{s7X`Ptfk}*T_maQVxTRRZmS_?W35#+5USiA-5+JU_F zVKK;COgOy-Ju@p%WWvE$%-;?%mauGKe4PN=6|n*|QPS<m0bY;l+wCba;YGsb>HPay zWJPBBfrea56v06VS!M1w-C;kAYzC+wi?oxs`=ckQR6pg>ed~o~+yDQdt?nz>N=1*m zgSShA4!#Dv9d!P3JxKE43!W8>C7j3IbwK^A*Y`kTD;Pn?44!_W0y@k%SpYPHb87m* z{VcL(6CgV`L_o8T%iI6|Z#hs3J}K?FAZU2vxJUP8hpuxk9{vHz@V8X||Nq~Cf7`L? z@BcC>1S2~ww-xR*adf9a4lJ$%IRwpdcR*q=$A$g-|9|@1-7Kp0$d0<%2C^FBC`q`Z z__v>X!TlE`!{1W*|Nnn}&}qk@DOb?;1W0lNU0>Dw6Lf%<QURzD0IK(1JGGvy(6i<( zF=u2bR`W<c>Cr2iVGLUM23_jF2HIGz;?d1=h<}^Q35(_j4zGn?JkE#de=#QyyyB_( zh{p7~gDg`19^EfN^M&r9r5(1_v;Y0y52{gnS>zpegfcKN%=G9!t9|I=50B&zKHcAZ znZJ2=Px;=!%*60Qo&_BLnw6}*b^l*8_r@_=->*9k8WEOO^iFR1-oebo(0ZWariU%4 zt5bZ@gZY4Ccgt~umy8Urk4=7GC_4SXVHR=bo%#Q#-#X0V!18L+|Nqkk(?D0Bb%NK) zg{TO0`lxW=KF&oCd`gKU#&Iql&5+HDD5VtaJQvXU%cz?c(T{Vf2OV<)3Tse0#yrpE zclQ7Pujis{XACg}uW7+@o{QL-|KNo)9=)vkhTt8Gpbd);KpPgJhgN_r0v%cbI>!QX zoQoXdJQor0p-CUQ&%M|NGN>DLp3C$LznMiqm(H<+4utPM?+7YjU%gm)4m4-;<A13j zlEI*mcpc`_eGW9BtpL6n<HUc_Yo4H(D;4@LI>i&TGYvHTdMoGu|JN5lRi^^D-Z~08 zXQ`Jp+W^~s_=c2=7Jogur++xcB2o{Y+f%`Mq(Bj91mPIAbAfcFk&YAqp9}Q*FK89O z3nq{5AEn$L-M$B!7lPKFq8%wPR|@?|fqLHqFFL@YkTV594X<v{P-63u1khO@ph(2( zxNADN&O4YWh3>fge>feN!BE2A9s34!Fv|-@usakQYLV{`d?N{RGIqzk6bEg@I&%hg z;Go8fXR@HUDUk<7m<6Z_%>Zgs7`(8Pn?B(rOP2IrZP3zHUC?egsTV)9K-n5Jz4T&J z=KtxUr&!$TA@>8^geaJSP!O2;|37HoMg7aSpoUHBw~~h*t#83Ie0LbY?I@5%3NL=z zf+meaR5U!AAqNhYih@sQzXmE_-+=DH`|)xbs2RQ=)O+>mRjnujtw81W=#6GdbF{8M zUo6GH?WE&37a!1Ca}UTthFv_2{M!zKhI>O)G$4x!x<gbn__y<cR{6Q`Z~x%f{V&bY znh4E{Kr0a-nh$9IDCGzBZn+@sq;k-835FY(RHv_#Vr8G+XU@!~69Zb+1x^E?S?>VQ zxd5O>9B8Ym+>3}zM2lG<<Nx&e7g&NAS*Pn=U{PSQ(wT1P!75zO{o?uY|NmS6moPVT z|L;EjG99#Y7;>YMfM;j6glA{5Lbzj?BglBrc@M_7eY>wac1VIw8}aDneWnenz>oWO ze*_)+;Rw#F{=FiXJi1v9I$6YAu;B0g&&a^ApTU8h!KL+hsiJ4EH%DiTO2CUP5&!?U z9;oMU{S6vwb5RLUK3;0azv~@e_c`VB`$1KE<4@2!wG#W@Mo>#~*Z=+h|F<40kppr6 zfmn(l)}Q~ahf3ugkFhbnmgN5M`p`~B(80^cln+`TEah<QuzSty*dh1*7y|=41LPpO zZ>|gu{H@s_OI=xZg6=>$pnPy2=+rJ-1_lO)5&`RD{4H$^3=E(f_CVX{x_vo7hYU%8 z2w@Om1R`|7rzU}xCxh+-0Qso-B_n^!J<z=LPe%S$Zbk-%9smC^FuVk9I&$eg4r<e! ze<1-{pVNAv<P>DUzq|hY3pS7tsENb#!aV)||89ntmp})sl(O)*fEK_*uD$|U0BVT@ zICh_ZA+rk9-uYj0-uifnWb+T^(vThRckgGgbWsT?<pc%A%RbNr7TbMP0vdn*`_I5o z%KPF@8Z0lpo&k23^@&nhSL1{O9-w`;=U;$2D4>#&zXg=cKmq3mb>jIKsh~ADAQxJ{ zjQaoo|9;Tvs9+mG1HLZZ$32n{gWcw$4H|v`xiEb?*oFKpTGQuTVKHG9O$BY(dU2IS zyWSlXdJ3Q=3?eVSrotTcVqMDr|J}!4>w$J*9eAz&{Wv(rrXF<ocASHM>H(z_-)>4D zPz6O3Xbrx@YgUlLhE8XeouIqFyN@d$EQte8VwXTBy-S>I8JHOuN=$4SSQr>UJXQvV z5_wxG1~vwU5;g0CB_c1%5!M@|fV!F2Safu}n%@eP*ntQm5TVxm*P%q{g&IQX{pA1u zU#l5^YpiCO&T*Z^Pfjlsl#)y9EK5`(N|+nC8+L+<j@F+gV%@A-decj;vsB9QCxezh zfsddT08KqYZ{bb8>CwwutUi7H4HiSW1>ZqM(+^NAl#0Drm;C>KqXp=Yt`grD2b2F# z|968$LUYqHuwCM5%{3|pQl<PJ-PgNMzmO3J?N0t*augh8-KSqTf1hrDlSN^A_iYvh z#skyW+-8xlfBWbEe|`bb{ECMFzo6^#H2&fn9BH2Xb;m#P3;G`SJosJ##MtiBS$o~F z`Tze?i5I7mAm;)!^Z$QwFA1DB9YF)~N{9ac?_>w12+0@Akksr-0>!5U0|UeB^WDDd zeR_TG`*fFXcLbgKC=|Nfwfp$N7wnz~-zj{*;KE(HeR|9t7A491AoU)drO!KE-}`iy zp8qfU#g2iYJ9hQ->33M<oWQ1l7C;&B@A@p?8N1pQG*A$_+@-TbMWfRP)Y<cm_c-`U z;lJn-J5ZDO1vmhWJ(Br-dTk?B85ySY-)9l8|1atSGWNs^*Tnz-U%vbYx|!_kf6?Xk zpbDup@V}@kSi1Yh3zbCBre$%TURy3zP|Nca=pfmH@Z)mMgPI5bJV8tSnCuuBT5t2W z&i?oR|BK2*kmo@M*Szfh_y503SLt%lndWSc4d)zQa~gy4DT`ynIgW0A&+e-)w(JL4 z0&?Oq6_6zd9UIOug38e5hxRTVrTbkvN|#UHbC<;+?ZO|>sLF@d110?3{4eg!0q-<; z=>ysrA>g{)r`LCWH~%Mo0pH^uy`leIyN~c|y8d_QD4h?AO#T;K;Bl=F9?9&WnuMkM z#OpmC-6udtH$Z%Jpv!f>XE)FJ>Av?^<av!;F50Rv8n|4v{pPxVdeuD^XTSM2px(ak zc~E4!bh};$#R51wI(<|$x_#HfqM$Q&wMTd8a!5>cfi;1L2uh9ri+bCD+F>tz;{Q+Q zzRx1Z=6>M+|Ci^d>)&TlW&w?SPS)#^nqF|9MU(0B*XgtGv&c%N$TBkQ2W{={KL5g? z0kZAVnd60F{Qv2f?z1>dk9*Fd;NQgsnyUq^59RPku1)al{^;8Mz^D6_NB7Ov|8*iB z-Pb+4Prd*hOlf_*w}P>Tsr!dZcWH%d>o?GfQD&F!0-o=4LDi*8_j#Z0W7E$)XA!Hv zy92b@&nFqYJEfQj)O0xR!F<4@*F(U=`k;sO0T1Pa{4KU1i5(w6bMOEE^Lu~`nQ}vq zUJrf`>l5Y7o}hg(4?lQxAABLJ2s*j)A!xm6fCp%Vn3aiv0lMZ?0<_5ABo1UDbngIH zJ<7^c{ua=ouP&fllpt;dRrLzsb`$6n79+4*K|}r<K|_6=Au0~8pliTFR4hQ_VVxl= z2A<t#J3+0T&JYy^$L=dHW;cRu1FewdZ>a{&KJEY&kglx{N&>rG3tF=e@VDeJGB8+w z;O~#cXQ+#chGX{?k8alt$QYC}*kH(>Z%`xdCFsB=(BentlODZ}0v^^UJfu&0D4*bO z0iFEdX?>#Hbb3M%i$wh!c~Ag7@aU~k2>{=|be4gE;W#^ZQLg9<wpg%xyFm-w5X*9p z3xHKF1~v6?`MLz+K+uUaFQ$N!(52P`C2`%Z1umci2f;yf+@mw3Ud6z%`&{dRQZaZq zy@=ZW|3AnlrBbi;KpVUezI1@flt_E@`hRG&1g#P-)q9~D^Z);Ab&u{}pp{F4NK&jX zxMDzM=xZ*I?pxiTJX&v;2zvB-!*sH~c&!}`s`xy*eK|m@feV*_PQ;0I@aQh}@aV1$ z@aRny054OBb&QEUJiYK0iwZNp{{QJSUa@#GMo)kAibdZm9JFEjWXl2mDF?d`LRR{N zy4Ij3vgC_LQJ_)@+=iYV3F<;YHv_<KgysX4KFvooJpQXLHk+>hhea;&bJYL;uR+K5 zm9oEB4Ppy=H2;23ru(7}Y!+m-D|odhq#ysn&KFcEmE8B}KK&x;7?^$8qnmfOGH5p$ zWH9!>sHhouscXr_*GH!J{bSLr_Y?pf#`=OS3eia27XcpDm3HjD;Mjc<6j+=ul)%bf zv%ZiN01eZEtc-@8_zt=j$B7+mj64SeL#H!~F=z!X=+yqs7|0!k3Lf1zyE$J(a4;}* zd$YXg;ACJh{txO3m>Ph#)Ed0l{2%1tQgP6<oh5fEf47f{iKRDa8P@Uc<F8r4W5FQL zf)Cz^pC138MT#+ddewgxDeeM@R?Zi%`KHhR&l17(R(Sf)|14%qr3<DSvf412FPNIo zD$BH8acUo{yqNt028J|#jTdSBA-c?9w!ZG~`BM+GD%Gnm0Ihq7QC$xaHZ@<!zyQhm zY5XCooeM$L+6fP3R{jMH3_i-d5(^j@JTE@<WImYY!Jl^`jbC3?6{Mr-J}5sNe4&%Z z|5~&dY}RYuY>=K_-X|NuR-F3e$REjbFpXd1Vj923L7!gU)e9NwL5%|0&0t3e@K%HA z$XlQIBTs$ek35vdukqj$e}rr^SUiH)8%#$&_{0xZa{?q64i<|5slW4yKjQQ!egWOX z^FcO7@>WCWcc1uUUVd`q7hpN)(JSh<5+o@ga_AGkfGShx{OL~_S@qQ_z)E9S8^CnL zg*1MR6QB6wPJtBFfUOYFow8uM6%(tHlLMF^p&J3FBQJj9k9_orKl0KielYvhCw>9Z zJM%!cL_Gb(AM@-JzkunUdEh9xk;Z>p)?vZ)c}%Rf^#{RfVnla>X@OU1{I^AALFzpC z>n^167hg3=<Nu{=J)eQ$Gyk)%FF*eM|37U)soW=i0p4kILF-po&(CLIco8MY!0_4w zw)6-jI|CxS6(nl|lGRFsufg)LX3d<-0J_zP*P1l|#5(7}&00QpdO9<!R(<qb28N@* zo_#+0^R})$i2YMvS9~rgNjNewFdV)3{_WA9`bYWO9y2m99Q}D))ElJccZ}*~5dBl% zG<qILE$F19qd#x++JZ%I%esQ-hsB>6k3PI|^2o!VbtjJAysg?l4`hbEsyj$e(?(DN zsz3Nb=jhAVqEkT{KECGdoeNqC#LKpxf#K-qm{Ug%7Dw`cQqEP7*3Xd#kNy^ry$MqL zTR?Z=Tn2_Ck3O!H-2r9j`p*T$fxrW>=p?YR$OlIrUEF!%$fJil&m8?6$-8F`1H;kZ z0=i%3fHa?!UyVp7prf`w@e7C?I{G@|>XAn$cd{OsGkqNktC+(Hu%;N+3n2P+#D$~3 z<4zs@EueY<Y=waC3osq|@#yD>lSe;CUOe*X<x17XU{}3dsk>|LbQV@tC9Q2>RWXN; z-i~;1^mZh#7|68Sk*aba`f(&HnEyCZ_TTL30j#XD%K9Mj*D<2%Ao^nQC6l8sZ;N)# z28E%<p`#an>8_hIeF7`17$4hgaN4k+%fRsB6yNkMtgH(4KW2f&L_uP6_&|E{OH>rV zCs$7Jux33ui-Dm;-NTx71Bd}i5Z7lhFo3hTOE>G|ISdRh()bt{UbBD};T`=6*L$Y% zA*id<eGoDhP@^K?xXYmdw62tYU5p9`XiY4~eg+l>MuzG4cvvOsCDWRJIFxcYg0F~q z&7J0GeaNNzkPE-danQ2LT@0Y3iFbpSL@FODQMU!1LQ^7X3+{{aI$9sv39^je_0(%V z$L`awIl-Ns*G%1~9J?<%b{{<Wib)l8^^Ed$?hB6H2bGT>e8mJhkwt*}!ogQeAPef1 z4?8wKY+z(y00}WWa$h|7irJC-0{6x4L#m+FjJ-TlL93~_4<39V#(n7UnKNK-bcd*L zG(WO;=|0qbsQH0_<G~k9j?E7^x=*=qA83Ba1mc4vI1WB!cHuq%VzM}1e8GL9`4J=Y z$%BtrT(}Rqa32D#Ejjo=!jby`B(PvxuR(QzLifS$iw9qbIqm@Y@Zc*6N96;}kL-=V zabExhAHxm?9tH---C*CHm>$o^s#)KC2z+jU<1R>W9Vk(=K3pQ@Xnm-J*U|bwsf6PW zP-wmuaohn4zSlgCJ3yiNn#F~G`!W7qj~I&CcY+$ZubKI`pX1;4h_MJHb1%)2`!xTq zM@&V`{M-Mfai8bk^@tfPb1lu0`xO7KM=ZtcJ3#H$dXUCrY1}9HcRgYSslEp~0Y@T@ z`!uM=5=e95J_rhXg&ha}GcbTdG0m0xV492afo>NS4pn=G|NkBNx1ZoX*y*Ce!M`p< zg##2S-4_qOl4yQp4+=xZ?>D*+NuO+fz|{Ou;rk7+8PW%u9|&-t=swh3|9}O0Kopq! zfCIu~;XVQCoil)3%0KBq^CJcB6W?!vv@vm?0NLF9;6U?3dlYLunw1zlx(^=qXjWtZ z4eLS=tOXrtc-SEra(*3T6biJX-0e35=tjzVP}9@Eqk9YZCL5n#(eo0F46fkYo%qc` zw+o;2=sx7r{m7T!^`b}XCCA=uMh|}1UoPE$efeE~cznO%EB(z!`J->^|56^0;|D;e z^S$&1-7e~C8O2tb;ljTSbcTm(%gG9H&|Rm@uAO|YEhioMrylm~KKxRdak}GQ7Int= z(=-3FDAqf%ICcv;c15u{_B#BtVd8J!0~$}Vy360R88n_~b%VbdwD_HW+iOqj_b%OM zefgcwzm|ho(REPefK3B`D`>HQ_o3#8_6HxZbzkJZ06HB=`v~aNvg<z9XNzSV`L`W# z)Vi7G*y+T=zwI!HW^?Qmddd9%zu14|DQK6*UknU_48=Cn<^QoL21tRO@7O8!{TAq^ zUr<B*><g2B|Np<{_UOI_y5R$~z819J*Z?&9o;B?sXv?SrxaA31AbSQe{mfd;JY8Op zRmx@mbkLH|lb~g=3ZRp`9sY~5Xn{7+v$`^aZbtj@pMUD%ZqNoDhiK3wD(KR(ZeC5W z+|R$|Z2v{KYEG{eWHqsT&cw*@U-YI1=)jiN1EpF2MPoHVLmF(Q@gCj0Cz(K|L3D&_ zf~LAbN04~*@(N6!{z{NlM$ro@sK5ZacDMV4M<;7N6X-yJV;<dC|BGg8Ojj3TRjLPN za`a<?`FL>+lb`&>z;Mj<1?U(r*Bd^)t_NOVI~Ew@RA8%L|NeJIpbe6%f&@h(Afx1< z@eB9}K4>$v2>7b)dXMf~p4}geFS&Go1fL?9e;?HKaqK?l)BONE#~XJaG(hy)L;Hni z^Pm6xEuiBFK!Y8SqxFpcdw{NK2TjQKhBJc8l@~QRARVABjio%j6+Fk>3>Z7>bY5rf zVrXDs0QDf1Z9szyKXxz(Fw`@+bRYGwegT>`?!N5Uea?m7_rQzmwcwGw5^;|i9@;NF zTHn@RaRiMRo_q1q`v3pe3Jw-^7A1nsbtbH(+#utRyXk<2KpZUU3`&^0>vTYU0%q_3 z|6gZTri1o{fK7fe^&Y4z^5cIgH&~%>cb(4bP!EuUSk{1CeB!?-vjzhL=rV%;qJruS z49DCo825t=?sPLjvgWmj@qe%htle%puUU71`Z?V{T#XNSc3%ORrgv|;t|+T={Tbr} z7K|l)9@d9SI6eL!Xt3d6DE$N~>mXCZFF>a$bl-S!2DCiV_~f_4_9brJmzy6kg6fU# zLypZSIKCZbap8A4<k)?p`6SD?!yJzME+@J#f^P0UEWqz_5wruL`6T1F!wN3^E~ma7 zW-4KI<lpsD*b&?#<AGeW`Vus7dS?12MONixZ8lI_;DSr{3CDvknH`%S3OMcqS0W%o zIUHM$Ir6()>^{|el7)ZQ11^5&Q;s`96%R<3$+7hyzsp6(-Jq%iq=eD2^)SE7sePbf z$L@>#yIu*m9^-epINd{uHQ%!b)W`2W(fm;0;6vu_i;mpa9KRjl02|J~>m`@tw*xHv zE~h{e7ahMHU;;}xa-Vkmc7PEiev|v2Bmb@k!u-zD*_BzdHU9i%U|=XQ`*zr&#IXDH zi)Abf46luju|5R}cgLtWG(X<oefmW|%k){wtkNDupp7!8558n>ekcHPI)`KHJ+KX6 ze?12I3na|Mzw0qKzcbjsjQqPE^YA;Lf_en3{P1)?C06z6hAOPh;trrC@x7pvzi;V- zdv5IAr(fJ=n|@k_)yguPoq?hG@%Pu^;BB1_Ek8>HJ@|J$<1FTS0b0l3{P_248;5Vl z8B4@K!d%7t;I&XMOxUN}sj@0C39(O4P-T^1`oT86N|jZQ544SzU$fwZM>p%vj||iA zsj<o_DS+10`o@E59uLrHjKe3;f^`SbVmFUZ{DLkj4%5G>vg%IvQfC!Y3jirocwxfC z!0<v_4>TKIV$%A*!~irA>EYXb45D{>yc(;jp#o^BL${BL$1YH9{UVVS+-`OO9sB6} z9#ksN@BR0mUt^03XrH%7<B<o`U#hdJPcC5-<Q4#p`<`^^WL4suZlJ+xXYh!ZkwJyc zhRv1V<)BL^>t$X>2A59O3%sDc{vORo1foGFxmbAgvTj|*z~H!3dip;N*6D)N|Nj5a zuW^iDqXc{oSH|J#X<Dp4lBbq3FcgcV@$0dkSjxaq#`VdAU-!f(4}Puf>-Aaf7@6)f zZGUgTYRl;P1hl#Hl25O%0Qi;*#{Z&5a^S&3fp3l+0wt^-{JV_Vzd3SnK$x80964AZ zOs;Q^983@<_cuq5=~YIo`Oct04A5kOIEY|v{>fM>@#2a-XgCABZi4&8aWF>_)Mo+h z(uC$^SI{EC8_kdHUxfadu5ZGsTrUO^`2bp%-hKM}#m1AM<=M(7lz(%d@AOeIXs`|a z3QE(e-wryID7^Uj`~UyfipN+TK!Tt_f#!$%Ux3&4mZ(^~<^b`ofmZq+12wUbSI<DK z2MtLq`~Cla^J9DN!=O>XBMK7HFPHxQ{~vtu=8JBS+yi^?FwJybOV(uOn5=)(CtI?* z>B)H{2ikZrUu?7raAja9<u^XClbeZwA<fcDf`7_^!^Q{T!ydh?`xi_Xw_=^arQ7!J z|CyJdwOrF5zGs&9QSj`J1f8+t3z~_0=?S_g;G8GuDoSUT7b&21{;n)4Y2R*uM>Slf z4>*3m;lg~trPZ0GM9`=Eyf5gQglit%XJ1TN{_j8N!p-U4)~soPj}`y_2VcbpJ0T6c z;^pRx$5a0O|K`k+R?6FGom`yzpp>=w2P0^oJ7}Q?_yWHdZ|3|1-CCyb;xU*}q4DCG z$^ZY;9j#eKrXRCry#%>+$JO|xPxryrOQp^p-4`93AMkrLKl<R<eCj`c_yNc66ONZ3 zrSX?ArSV@s;HZ44RM?~WkN|)90hn0pfs(iUdk%OoA9}eIH2-G%{22oS6MrwLH_N~6 z5XhYF6TaOy4nE}YY<~QK`vk}a$L>RE{CNlK9lK9_;x9PC05Z>!zl1rB|N0HEeFYa8 z()jZaU4D=T6~5r8d`bC6sV@KCQ~cp4L2{nVr&}-i@VlP$Y(6XiQpOD;Kt|k5<G+5P z^>)eS?!(`2C?EcRLiqy!-ctzm-3LL*hvTp#KmR@k>qEZ$E+-rtEEr0jPoHeds?NUO zv-yC)>qnqq5}wXx$Eu@zNCLD1@C+0<gn|!{01b76_D6PeykJuNKRwirwW<E%Owb6T zuZBmbhk{49tAR&%1jma#Ai>TEjTie3|NozG+!eG1iJ{vS)c4eg1rMi%f+lz!Ji1?b zbovH(bozR{=m6<~oNnOJ=~3X(y%%&xq(^r=$BSH$RA)qjN4KkoM>mH@ccjIONQl_< zWP4U+qw_x9trI}`vU_R=nBsilvh&~n7vdmA%?Skz$6Y}OQb1N(dNdz#h@T$iz$(kE zvFG1(MMqY#42u_xi~jv@u2o<Fjf2hwbtj-n%(A&!f~C~Bv06cab+TlMP-C@%B8b7+ zSgoMMI$5$*!lT<;<Au@WfB#z#lyGli1hqgmO#1hK!i%CAprGjm%{YKU=S9+tf74$% zuu3t%aG5-Pp*yRv<O{tS|Nb{u7%<dvyilI;@Be=f@ELruho^sZXBE>{F#7-h3?l41 zeKkC~8M`?;eN~JPH2wtT0RAZlI$agIT@|MLI<d+!FW~w=eV-Gn1am9b|LOeBtWs_Z z3{i{#`;g0{+t=a6wH)vcYF~#JE?gj1^AUyE!w}mHK=IP;>i}Ao82eI{>;Lo%&a9%$ zyfD*0asHp~=fWz^EMWM5`UiJbaprFZP{th?;}DFo0><crGGs~&klnNsbbt?Nm^Jog zw88)B3T~`o%uZ0HQWK`Yl!DyU?VA8`Qsoq=!XNq&d+Xic3KcxMUqRfi5c^UeMHn=$ z-pv8AYpp)aWRQlPpjlps#1vEsgzKttNhIn2XZ$~1(4AFO(i26E@kxl0#xPe(qDVK? z7BG}>gO=zry!fw&B@W>J^_&cIEGWw~*E%qiBsJH%FqHU0&jayH7W6pyi_NE(HR?O4 zr42qTy_W}cmeB>5E|(J)jtvj~d78phiJGFTy5!Q~a>Bx+8+_7jH^++`lOXPKh&?<# z(vvlI`T<W?hv^BqtPkq-N<ph77#M7zv{4a+uLR{!%Y*P&K<NWe`WBS_2BkUjA?jqH zv<{T^fYNbLx&lg1g3$F0D<BMpT~PW0lzs%IKS60O(1uh71_lWztpla)ptK0o!3<FP zLkYw|_n`DSC_M|RejS*uXJ9x1W-u_^fzm&qv{)g;04*r(2Bj0AbQzTHfzr#M^d2aE z0ZKoC(x0F-6EuXSKs0Cxi4WApULXMm28JRiT?eImp!6&#y#z{cg3?Ez^ff5`3`+li z(mcfwk4Qmj11RlO%mg}KnSsF%Di8&w)1Y(-lx~31eNcK1lwJm<w?XMsQ2GIs{sg62 zpg}JHr4^vGP6-pp|Dc645ElkOC6b_Y4wSBd(k)PW7L?usr9mTpAY25Ex+Eyw0Hr~4 zAY1}XtVvMXBQFSIF-Q`GEz}vnRSS$Zn8gU@2cXd)wIEzz4^a<dgYXGi28Zc^w^>EC zWg!wfptQs?2w$ZVV&Df;2;I=n2-YAXl5q^8;!Ybx#%DQ$!}Nn<Y%=v9x|qO@n9vQO zA@jxvl0_e)6XXC87T66j0d%(jh_3+Ug9<+oUjxdA$y-4Apw*Tjc@HQbbgKXZ=xV<R zQ~`zzC?7PL2hvah<--hUf$~A841(k*K>0BF1!(*YX#4|EKE%PGED9BXx`^Qhl+O(^ z9dud|ln=Au6O<2?X7~c-gAP>$i|v7g5X1ro1`a46v~>d{&jaOy69*`X3LpzGFffQf z`7jL<P(D}#0|SE$8eaj8uL0%5qQC^ohv~O~@<HZ<>}Rln3cwUNpz&Rxe2@l^4?NKL zK4|;^C?7Pa08$?U<-_zxAoyVW8DbCuAoUChP(I8-DNsJlfD9-fCZ7Z4!{iH~e3*O* zln;}yfb${tGt|HZ!1gmVK>08OTG03%X#5^D{sc7s6g2(}7$0gs!yKppEXWq1@s~jP zFbAzb<F7&EZ-DY)iS_^*{{oa>4@;#tpaQT&^8(5TErbS#$zDjRhRF*+`Jnq<K=K+; zKIkey5Z?pJmj!Vc7#K33e3*O(gkR49Q?LRezyMQl0?Jp08t?(imxA&I_CXv3?l3Sg zFjzqOpu;*qN+O_q&>lSyzX8gJ>0bcm*E2AHF1`mT*Z>w_0L`#~xC~pMd{BE2Bya%A zhpE2+<-;8K1<HpNObq)W4unO40F=)MGK_(NK>@@E#XrnN4j=(g{)Q?@fbv0W3qe91 zP`(O?!@$6>0m_HT-+=P9q4FFDAP#_;uL0%5LM-3_qeDF?OMnI~Kzb^m3P1;tf%q$+ ze9%+}h<^jhmj-bd7#My)`LLpz;~>OBL8!a}ln*OO(MwK)gN*gy$_J*w1F8XLK?al$ zOJogDJ}iwafbu1w7NT2#T+)G*pchmPdmJGyhGi>6!2nXuz<^XzK?I<Q5S9xL9AuoH z9Ll<$y|_Fxtt8%fJ7*ZHJe%kTsJjdfL5wc|(bLb?u&QtONoHkXgk`$v`6;Zkgq$HY z?~_nSO&b!!FnxC_tE^@PRAK=_0vuXNi75)H70IauC7Jno3=9lP(<i2|3QymV#>!%v z5yS+V#{)YSlyE`)PEZt2L28SD_zQxV7!1Iw7#LWm+orLa)U$Cga4>LyNJfbF7#SFt z!F)CjCJqKh76w)ZRu(YiU<E-2kOd6P49pB146Go%AZ;8B3``tM?93dj46N)R0nj2? zW_FM&R*)(V5TAj8iGhiOgMkBtp{_7uV_@R|W3ZhJ91QI29PI4u3}DOvG9RoGWB|xq zb_R~=j+v}}(+l!gUxdQSO;~1w`CBIv7PVl_U;>u@LE!*XClQ5E2NG9^Vq(ykzA=kc zxZdY9BwoOJ85kIrpz&Aygvg(P(sQ8l3!rqsIf(ogD6L@+Nfa(n8fNYjsQR2w5cMk{ zv?{}qFAxESuMqmedI<dkO1Ef3n|ZDsXCN{#BX!XDZ=hCmK<OSRodBg<K=gLmV%B2D z`U@u^&V<odpnMp81ImZdcc6S2{Q$~`$$x<IVe$;8Am+p51)zMW{B-_O*2MY`XCR8c zK<OV)`VW+5I17<yfzljMng>dYKxqXitpTMiptK8=4uH}zP&xrZ*E6I*7z`OuItNM@ zK<N@FT>+(QpmYP2Zh_JrP<jHCo&lwoK<PD58fN|$Fu$IGVGo$Wz;FagUx3mNp!5qU z{R2v~oP&f22b30o(h5-80!o7tIVhQUK=}bsIs!^3fM`(dlmTKeFfbHA=?W;_0Hr5D z=><@F1C%}ir5`})4^W!pJj8(lP+9^?D?n)tC~a^aT02=l1stHX2b2zg(h*QP0ZL~; z=?W-40ZK1`(l84)K=}ut^aUvW080Nj&*%UyZ#gbNT&w`4O`x<5l=gtq2~fHNN-wy; zxLvz~^(b?F!bOM)3!wB3C@pXaBAx)H4?t;w%Mfu`{Sg4=Pk_=FptQghh`IzQeE>=e zT!o55Xe|bC1;oI>PyrEOm;j|0K<O7ynqhikGOPOZ4K=JGj3%H8%X+&&Eo%nz^cBgh zJfcYqi44UIsi0)TkjGHMkiw9|kOR^oJAGLLYY;1_S`(Q5wux1Gx<)gr45RS$qs^?^ z%R_Tn8Mkj}Wo2OpR~U%uij^;ciD3oUI0jH<GW~oHtEKdhdl1KS+=tK-P+H?Y<8<X- zR!5FfhHS8&?J;v%|8Uk9e21um72p+6KCDV;fbwDevkoX9>=*_Hh8a*ktlhQ%$_M!d zWX}pHA5`gp_#2>nXjN0sumdUp>p&iW@?p)M6Hq>^nREfl2TdA-47>s5!y1MUpnO<E z^97VI08-4r!0-XehqRjN85n**1z^o2h98g+5r%5ufbwB&c>yRNbZI?Ei3F4nnxh8s z6`*|3_6HDO1ImXrvkahoaKjQ*Mp!@vVC^;sC?D2N^MLYUZT$c!Uk+qC0|P?@ln-mW zCqVhInmPl@2TiDfv=l)3poS~Reg+e08iBRNE1(KsP2~nCAJ$avfbwCTg9%W+I>>ZT znt<{(q5K6<KCC6Y0?OA0jbMP(Y=8>rfH({c3_GBFT`2zml&=rvpMdhsp!^F^zB!bC z1Io96@*hC?mQel+DBlh;$i~3%0V-e*RqzAKcYyL4enQfOBb3hp<vT<90#LpSlrI70 zyFvL1P`*2quL0$Ig2SJIfx!SO;00A+0p)u``3_J%=<pVhkO!0xTDk(_2SE7&APy)^ zK>1-%egc#q4&`S+`SnpyfdZ%iq<msvsDSce4qRXjX=gJ+3xWoyJQI{Z0m^5F@)tn) zEKt4%G>x%B`5Pee^$cuKfddc$26ia_0+i1I<v)P(IidUo(0YO!%KreB=YjGWenFy) z7s?la^7){A1u!4fgM|thfCU&B1fYBeC|?lDhn1{CP(G|=6^8Nypz1}S`~)ap6v{7v z^2MP11`r<<yrA<$L9s9aB*4JHAPH5l0Lqtw@;5;F(op^ZC|?H3zX0XSLirD%d^srp z1C$Ti0S~f|;WxC6pa4}M@Ea0jicr1+l&=Kk8$kKWP`(3{uL9)<K>4aregc#aIx!Ap zVF8q{4wY~C4eh~dLIoy36=*^E3!r>$D1QT#uLI>Dfbw;r{2NfdK9v6g$~S`Ye?a*r zP(H_>dWerrp#l<rAbik~fFKuZK>6lSc?&4t0?PM*@-3nK2q@nQ%FlrEt)cu1DBljs z@2H0g*h2+oK=}?({t77H5z5~I<vT<9C!l;6DE|SJ?+WFAfb!j-e1^Xe54uD7^#V`< zPpE(bl<x)Q8$kKqP`(3{?*rurK>2=9egc&559Jp?`2kRV1C$>G;ny=vfC_+4+yw>s z0w_NmqJUuolph7<AAs^xq5KO_em0c<0LssS@;^ZNjZi+rKS&5by6N={3<6LA7HAU% z)^dXMzZn=5pz@qhc>^e)3(9wZ@_C^A04QGo%1?mug`xZcC|?A`2j%|;sDKzqfPsNw z0+cTW<u8EpWug2XP`(b7e*((4hVmak`F2qL2Poee%4hfw34v@5X#Fbz6<~z6u{5B3 z7AW5W%4di2J)nF}C_e(q=YsMxpnM)EzXHmag7Q0{d}|(P{ks4vkPTI^0m^5DHrftA z`7BWW1t^~#%6|amb3*wapnNVUpMe2VdGSE`0#Lq`04V%Hqlr)fYp4PPD4!A9=yQPb zS)lv?D4!k5Pk{0{q5J|Up9{)wfbw~u{0UILR6SH+0aU;m%HILyGeTRDC!l;zDE|hO z&jsbbfbw~u{2x%h6qL`w2nhjeC|?1}uV;j|G7X>toKU_4l+Oj_2SE8!P<{fGZw=*F zK>3W&R%Zv4&k5zvfbzMZ{1p&>J%cq=U<X8iff3s3JOSl%LisnKd@d;e1(a_M<^O>4 z8KL8^983@&b3*wNP(BxwuL0)QGcYhhTb&kQ0R{$6DBlCh=YsMhpnOK?$X^DO&k5yM zK>1uyeg~A#XaXwM7#L<i`J7Px3J@QZ{<xq5J3s;q3=E9WX6p$kp9{*r0p&B=Kn#2V z<#R##KcIX@XseZj84?0qP`(6=4{fDtFf%#$gGMsAK$lB_CIMgyd>|Hh!1&NsWdxMZ zQUj6CfbylF{0e5K?cG~hMS1FBtwkq@LIzj^9U7Dj2LvHbD}>6!dZAD*!v&~3=r~D` z*aIm47Kj7t#6kI>m0(~YA&7Ykz#N8p1_7u*KSY2*0m?rQ<r_fxSD}0dC?9l014t+U z$_E`B3*sk0`8z=z(0C4%54w#GB-8-qgU%!Ym#Pz>0<a#!0x16sNHu8s0m|PG<sX3Z zPeA#wE)c8_bpa|r8!G<-%Fl-KVSP4mCl8dW7=$4~k_=M-?dF0a93&(Fm4_w<1_da; z79<JkkwE#|p?ugt0BoSZ11j$dm4^)kfT~%r{Si<Fus%-)ln**~8Keg`QUDuCsDR2t z6C(p`<N!9Z&;gZS1kw!ZWkUI&6WKsQE1-N&aQK6Ikx&89HVu%16HxwY5C=4z1MM-u zI(0Xo^4(B**iZ#*DB}fG9@a;Lja<O0)gMs##n4)ffkOlm1!tiKN<jIbJElQG8c_a8 z5C@e1p!`Wtz6X>K+JgZSih%Nuf;gaAK`0+|tq4e{0?NMz4u1v)h7PCzXk{@-!3-!L z)~j3r<%3qvf#i2U`IkW)1_lP$SPXQqhT#NM{vuTV29$pn%6|dn*I$PU{D2Cag7P^; zAtACA%9nuhLB|M#gfyW1D<BRiM4<d7P`(G0zZS}mfbu~bWI;k15Pm(wWDpM&#}EMq z(28%6PzRL18^i%6A}IeHl)nPX2c6;y650Xf-v)6Q7#L1K`JnS)Ktea5{F@*SXt@KJ zU(djB3@QK{D^Z5>e}EM*K*s?Y7!E*38en519Ac0V%7Ln10F{T0wManaGobRY;W60o znFdH66#vjNoZ$h~0MHFRAUzf!1q=)f#UKs?0|RV4jT_4MfXajRn}CEOpnT8@To6A4 z%3lZKfI=9`_l5F1#F!xSqT8SXGoT7U+onK5u%QS$5Ql+*VFgqkw4f9uqyf#Au)&-i zP<fE2K=QBwKWJN#;RIA3HZ=0$2eelS8!fs4RZs%b4N6qd5P>#@7+yf-*F)uhK>4tt z5!i?#Y{Zd691=yau@~6r6|`Z&AR%54QIG{S5H{cj8=%vG8juK;hYeA}hA=Il^3ZA* zK4b|S()57JgSS(H2793VK&W{?>Y-&lv^C3+0aXwLRR9|wgN?6MK;?^|^047ALnyxk zDqjKR!$za5p!^w7dC)~iAfbBL7%F6tm4N{^+yon6TLIMo+7}1Xumj2u25~?bng)zO zY*4m?%2z`9GoVoj8<D&Ll~0Gr*E7I|B%zH%h8Iu;X%GbrKcIZjfl45u6Ho)SK^z7K z1`Y{G6y`$t5>S3Klpg_gAn0r<kdOvc9(2GIxc-3+&{>0IL5U8k0CK?#V#E>JSY+^k z%Fl(WkAU*aq5KRezZA-^fbv0y9fE{lqtxJ0Y*1F|fGPkTdInN31IiBpaX{G)$_E|Y z4HAM4Yr}@UcR=NPL6V>@64b}AG1n7N`8udPY#1EWfdSdia099UHUtS97l)0Tzktfa zh9rML`JmP4ATv26AyEK2H5SB|fb!>qI1CI78c;rL3IsOJE(Q*NP>@3vL_jsb2HwS? zd=IF6B$N*uLxnb{86u$atx)+4D1SMWUjgNpLHQj}{v25S4;#pbjr`AmDu{+^Xn-a< z&_Fy$Xa!V01;hb0V4!@^DP|y{6HxwP5Ql+*;RcisI_4K7^a9G?0S<rA5)-JvX^<=^ zRZBsF6m<R=NC-Bw0G^5fE#QU9$ABb3WjnNi{}{^GfXajJlK}}iK>6TXGC&0plwZFL zBnxULLj^$BoPmU3Qy0=84yb_wm7fLW&w%n{p?uglyD^l%0xDkx<-<m;p*<Xi9T53? zhAyZA*tj~h3&n5(q5!l_60E`knyO(l12>@ZjbK^C+zPap%kTm!9|x8H0p){Ml7NH~ zz)@Py0AHBJAq@%gc#te8h@lpm!uU{mXcr1T7X$4TGiX5Nlc4HhlR2=-9}B2_0#sfA zWIibVp`A(w52%89Pz4E4el?W80_<W22H50H1ynv0D&GO+=R^53pnPU1e+88P2+H3f z4eeEe_KASRPCykb1aUyA7RuiQ<-dUPL7S*SLO-B<*xU(+4Ab(<=UG*)3}Iy@NEKv_ zt-UjpKKui^+=pixWN^!hL4iS)AqUdTnQkb{p*UUc2kWirD}J#`Y*%1nTfn@0g#a7l z_6>q;7nqrq7#OBki?ZoX-yq870c-6-7WqanH!wlg0rPNdhL|m}nGq}^3R*QJ0$Qve z&648+RaGwlRiyx>HK4Qsl(vA<AYb?&kOEJ*fI3y6s$`Bk6T=)`5RZWYCI@QgfC|++ z?o14K(Bwc(5*cO&h7ayc3?CqJ(?fGvD?tw9;a<?i#Gv8K#K7RpG*MA<x`7NEs~Lz3 zvYCN_ApnUD5&|g)(I5;8RuB!!SQ^eu)BDp{CAllQm>3o~Gci;^%-bN%#$vw%$&d@q zOc;iO3<2qbbvuy_UH~)rL>Ci-f(sMF52(RutSt2wE|6dV8Q_7$2Ju1aK{N;>8wfH3 zBnHBu)*Vv=Q$vdj6T<<}ZCCD044|6ev^)cYy8;74i~<A0R|N(JZbb%$)k+KuLaGc5 zE~*R+`5FuiB^nI%4EsO~69$HM69$H3W(*8(%@`Om%^4Wl%^4Urnlmu$2GN!b3`*e) z49f8g4F6jh7&QAC7<&5|7#{XBFif1lz`!(-fgyGx14H2=28Pv(7#KQNFfi;{!NB0L zl7S&?6$8WcRSXOZS1~ZGS;fGhyPAPPa4iEv%UTA8eOo{i(_0uAQnoQLRBmHnSiYTs z;qZ0_2A&-Z4C*@=7&>+`FihCVz_8;81H;233=E0K7#LWNGcaf!XJGhqnt_4iJOhKu zc?O1W7Z@0%E;2COdcnXT{gQ#f>NNv{>uUyvy{{P<uDxbpkbA?x@a_!*!|SgM44U5< z7>;~nVEFuvfkCDII|D=3cLs)lUknVVelalI_{G5R<`)A)2p1#6EG|ZdwOou08@U)6 zc5yK>2yrtqY~W*LxFF5Qa9f&@;h8ie!v|?bhVRmh41c5<860F78GL0J88*l;GVGIK zWH>3q$naN%k-=4!k%3K%kwHzHks(Bzk)g$kkztAzBg0}VMuz%LR*Vb>tr!^|TQM?x zvtneJXT!*F(uR@Yj}0S(qAeqXku4*GlPx1dkS!xak}V@ct1TnLOj||<$pl7*jR}kl zLWztFYZDn6-X$_J{7YnH;7?*?Xij2en3lxIupo(%VM`Jt!{sDKh8szY40n?l8J;CE zGWaJmG9)E4GUO#Q)-yCEGcqhpW@K2F%*e1hnUP^jG9!ahDI<esDI<e&H6w#&H6ue` zH6z31YDR`5)r<@$s~H*iTNoKyTNoKC`WP8%`xqHg`xzOs`WYDx_A@dZ>t|$GGK-O6 z-7H3it+N;zcFtmCI68}w;ruK{hC8zu8D7p}WcWRck%4(OBZJiJdPWAt*^CU<vl$tZ zXEQRC&t_!UHJg#)?Hopi4|5n9KwHEwfJz2g28IG*(0P~)3}?6)7+$zCFm#A9FjRnU zLoQ%o2sp>UuwX3%!<<G&1`&P+27!r;3<hir3=5_+f=)1DxG{r~0d#G2!YoFH1#Aoq zLBTG;DLuYQ(}Y)Fbl8}&#O;d4|97Cg>tYp?INec>O}(B0)E5R}P%Z-v$hkX*_<-D_ z(8b80SCU#$qLK@)4i#oGf=)+)i>VkGFu?4AsH*_oh0DOf%)p?RnUYwNr~<APIW{vg zfa+^K1B2wWbOr{8&5WQe@(g;;K_My;_0Hh&8V?jfXGf4=0IC?c{}zEF<_S{9kbouz z63jpoa|X3uHZy{kgF-C!1PL)rs7F-@wqyp1SOCa8h6S4$L4g8wbpWX7Vc3AGE&`-* z2dWs@yaOm=As}T8C!k{W5Z8o&6<*lP$Y9XVz@S$I3O)u<NzVW}<qyJF0r%%}T$mUP zKtT*vqf(ZiQ<4j6VS?(K5`=hFRaHt7sQ)D3%>)VVqLO44PjJ98NFc=OlT|#Uz?Lf@ z1d~-lAPO~5#31SnyqOp*<QW+BDj<%`$YNpub%P*$6>z8WO%@XasND@s2jG66Mm7@z zs1%2af!lx%+4W4w2?pHC@yKIh5MhTWB1jLVfr+7li-AE8VkZNr4g&S3!F-h>22d3O z>aauk#h}Fep^J&Z;vge~UQ#ib&k(@EU?Il9pjQAjq=1DX26QxVe2|MHI93{17#4to zu(&8$#Q@x0UeL_Ku)u8kIYl<(>Ap&AGVYR043b5n28ygq46G^a3=aet7}!9^>3cIV zfCg)k`HU=#3@l9y43Y*c404Q|Oo9ah1{Tv884Ls%7^a_5W>aLE#yI`GGMi+kq!J5* z0HYu?a{&`rMS=tagQ5Z(gTfPjX3;AG%p6C=m=(kr7_7t@7%qTpy1~Y9;|m|NXo@H^ zM~DbBNPLb21H%)L9H@7Pq!#Q7=*T_ebVo-vk?E?cY{Cu;bU-VQ85lU^7#Miu8NhiN zL|e-<F!&<z8QGW^*o>G0VCFD#GBR)`F)&PDqROTt1~LUypn%$3y-ExWb+Z^5dX=U> zQ)M&e;$>mrHQ{97HDa4yuEyp!{i+(9!gNk`HkawK>TDd-*BY>KOfS@96V~G7Wn|!O zVqkz7W~<M@;G@sLFl`nim}X>WW?*+>4q!5vE~mjJKRq>vO=5ax5SzgCkE(1M)8}fi zaZEp}$;LC?SD#H_`bK>=ndzP;Y$DV58nLlYm#}9OoGxp?roujrkpVPxI{iWpo9y(3 zX>20X?>e*bOy6t3rf$F~!NeeONyGr=gxQu147)8E7<6Vcf@ww$76y(YmI9C?K#6O5 zg&~`XyQCZkgIti*2Z;w_7eo#S6$mB>fK33krqv=D7<NQ5FjUQ91k<l07#QwHGB8X4 zmG=w`3{p`H3<^<T{`AR4Y?|hh0vrqimv}yKJ>a;&c7UaTIe`gm7^va&Hw@A;IX{~b z+(H5IXN5B`e3{KS{k$=o)AY4!Y&_F-P1sDQZ?j|*n!d+`O+pjo7m(&!cLs({9t@y! zM;P9CFfd&5U;xvgcmwe{rze`R2}^*KgM^ek85m}GLX@xbWMG(np_)xXR#KgdL6T9G zf%gOV1I`QV2UrVO5||B`0ze5`VERQ<HjC+wW^6Xod(GIy>m~V_7}$cC47S)YFbEt0 z8Op%mmIyi@{QrM=I)bDt14%g+200TR2Ej>O0U-4jM;JlJi~Wy*_7AF{eIZVe`XES< zfK1ekXJBZGXJ9xxhmqlIJOcwPoeJ`^OwaaU<J5!s=WQGV!?!pFhRx7`hbd$fU}X?s z6k}j10QqD3J}owRYmgmAOa<WFZNkow(8R!y-^9S65e&)Q$b3eAHU|C_b_RYEHU@qp z?t<wLY}q8I_olN+Om}o*6VU)={v-wlNo^hmnG|6LnGhic852PUnMo2K#2$!T5IP`G z017*Y=?`t#Os2oJViTwr;$RR85nvE9;b#z<#CL$FfIESai-m#9goA-Ah^;`<h?_w% zWe$U)$!rEi#wiR!9|RtNRRu6GfQ*{J!oa|&$i<+T!o{E%!pWd$!oi?uB>O@7fn<TC zHYbA=<17a551bDWkq6Ot0HjZZgJJp=P*wr^07i)G2=cSQy$B0YrX&Uio+Ji_UuYpZ zy(gVbl3d?g6YxEw3^#*}i5!CrqX>iO2jK^T7x)kG7Vso+2Y`~OJ)0~Ws7N+poZg+z zCIyKHkT3Wlq6~~sdU}Hmo8ojydo}@nAvOk~5`G3D6Fvr^P22&~FW9q*hVd{l@D#BI zVDom>3I>L!D;O9==YrB7Qi=l^WFo*Iw2AKlD9&KPB(ai#;owRJ27|eb)9roOB<m$b zIT%DsxEVxKxEMrDI2lBP1Rt!J&Irz!W@{K2eAX~9_@Wuk2r?YWm5c&x3<4>f3<4$` z3<5zs1%d)B3<4&cU^dKR&9w{+W@{N3Dv-?zV&V;eq$YL-E+e*r=>d9d64O`svI&B! zq20c0vN8f27#OlQFfd#Qha`7o{&WXFHVF@y4ga?>Fi31?V3>evLja>B7lWh;AA@8N zY80X7H3o+1F|lki!Z6d^wlgpUY-eCt0SPE6NIA}{%qBd&AdpRTx@{mEhrTE$gXj}h z2GJ502GJB|22m3x2GI`;41&Cj3@k|u44|T;;~1jon7$#AO_qtDWqN)Po7nV=0c;W= z&i#BgvFUpg*#xG~3}zEBf@F6CMs`L9b|(e~K@m0vkrYk_5fcsuksyHrnESYoF)%nE zV_-NumvQ?4QZ_LaAtnZ)BJKb|VMYdSsNEZo?7je+Ae;U%k4<L!Lt8d+d2ER(_BaDW z`f&z^yK@<*-}hjXga^jV;|vUok25fQhgvp0Q;$txdTc10z;szvHg-KpP{HEFzyM1) zug)+q{5b<DuE8|SQ($$||3$KigKJ235Fb=;*F>=?g6hHttPBj(H$<_CPCskKroauZ ztpyl(FR=wo7l>d}ntm^ajeUBfI-A0DUrjb%PF@Cn6CMWsN!-)x&Do@wABbK6RSc5T z8{^m%MPTKd08;rj{ap#0zBVX9JmF`MEa7924B=&vG~r>8oFw{zQG$a(B7~1Y!i0xG zqDbTcsO|(6AF?t|3=ER;91H>`f(!zaz_nokdjcD{o^hDYSivSSeQ7)!|MUnAHp%I> znrs}?c@5YErq>3r2|6-?61D*(k+Xr=1&o|b44jjg0>E?;6V_}k_=bT&@eKom;5@XL znD~Z)Vfh;d23K^6n{OBxINvfb#6u;lVF@Mh4Ff~`8wLjLd1xgBG)`dZu6<!(c>9Hc zp>iJM^z-p-Y2fl`dSDEj<n%HPHhxeOMp|AFT=a8-i+-3!tzQfbD}OOCOq$0yoj;CE ztRB=DTg1S?$ic|Kk;K4&Eu~5RVPGi!!@#f_%~2R7iwGx!$RqUnoq<76nu9^wgpWZw zNc@B71K|sT2lx|U?y2u(V`MnR#>j9K+3+By07+wR22~R!21!OK2EGqG54bLH9AGP8 zO<)ONVAwN_k)h%qBLi$4`^P^>%Ro|>lR-LU0+X~!ACoj=7Zap3h15}?<KeN$a};nV zfE7$<PGM6Do5skHAi}^P2@P&o7Wu=;$e_-}$Z!YQk)S562nQs;hj1{6n6NR37zq?G zg2nh5L_&BOL`--XL?#JLUvJ4KRgYc{qgDUl7+8co1{nDn8Ql398NQ;~FDS#sAajJ9 zK_-QZLB@oWLB<HuHh_ihM=?eQ4RJ;W{`rgy(`!=MRK>-(7{o&O8N^KZ7{r3$^?$<j z1F3A1;8vWBqy`6rREY?KREjWzl!*|7)F%OO-YH;UV3?ke&L#`W`a75y7^bhuVpE-N ztIoz=FR2PLR**r=M1Vo82w^O!Q32|@gIi2ROei@^66}8t27VKEaPtQi*1Xz`3^Ce_ z3=Z>AvjC$iCxdEAFoUW|5Q8eCAA|S<(E^bGQ2U78pFyhR3xkx&X9g+84-BCC9At3; zJ1j7{82F30;f3)^Wkv=MRYnFibPL#+8Q4si7}yG?pUYyC(-s7kJS98~k}2E_k|tcR zD(L_$a2FdhGE6pMWGI@?INjWnO=<epY&L%%n5?)FBSV}KBSR#*EqqK2d`4Ubj9k#d zMuLq&B7~hm!i0@M!bk+#UV{`q(`$0s6j`S+GDI*;UzN*d1TW%0+A=aQ+c7e9&j&XQ zq^8?Out`t9k<TUzYR7YD3qsQ`%rQ+4j103K7#WtJI|f#7iE}ZCrwB5Ln+Pz77YTn5 ze87K!_W&fwKplWWCq@P}XGVrAQ2k4s85#CK_^5TyF$YG5`wol@yXG@a|E<BMH2tDI zo5*z6A~p?>Hy*H0e^kt-<g~z*k>Qs+Bg27INHYPMkJ7paB^i*@LiiZOO?Vl^gJ4dZ ze#?qY8C-g+iE}WBr*JZehj1{6o3Jy88wnSH>xL9g28j?31_={(P`FOtUBae5ov)OQ zKNvk9qVXlMlvc2`8I{J!Fg=Zt;VU#8!09@ODF9pxvVe-x>9vt;YSZ=0*x3A&7#JAU zc^TA86dBZ0<QddW<QUW$B^YErNIj6aAa($pcEKey4+GaEwgQ+P!r6=rR@saUJPVN0 ze-Tr_^pbKmTTZYBQ0kcORKaG<0!kaxKdP{aOs~{q6Pa$Q&&JCJZJjNsViUCnwOLD; z7{FbP5*7xo6lMli6D9^wx0AmJsVN@-88!g*n81E2VltQ>V8|va4yyB=7#Prt`sodE zY_hP{4=1?9<6;mo;RKa{ANU^dz%z+*4<mz44<kd%0x&&2yoOC(iI+iyQHFu@0eb;k z0;>V2L<i+p(5fS_<w8sb)9=)<NeVMDFu;=o$RSM(4AUEG*>uEV>H5+XMuwYH7#TJ! z0MpYC*RrX?CFf3MWVkSuk>SAtFg^W$Et``bJp9-|<r%o)3~ShfdgUP81D!+f$YPp4 zUz$y{enA!!!-*_VJ^)E0FlY=3#Dh&afCi`jz~<9I5>ULL3!)cUT?Et;kP;2(88;wy zR~{3?i%pCS4%rYr3=9m?3?ZPyaW*hAa3Cq{D_~+cu?ckSjMV7KP@^Y9jpUP|7@4N8 zZeokp{>bE>S`u86SX5G4;F*_}AI>1n8k}0<oS#>mpOflbQk3J7n3s~1TEvhry}p@E zk}+rc%w{%e^N)<~AXT}!iFqkLnR%(<3`QW6oJ)&}Qu9gzit>|Fi;EdPgT#VMQXpn9 zFsM!c+sq~{J`p7Bo1apelj@e4lj@h4n;Oo*;5J>qg-wz<l*xU%VGEmhQX)tdNZzre zq$o3~v?R4SoPoiS(WSH?Co?&*Bo%6^5Q}eVPD!RyWl3sCet2d|s&htS5yL@7xBQ~q z#1h}s;^M?~komPB^L!GEOI(YJ@{1T41lguPXkimGox<RplV1!o?IDA6QEFmIs#kuJ ze^ORza)~1Y!#AiH)LY>U3=z|{TiKN5*D?j<7sIS@WMJrKf?DU4UlGpGK0UXUO;YqL zOHfIUb7DbBX;G?keqKpxMG3>->9avnEUZB#IboSaC8dcup?T$*c_|DG&!(SjWs|O7 z0*Z#vybN&Yr?|pS+i=UwDM>A2IKmo|T9liamspYtbrb``3TDq@C?~(jEj1BjUqDf6 zacW)(Ljg-*X=+hrKx$DMC{*&2Q=Rim^FSsUgF*#0+B{Pj%<GYaLo$j|6H`1>7#O&i zL8+y(xFj_<Br`YFu^1FRAQnRxvu9prNoHbBW>spiPiAq6M`~gU!vbc{VwcpU()9Gy zBA8RAf=q@)J|qIe85o#B;Q$E$*9wLd*5K5z5~P^&WON0&)ww9MBr`cNCpa}3a`4Cl zW}no=vQ!LlWk#3OoYWEwi8kix1}UtP^^SQd!3CLl;2>bQ#u}1S?3k02pUl8;1H^Vu zEeT7^DNSX#3E~CAc-KKZx1!WkhNFxi$|p0aD6y!L;Vj5Mpm29gNhty)dWL7rKKY3$ zP<hvia0UifM%TRL{FKyy{LH+P)cPWZc9x*T%;Hpdv@$UK2c?pL<dA$&kb(j)wTPjD z(X}EIo|&eAEJ6-Au+bmTGNL1cH(Pj7W(hcFF%&R+q$U=CoXfzF17<ts<YeS0Gh~4b z16dVPS&+)Gh0zTj2HQYvco=L4@!(;w6~qIZc7@r;**CEuxTGjEFFl-rVJD+oPHAxl z$V8{ow6xTsVg?4O>4BYWqV-}RtDpsnZ+=QD1H%uH2t+H$`fvt@87x7mi76o63=C7j zY^a8C28Mn{x6Hg0a2{ot3TC@y78RF(6oW%x8Cc9OwE`>@&ajTzvp6g<Co{zv6yk|$ z>8T87K!N1w9KgV^4P>>yt1pOs8zkx+04nwv%%>}Mv586tgQQ*a$})@c^Kw)3N+6B| zl{-hK2X?VZ*4KlwB~poY1*8EK`>DmnprB@8$N-6e92cBfmFil-5DL-(;zJ_8$hCrj z;TE(&0SSjQl!7A$q@01F7|aezg(OHXNL0eZ!ig7Tm}_2&e;P>Z^uS!!Wz%}t6huI$ z(}0>n3=E)y(jh(j=?4>86{e^3uzi^hT4n;?`VN}z2CcP+HLD7)Lzd$(f=`;6KBt#W zhvh^Q6Xa+<B3U{t37yb|J0c%$Ld+|;4WSKAF@nu95lm==EaFmVfzZy=8xz<KrYjh- z^H104XA@v4x&vAfB+ix(S_~ArU0?!R18e<{PKfH9xzwTSq2LeH+ybb%IA~o491;wm zrQje8x)%c)@C?&!rm>k=+d$7Vgo*Z;L!3SVN^gMD7oapu-3>FQ>6fRmsWO8YzoCrn zpQp2#GESSt#!{alz`y{S1}+d_V7Ms2z+mIegfbBdnh-S+WMByKW?}%*R)P!+8Qx3` z4uT8}rGg9$72Zq?4T1~|c0vpc4IptL28QE83=C61<_Iw`WQ#H|EbwMxC=g{}5EWx! z*yGK_fHeJC51t2w&3A(6M$m#jA0`G6y-J3GLB@xPVS@|<!x0$<1|1(Jh6geX4F6;p z7%Y64z-#%o$ucn5_%Jc-kY!*vA<Mwv;==@{AIdT?`1mj}JdtH!2$g4G2=QTJh>&Ms z$dYGZnBc?2kR#8)ut2_^fnkjg6T<>|28JR928J0vObjIo3=B^d7#J4#FfqJPU|>*G zWMFvX!^EJX$iR@R$iVQ&hl!y;k%8g2A_D`DFB8KbMFxf`N(>A~e3-!W4kZSLFCYgg zF)%z-VqjqLWny@u#K0h@%)qe6hlxQ!nSsGvnSo)84-<n$y)pyC6J-Vl5nm<-4HX6k zXB7qp1z#qH3>5~3&8iFx7QRdjTT~es-l;M$Xn-tJWnl1CV_-1wWnxHCV_?{?#=zj= z%fxU%je+5h8UsTJNR1i;gM~T+LxL|8gN-@^!wU@th8$leh8j%<h9YeSh8|xg@bv6- zJqCvQIlfE`GxQi34(Ks3>;M_0$G~tC#P?-lV9{q_DAZ?Q_~OgNP@&Jjuw0*k;esy{ z!x?=B1|tIoh8Mm}3?>E)3~mMt3^#n47(5IZ7@`aq7#{dCF@UE0(hL|FPWUo0G#D^2 zOfX<zQ1D}7SYW`wpkczmpyS8H;9$Z~&k$k4z+m9V#E@XZz>sLdz+mFX#86<uz))zy zz+mCW#IVMMf#I|X14D`*6T=x328O353=BSgObjnf7#NnDGBAYrF)^$#Wng%3%D`ab z$Hef#lz~CWjDf+$kBLFVjDaD_jDaD?kBK41jDcaY83RL!9}~kAGX{o7<_ruQ{OXw) zo|rQ*Xj(8Z)c7$m=vXi?6j?AZwD>VGlvpq@?6P2B=<#D>*ki%Kz-!6CFvX9FLBNuM zq0o|nVF5^uB?H4zO9qAxe<p?#mJAG9RtyYhK;~F6Foan#Fg);MVu-L}VAx~D!0-ZO zjuit#hcyGk4?iX_eXQPwfk6eN*@l7Pv@HXJfIkz%8CwPhHaiA}1b-$54m$>hXgdam z41Xqu7&``rJUa#k2Y)7p0y_qVCOZa(0DmTi7CQ!pId%*T9{x;V8Z><p;m-t~MzOMI zU?}ltVhFHjU`ViMVAuiDYtO*&)RlqZh(8lUJ!n}HzZ(O?1%D<60XGH)OE(6FC;m(f z9&QW_&29_~H~g6xdfXToKDjY4obYF2_yS^kFfeEYGBJGdU|`td$-s~i$ONWay%-qI z1Tryncrh@<`ZF-B31nhO@MmDC3}j$<63E0*6Ue}@Gl+pfAdrb+PY?sc=MaW^hADwe z44|&MMJNNqfdD23P<Om5l!0MQ029N4PzHuap$rTs0+<+{gfcLwg)uN}31DK-2xDLn zieO-f31DIniC|!u6~Vx8C4h-xP6PvkS`-7r8-FGSjVK0&eNhYy9sx`Y2cj4l)<!ch zJP2T7*bvRYU=hQ>@F#$Yp&_Q8f#CpXO?40x!-W_IhF>uZ3>=^%<zg8a)M6PJ1VG2h z#WFCI$1*TT1TldZZ?VQPFen5uF>u5&FzCiHFqnYU#4#{jh+|-|0htrWz`zmDz;FSi zCZ2)eay$dWiXbM2EAb2rGZPpX8iJS@<|HsMoJ(L}sHg{NNMK<2n83hL5X8jrC4qq< zIgx=OB#4P&Mj`{lwL}I6pCBfNCy5LUib)I%Z$g+DRFW7NZY47?6ofD_+(~9&Xh~sU zm=MAQrVUaV7~X_3F%+aSFg(p+V7L&<#PA}Af#G8w1H+yWCWbG03=Dq@7#K9dm>3ue z85rt0iy0WMgfKDi6f-c0mNGCngfTHllrk_VmNPIc0a;egz@S^nz#tID#9&dy!0@$- zfq^58iQz{T1H;y828M(%CI*f=28Pq1-3DPy3}@;X82alO7$U-$7%nt0FuZAGU@!?` zLYaOCO~dbKVqh=`W~yfZF^)GeFt`LWF`Q^(U<hkwV3-oj#1PTU!0@b@fx!UegJuSX zqiqZfH6S%@3=H!+85kr&nHUyyGBEgdGcc?OW?~5FW?=Z+!@%GY%EZ9X%fN7WA_K#Q zU?zqm6B!sZrZF)1gffBYrPCM~o&+;7teD2YpgO&tfuR8;F`a>-e<lNiNC*?dgqaKs z-)A#0YzSpy_%WM-0d!a1m0%_?-7uGdp&*or0Ysb4V_?t-VPdeD$H4Gz9s|RXP$q^C z^B5R<<})yS31$M*8VeX0CV<Rez`!tj0Rsa|2ouAc1q=-Q3mF&|gfcM*)GuUUXj{m@ z5E9J9(6Nw#L3a@YLqrG@gTW#O2HwRC3@O1(3<8T87)+KhF#HK(0@J+97#MhhnHVIN zF))}fXJE((V`A`G&cLvIIRisO7!$*R<qQnbD;O9$!k8FhRxmL9Si!(>1QcZ}7#MD@ zWMKFZ#>8-EB?E)yDh7u7Jz-1?HmevIPOM^JSP{kqrf02YV3-lc#IR&F14Hf_1_qsQ zCWeAF3=AjMFfb^DGl6NRwG0dm;Y<uJYZ(|`u4P~-2xnq=16m`yj)5T|oQa`j9RtIM zbqow^!kNHy=z0c*9pOw25$hQk&aP)*I1tXnaA7?|J;T@a3=Aj2nHZ2Ks6i9g3|kl& zUW79-fM~fb3=BLGObiNJ7#JG1F))NgFo9{+?F<Yu5ljpk+Zh;Aw=*#GL@+UAY-eEb z-@(986T!p~u!Di2bteNuP6QLff}IQuZo3#5c0@2S)a+tlsMyWGa3rFh3C#Gphk@Zr z1QWxIy$lRi`xzKmBAFO$_A@Zd+|R)9CxVG#&VB|4xq}Q0FF=ks$iUEdkb%J@l8Ir$ zK?a7^hZq<#BAFQ09AaR2dx(J{Ad-pU!yyI+!@~>=F_BCRCWjdq{0=iPI7Bir1RQ2y z$U4lx;1S8hkaL)UVSW8!1_qf(CI+4(3=F<U7#JErijFWaOh3ZF&=bkTFyjaV!-*pd z3=1Nez%=Vo28J1tObi@H85rIiWnfql$pogOjxjKth-6~OIL5#*?HB{Y0g&Ef3=E9N zK`WP-7<i5|Fqj`_VE7Tq#Ncq8fuZ_114Bd<6GMH?aR!F%#~Bz}qL>(V9A{w2ILW}E z5yb?iJ5Dh$I7Bfq%s9osaQhSk14k4S1IuX!1|QIDUlbEV!f6JE=F<!eJEE8vdQLMi z%sI`#a3G2abdn^)!_y25C!&}b-kfG&&^g1va3P8bOt+t5V7L**#IWED1H;ub4D}2f zqL>(NoMB*KI?KTD0A#^g28LwNzT9XghLp1m47<)UFmOaOF<dyyz~Fn1fk7ae3A}c8 z#yJKCk!U7{E$0{*UY}!NkcnnuusP4bkPTX29nHj$bDn|W+Ia?sf@mg&8z8X@3=9p? zObnpQeCjVUFxW&hF?3w4XJAmi#K15CByov>;lm{chL~t3FwJ+Ffk7vli9z5p14H;_ z1_qO8CWZx<85o{lW?)zo&BXBHG6MtG6$XYa(M$|HR~Q&{t}rkxiDm-RK35nR=0r0w zfas1Z3=DffmR(_Bcy@(>;Yc(S!+~oI3?HvCFr2B6W@7kqje$Y)Is?NUkml<Q46)Z4 z7_LM!F(h1PV3>NHf#FFs6T^(_3=I0W85n$Gm>3LhGcf4fVPKGmVFJ^<_ZS%dfE;>{ zf#K;r28M<hCWaUH7#QpxFfe4qFflkhU|^W^kbz-J3=_kYhYSp>9x*Ts_edBng_ zKk+F8!<%R(hAB@O7+jt+FszAT0@Hh5fNDl21`z%D1p~v47$$~4FBllwUNJB{h+$$_ z@QQ)q<tqjTj#ws!H?J5NHos<I_!Gm#u;n!a!^hVQ3<9xC3}0R|Fc`mKU}%YDVla8b zz)<*xfq^5AiJ{~T1H;ZY3=A7$nd%w#ykTIFe#^jcCzgpp<}Cxm%eM>+B_KoJGBEJG zV_-;#WdhTT?->|sVwo6N-ZL;{zh_{`h-G5PdC$OL|AB!)BbJH5;R6H1qYn%W7O_kW zPd+d(tog{m;1J6Mrn5dVFa&_qe_~)*`iX%-B9@6^#U}=aQ=jS?7!+ce7|wiRVA%PY zfgvM~iDA!Y28JVF7#LdOn85V^FANMOaZC&hUl|xcR}{s>F@fo=Ul|zY#4$1K_{zXg z@|}U<4ajHT85qudXJB{|$HegFI|D<^4+e%UaZF&^<0k{dkvJv>5WVy#1H+9tCWaOD zKN%QK|72iT634`F<|hLK?=J?1HE~P~0>2m-4*dc(B$ybE{9<5W`^~^$63@iI@tc9+ z=WhlEn|LOMKff6m+W#;x_{1|Ybo^mpko?QQ;1bWoAoG`jVIm_V!<Bd@hAE7U4AYnx z88{M{7-ldrGHhgKWY9=pV%WmW$e_Z?$WZT*zyxOOVP#~fh-YE|(Kp!`85YDdG2CHe zWO&5M$j}kb#PEcZk->_Kks&96i6MfEk-?dpkzq;#6N3vkBZC_sBg38qCI$~aMusPR zj0`Ihn80*2KO@7R1SW<Uentja0Y-)|2}}$M0*nkh1Q;2vBrt*KdWKd(MusN|ObinQ z85#V985t%dGBE@QGct&YF)~ynGBHSqF*2BmGcsr-GBH?)GcvSFGcqJ3GBI>WGcvrF zVPsg5$i(nLhLPciEF;67L?#9vIYx$`ii`|55<y)vMusM3MutC$Obk8Bj0{n#j0^{o zn7~VgZ>lmfcqG*`G2BsQWGGQ%WC%!N0@KkNj0{UaiZmD*PHQnT^dvDcoY7)rXaUWJ zCozHPC)$h*3Q0^1AeupkkwGGfi2+3K)njDPNMd3L&}U@OGhk$Rlf=YeV8F<5#(<IG z2gn=)MutK|Muv)HCWaD2MusExhKvk7$xIAK3>g`6j2Ic_Br`EgF=Av0HfCf<NM>TF zF=k}gWx~iHlFY=g$Apog%#@MACz*+%!jzHWttle|Pcjn&j~OF_m^mZEg=8iM33En< z7IQ|18_7&ydYd^T!-r%hh8^aN3<oS286G4vF?_LLWN5ZxWcZWJ#859_&B)MZ!^ohM z!o;w_hLPd94I_g?3KN5XEhEDYTSf+z6ecjOX2;0jk;25FVaLeOYsbh?lETC=!H$tZ z)t-@|0VHnE$lzkn$S@@Z)Y)KUcw*1UFeilxOlvtXGOS5qVlZ)FWGHfAWZ03y#8BeE z$gtXhv7X^b3KPQ`2S$c34vY*osZ3y6$&r!aO$rl(iz6e$US~#zFDXn62b>uhCb%#% z)TA<jY0yk{Mk*5nh=$EzgXou@j0`tYnHWH{jTa-sn^YzS5Pd3!kzqk96T_JpMuy;6 zMurKgObj8h^^6P|v5X9VQkfWd;usnH;}{uO(wG<m;usk|#WOPSq%kpkiDzVZoxsT8 zlg7mGCV`RRc_Jf2LK+jpi$q3-lq5z5moz3Yt)I-uppwSKV2}(7T1EzwG$w{W$&3uq zDU1vyX-o_;DU1yNQy3X)(wG<+QW+WAQyCei)Tc2qbfhveEK6f#IFZK0up*6-Auyeh z;ZGV9Lr6L!!@G1wh81Z{3?I@N8M-nU8Fr*GF-*x|WH_I}$RLo;#2}N&$dHuD$RLr< z#E_E7$gnkwkwGDyiD5?;BSUpIBST6$6GKflBg3CuMusivOkkR+fRSNBIuip+0V6~G z(E>(>CFx8ICkhxDwwEw6xPUa5FfzO<VPvpLXJU9$!pIO_%E)jgorxi$l#!vcf|21x zIuk=r1tWt}B_qR)bS4IsN=63jN=62O3?>GfN=Am#N=62W3?_z(N=AlHm5dAu8B7dc zDj6BVs~8z{GME@5su&q6su&qeGMMVYj0;ta3^o}|3?N#envuaHgNfloH6z39Mn;B! z3?_yZjf@OkO^ggN8B7dMniv@*TNoKqGME_FfHw8CF*1~7FfnwrF*4k0V`P|+!NhQ< zjgjF;8zaM-3??wWt(}o!Mg|kZj&??dfDT56Eg4K;`f+DHBg2slCWb$qj0~w=j0_Jl zm>3GW7#X;F85v$=Ffs7-GBOnQGBU_yGBK3&GBW7(F*2xRGBFtRF*1brGcuTDGBGst zGctVWXJiP;WCGIy6BrpXGMN}a^s)(z3^AEZ3<oAKGF+Iz$WQ<hpUB8yK9P~3ArmzI zGm(+OVG1KdM<x@PE||i|P?5>R0HS-RFfz=^WMY^wg^_`0DkH;^OeQd`J(ZE+P9_tB z&QwMQ+o_BUS3qi}GBVtq%E<5pq-Gi;gZVT@27xRl@LJ-~X^adCSxgKO(-;{xPh(_| z$YKJo+p?a{$WX75#l#RWosnVQbVde;EGF<$#Lv?i89cI>7zAc8GF+d*$Pkgm1m2D$ zJd2SbCX0!|U=|~T(JV%W245zIfLV+TVY3(+I((VH+YUgR20DD0z?%m^YyO}3FoD<p zgBIV5fJR1UGctfyzOV3S0@3xLW$z3#0+_%wXnp;H04DG{d(hf?ivT9@8vD(27#SP_ zn83@vL2Jan1Tlfvih~v{p9o?CFJ1<%<P`{I0<Y*bn9IoUB8&;NS{J+sS0bDVOoJBD zMuang7t?~4yDkZ@X9BN#T``xD!6$+Vv}zT!GL&IM1QVFPJC~8+LnISuWhcY;xr_`o zQA}W3a2_MWiYO+~Iz#XR!4<JgVA^#aBZE#H6KI(sXhk8zl~^V)T?tw(7RLlyBnVpX z#}E?71g2NlgEYi5ffw|F*4-7vGlAFNftI(O0ad~CAWO}95||ji&Vwu;Q%GcD04*Z} zt(uBRWCE|A0xi*clEegFss&o-)RM#mUhh;ipON82G81TJ6ljSOgG(|Km<BCB%1L2j zhzBut&1YnIlEMU9Dg<6vl#t2<ra^0KOj4P^YivMkV7{a=f!D%-R*-b0Gl5r<fYy76 zWHN!*ecV~V$Z#f;3B1gMVId;}M;6oegXh>!GS+`GU|@J>z`*d^fPvwq0Rw}IAp?Vm zAp^sA0|tht1`G^dh71hmh71f2h71gvh71e}h71e>h71g!4Hy_68Za<a8!<4H7%?#9 z8Zj`W88I-#8!<418Zj_<8!<3A8Zj`K8!<3g8#6GN7&9>F8Z$7c88a}*8#6G78Z$6( z8#B~1Fd8#3d^ciXP&Q#;kTGFk5H(?7;4@)hU<YkeGGSo&Y0SXz$(VuRHFz%*1H(Lf z28I>~28J8<3=I4Z3=CZk3=H`W3=9bl3=9wK85n9E7#Lg~7#PeP7#I%NGcW`@Ffb@M zFfjbEXJA-h&%lu8#J~{m#J~{f#K7R}6vMz^>cqgH=)}Ol>%_qD(~*JUsUri!G-n2e zerE=TMrQ_wVrK@1RA&Z;KxYO9TW1CaO=kuMQD+8*Pc94$uU!}z?z%8AoOfYhIOxK_ zu-S!yVW|rP!*mx0hE5mIbj>C$Mg|s!4rYc13kHS;(3X_|28ISc&_O{A3=N>eMs6@L zG)REX=VF*X?-iRkBja?vS8QTY3XBX5pye$Vj8JWi3=N=jqB0m68bHTCH83(XfR1^Z z!N|}6I&EnKBSQmdrso7BLj!0x_5((S2G9XFKNuMrxEUB21eh2aK(j#_OdxB-m>i&V z1cYWOU}9*P_L@zEv19sQkTYgLs1*=u2ZTBSp>9B^7ZB<Pm}25!p8oF@n;4S>l-7XK z7Esy)N=HEH3<zCc!OXy*u!)tS800(X<j9K-76y0NNhu5r3<if;7&KsqMS~7axXHq> z0u+c)^$agq7*>FM59P1;z`}3>6gp6T!FLvh3{a>+`8WQsFld6Nb71FQaA>nKXh8RG zfz%k}vNEiIos`1Bz;I&{E5iy<Y=I;h7#JEBvodsmf*H!^Sj)<gf#iXLjjRl?(|$lo zW^7|+SOJQC5Ql+*0kq@I73?6;HgyKjVdS9<!3>TJ?hK&A!P?E<vTZke%ig6|A5dA6 zk)NmFlUSOUoRM0jkd|Mh5T2Qrl3!k|5SCh0oSC1epjyn!#miL+TK8bZ%cWYZ5S;^6 zuA5ktUL30sT>v%(#w$)P$}A{Rh=$M*(O8fXa9a|K(n~?}p~dx9yj;3Q3Lszwb%a7m zMyf(iVo7Roi2~GhMtT(rWe~^ka_Jg_R4d?7Zj7QlLN8K50abZ%L27blT4rjB0?hw# z(|Nf<GEx;1lk&?_6;e{u5=(PR6iV_H67v)ii;^=kOHz|T>mU^J5=%16QWc6y^GY&v zQ*{)QN=p>VGjnnjic@n^lS>p5^D23{63Y@Za}twsQuP!ZQ&JQX6_j+1jg&yffxHL~ zgZk7wu=)9UIh6{KP*pHC(oM=Nftg*b!^@Rlq>z}BqM)Q}W&+lppPN~Nu1rCrBqOsJ z6mTV}MGE=gyHpf1ixpB*3yM-f%Ue=3^+0hDk`H&ILUBPoI3SW?mgy*z7N>$EKsU?^ zYDh6yn{Jp@h@(3=<Us^H^b=um1Puy>^30M9unCAjE=f%1<<bqaa`yKPaP*7R2N?u4 zpguzZ!-TY={9H5>lJj#567wn*67y1cxj^=#U|d%6a_Jf<DCp|uWEPh|HCQQt7L$NY z2ggo5D0&ni$+sA!z5uFTw;-`3qZpKIK$^iefJHz-=$WRFmk$dag~Xy%h4jp_)I4w^ zNK}BNdQi~ALqG>?AwnWKBQ-fYHANvUzrIKzk(aADBQ+^8FI^!gGcQ$7!M`LUwWvI^ zI8_In?2^GLtqiiNM<Erlm_Q-FNFhBZKPfQ>o>D<cke4ed6&l5<Dd4yZPEA$FC@Co@ zw$j&6$xklUgZNi3zbL(4zqB|rFI^wBRw%!`STCa_H%A#FtqVzxsYSYJ`9-==1)%bQ zmn$(PC9@<mKQA#yAvr%UEi=8eC=tX5+Xl)%Y56%h`Q@2;=?WRCIRy%!HA<iW0mm#P zPh0VVY7YibyYrwlhrR$012e-{=4lKtdYTM}3?tigSs4yx#z)f~WjK~I>oKrTe=WnI z$Z5!6#GnVd?Pt26EJr`1@%DwX9Nvt~MhxuJ-^+2RBFRh2bG+Do;T*dHqt*sS1_4F} z29Cu7izOB-EY?_TvDjmA!s3j@1&b>dH!SX0ykPN)#Tyo1SbSqTqdJHE^e6?6W%UdP z7#U<385nLXe6aAv!X1kbEIzUL#o`Z(e=L5m?87pK<s8cemP;&GSgx_$V7bL|kL3Z& zBbFyD&sbitykdF7@)^rlEZ?#G!15EzFD$>YJYZ$S%7m2}D+^XutZZ1>v2w!787mj8 zT(NS)${i~YtUR&OV3oxxhgBY{0#-$=N?4V#s$f+G>#BxT9jm6FQRGmN6<95?T4A-u zYJ=4ls~uK*tPWTmu{vRO#_EFA6{{Pje^%u14>+;r!kQav9;|r*I?eC`BY5}rh6Oto z99VE-!G#4k7Ccz+V!?+6KNc`7<X9-MP-3CNLXCw63oRBpEc93yu<*vZ2kTy}0}b6X zJYZx1T`)dfN|nQBdXzecCjXijYksWZSSztsW39znkG0dMD04)zeqdzy!7%-kGRFsK zT+U!*V3>YSiKAh9p8`kS^jE4JlUW3q7#yZIs&QD?GZ-*2fSL#wmfcv!;J^gF7|mm0 z!orM&9~N>f5?Ca$NMVr%=qSks$gv;^3s)>WvGB!0jzt=aA{G@as#w&pXvd-hizF6f z3r0vFURZf!<%5+kR(@FN01wEDRSQ;~SjDjY&^h*0MtKQ+(4rP527@MjHa1SJHjlRN zyo~Hj3!3!48#L*Co-VJ&5fn11TD$VQ<%|CU-`2@RO*eL%Vt4X;Ot^~u@s?Wu9CiiW z1x><-4VqXd7&I|gEMR70WMUFvoh=<cuTRnFktO@y<>jR@2E1_78F^S443ehbx94zh zQ8bWeV-96u7M5_yOwV*qEh<q6DJm^4Nlj4*%Fi!Ra5piK6X!KFHn1=-G&C|WFffP` z=QRd#Orcz;NlJuGnl5O_p;*8F*@WVZd%K^+df6B#8Dtv2Ika3=@1&ybr>+~3haPG! zw~bg`HtX!VYUvi<BL?!HrI%QUy$(AzJy&-1rpiyJ1TQ^_zs714#2+MoY@X=Sx_$Fk zhKogp7Ol^iTySX9uF{!V#YR&u3b+X9-EaEL-tw%(I=AqVE|2s(g{vnOWRo>@>(9N3 z^E)y5hhpMvlh>@r;@(6{?RkCj{Mj`o4)GhS(%zMy@K})+9zH)LqK`*=yZ>^7n_=%x zRmVPFd(uDdsp)gW)3+wa-RbLZxV3HK42KDohbxY6+jwMamV^bfK<|w!=1cTgYdgL+ z*$GT6SRLBrXmtHHOR-koM8+CLpDTOTNi&z$$5y1>v@&#=W$dt@<9d|ml0(l{E=a$- zM19Xff6J|c5#rxfV%+*uz8}o&D4S7c8yV|V*4{Ziv&!ScgGEBpX|qaB-Sd`v&X>II z*_HQ`CRxq1y~FUtRkd^5EEh@bx&u?TTuRJ+ZG7|SeQy?qGqo~P5BGmp+_Xt>`|kQr zS9=O{924qSZA_MMnJQJ5RQIi6!|xX<%Zx8}vOnCr{h9L;i5<(z86Wab;Zc;`6r!ox zne&t{DA2uRpW2#jj-~gi*2MSPpWJiVQBWxQsX)MM!=tB)#FRMi*Z7p$C%;jQKcWzr zoxgE)TettAYp(Hg75*%gJ9?mh(Z)J1wV7X^Wa`h5)%|*NW&I}Er_xN!j0}v6oeUfd z_}Q34WrZ0T|Ff_fFf%g#H{b&a@Ph<cn3)*c3}iukJ{B<+kvG>LH(e@>P4T&}mu~-j z*Nk;C{QhXEnz@OIkzse@&DxbY`^1k-ls>$05kv3elnnl`^X2Obe*T^1HM4%_$%+^r zp7<xvL^Q*=%{*gWk{_&{Gfg5*TAA0j@?~!JwU8f|Yz{g*tdkA+8uVv^_3jxnGqaB$ zT)rY>iTa(nKh@V6wC?<t?rUY&A8Dx+?DG0VEc2<i0adk0id+pRiqkGGU`>dBv2@Gw z^((&Tn$D?->bkbbV&><H?k~QV6u9rP)W7SQ?cP|#dqBkKy+Nejx(9`y!k%PJ&z}^K zJFPdPYStz*kt()NDmys^1Fmyy+|gOpqMYcY`E>EwMGB7BFV0E1`AThJx5#xL$xQ){ zg|_y-1<GwaUUwQVoiUoy!pp%qUB>^wyKIFLgG&!AO$1sMMHx9>gc{u|^t`Dd9^m_I zpKtxe(lr-O{dU~pymZy&!>lg;I%cyU{d(lOLpeByEk8Z9-fgRoeV#^CrP`$>E0U&P zl6&;lt9y_1Uw1Fw`{`+Qo1z^rSU>q<{e>m@<@-Y+41o)}v`(I@ICJ$?JB!5TbL%}j z)_<NfbKB-;iTsyZ8J-77J&~R|S90ObIU8qhWRQD*fxq70Dd!~Do_Ef_tO}Q&@KsxC z`nNN7PivB_(WM32A#Z1eAH4lb;JoDaZZGM6#%=0TgI{dx%#GfYaYgw>ci^J1pC6Vr zEVw4Oc@IB-aH;01SHk5_?)5Y(u4NZ+7hKzJ%YLzR&-u@3bp}mr8w{FQW<U!=j<pV( z5-!d0nICsnY~|j`>u#c@8)z9uWNBz*XkcPw2`URArJ<RDiIIhov8ko0Wt2hY^jB6K z>Q0UZ_K<Sb0;61YH&FmB-Bbw9OwR)~NrHkMO$;o}6oNe*jV(+Rj0}tn6`UOnA*JQj zE&5IuG}cyZkG*OcDZR17>8o+iYum=@1xI%uX;m|rzoakYM$FgOCMxU?z5Op&IDZkp zE_dtarK{;uLH>LT!~b;5JUH=8BeR`vflA8e-bWm@Cbd2d;X>KYvu1ueYAyfi{b~0o z;blIX85LAN3taBr^qb>D*Mqs72U3^+n$h5CTHkIPDEVT7Vuh>T!udK6B@RiQIr?t0 zXMvMZ|L<e3WIm^6OkCva(<JB-lyOgBuSj_83kl)WqxGBoTXj5^gteGn`>8i)6@%zS z^M6uoQx4UfcqMK0?9`zz%NH~Al`LIvxovfV(Bl`^c78W}cxUYsi3K+fD!aRHUdW%f zcy;a!wr1(=^;zk<m-f0yO%iDA-(byo{rGI7s6+p=5<<E?4^Dpja7)aC{MTwfd#-N! zX(90J)wzjZ_g(&-KRMAPX3u0-jb<~gG>!NT#pk-!RM|E)Uy1o9D(Uk!=|P<Frx!2Y za4p}!tUYm)S>?X(YdPdfm!+QB{n#VmbNNK6f42h`xt&OinDMoyo=ME6S!1nb+nX!f zd4n(faDP^6(EG+<a+%1oXz$pPL|=QMiDmcpN1QGa&~*H8^=PhIS%#paaKx-TYTArn zI(;K=SDbJ3vU6~cKiL>i+$x}~7@5$O5_0g2qSOlu$(l5ovlSMu1~dKtC;R*CUd781 z>{t_F>%RHdwl_USoJ?nO1Z{Z21R<qm6Jw-76JzM~{f-=>_J~q3!~DVPZPq{H1>1iA zORVPTNd4mH1g_I%m02VV#2T;`o6~eT)cDKUIJDUqSy|Z`8CkLoGN;eA<xuB!gb5lj zwV6)8Xv?9Z0&Nd~ngi}8ddWp42F{=|S)Rqlz{<d4f!P9+HlyhubU763(N*Rc$beKT zu!tH68?dvnrZ@61G8=HPv4I#YjA)q<TzFe4yV&+}l)dZUV>R<~*aIf1r9V7OKI?3I zR+9F8O3_A!Q|ogK)P;rSO>mj-{deBt8nvtDd#qwTa;ILk_pJY-zFVx(HQ?`@z1vzJ zl+~FRo>uxEwQ9oouamPLzgD<-HK4L%R#(@-ZF?7bNYvfA(I6!#DRDM&W@Fg5laI@u zA9*4j@BG7V%KtJ;+j&=Jp7*+|@j6~@;nWC^t5W~2tK0vbaIviIuFQsnn9sZ`-aY7C zxYzQbh2O2b-DY!tKUEBlI$VG1W!A?<cDJ2(7@zRB5ScXd>)mr9xi@2(MC2WeYnUHR z-E>H?v^eOr+l?b8GK-da_nyr!GuLUgmpZ5RQexi(_6^SUQ#%xz3O<}U_5QD>X^ecQ zMd)|)u5QkSr@3DmO8wW9jIk_yxNpvKF1BlG>Dwng^NYV%wZ`+j-jb3@Yj4{ush`s( z|M*~-w6^m9{;jV%stdB8E!g$f%HDO^kr!eUgSs6Lc(iy=^Ih%Y@VNJbsK&XsA0@)r zwe$s!@NlHq827K!=&?E7-@(nh-}=irx$3_6TVJ2v{-Ip>*>es1HA3r_>MP|q{%nd7 zO*@mrcj{={;csfjJnY^JF0(UbWjPplc$?I(2vpd;R=SnrQ6z8fDb@h(S6(vnmi}F^ zT%N7u`KN0^6aKDm^-%m7ZoOp=^V>GpFIy7x_Gdg&OK5v_V*Sd0Q)HhfOIx*tRrnb+ zv6mY(vBpCSZ+3YR>23pF)z2cYm3b~)yo;P{xLFwtG7Y&6I6;N&^iNhC^7WLLyr34Z zk&%I+p*g&aH!?LaG&F^k@ij0T*@T%wgAMr&ctO^42($SYrHZHL=NSqa2!KS`g*lx- zJ2;9;^7E!2H{i&wUm<fr<nk}2*<04lzm@fO$z>7W1Dr>e=j?bfDT(1|Jx8*$zU`!D z>mC0mg#R!&e%M&(?wxO!PVO<62~Dw)-#K-Y|EZt#9XmgGbFnI2NNh-TUm(CfajNRa zV`4%@`%OQk?GgIek$Pj2mDJ+Ib6j(O$Sdjz>Rk(3W9WA4a_MW8J)0csqwX|*+M6ED zfBAiS#|#se9m~v^-Aw*}dviX$`PTe*<wqyU@NqoyXI}U*aNV*wF`esXy%*S|)!ZOu zedr{&^7Gv7`{PeEZ+Q7FvEx@osc@0OY?TvAPu)+f>t6Nt=gk|<$uF9WX4<B%eCB1@ z_#;_#^TYoQFILo9ysckle92?`+I?^8osVCh*Lgz!dXc12NlF-3<-SH8zFp;s4f;Hh zE!%fS)bTFAc;{r{0WPo14St*Ec3if+_pj%!zst0R=20x}CZB~=tL7+gH7+%k-F#VE zYv+w-Ru5sb|9;nerp&f{`gm_kb*7Kk_irg`YICM%%v9baR=vrqrAl$d>N%CnMb<XK zS@lkL+<ZRG`=mX&_TtyptSxffuen{1i7M~0ywDuCanaqbkniy)K8Tf{E!aANdDd3l zjq|gl_ZMChh&}PLVy}0ojl;TA0vogW=VwN|o4LwAs7B+nhWwOC)eq)3CX4?HdhmPp znavx&UYmIP=M9U~?^`~edl;-!{E1Pt$wNW<T<uMzn81B2x|*TIITM>f6B83kQH`}M zM-=tj{{~mdPUm~7d^2_XCN(iNPDvU5>Gj4OYNCx>LFKGGOXFID##IKv3j!DTxA}t0 zWD{ta>}~>Tb3mIM&=yB9xWNHxZ#X*|>LnNDz;!0ra!5{J;Kae<K$3PlkSi2e%neKp zjG=}6^tCn|x<ZXpVATpEBTHkuL1PP~wuylW8!)v6fNL8KVlABh&V)m`o{5n`CjSBZ z)c-ScCpaDV(A!>Hz?!I+n|WQ#PdVn+Zk08cUf0z6ZuWlQIWfaoj8SBf>GO*=3t3D( zmR%NlcJq&X%8cTN%Qk+>_O}a-`N(}<)581n>yrmQXR#RjSAK5m&|9X~fB5k``6n|c z7w>TT9i_vX{nfO!etKv6X@w~|3<dS6*&e$c1<Oj`+lMNa#1=-~atL_2V)7=XPa2=2 zGj2y0J(mi+`D<^e&@-KDmc_PDM3#su%@ywRTV3e7XtQUWLB5ApLBZc&QJzsU`)A3$ z&0Esp<m+kdQ>^%Lzg1Mm#h_)c=Y217&zY+{v(#!i51XZ?-6YZ1>@q)=*}K$k+#9{F zenG|4ARDcl8y}gq{)>*5;hK5iW6PVH_ey#UuQao2{5-K?>G$IoC01Rp?G?*9esACI z(8c9`4+?wwg%l@SeoSPZxP8Ssg(vr9LOxEN`gT7<^eUqe!TH91Q<~h*<j+_9b;*BC zOif7tHNCa5ev9Q(UhXV<u4+`uzBzl<TH)Ne@gjBg>i#VIB;{Q0aD_;7^?V83^l*~G zdqrInzWPSiGX;N*R)y^2%eK8e;m8`}zV0HGdpi%__~H{7cK7q?9a|sYmi-YYu-N$3 z{EgY3f!Alg+`fL>;}azxt++P2s775sntOcn|Bu^*SfA{RDCjDRXytsav+Ok!uV%Wd z$IZjackNx>k1i8Sxb^a}Z0~EsCaG-(O;Vef7#R&}p-u2K$}0jU0c>?oLYoI;Dl-cc zBP+v##uL+bnQ>Uv>%#|EI9UvpSQO%`N(3`r{|mWZxwqk@FYAwG%3EKtAN2S9$72{F zdRXSXK@1z0HX9=gW0N@(Bafk<fzJZB1{Ve=hEj%1h8%_x2GHTeK@6!3ISi@LOJU;~ z${36p^cY~Hjqwad3<eBF48{zG4D|+JCTI}Sa3NCz19BC~$jZRd#KbTw<o|~Bok#nw zs`oM<TF5cm>%xi;75k0P>~=oAyYA&mv%B}Zj`VCWvrvs$f4TbmoYn2?Tp!oozLd!G zJ^177vw5|@b@n`DdEuQM_oe3kq6fz`_a@J~7;3vDch+TAE~k37w|8D7ZVs9<pS|mI zik$t@rAu{By*%xn#(rM^#k8FTS3~}keoctjv0v@{^k-@7IrknqDlf;|&t&-UOWm~1 z{EMzWR(@>I^vT<C`MvtNx!>14-tMyOpa0hBD(lxiIoT_BGsAYvm4%NiPnDc|uXk_j z@<{XBlUuKy3F_a*u=uP=l<&rRcVA^s{+#ZAAH-9dbP~2jDv1_n3r&{SRCd$(X0UN; z-^RP1-=w50cII>6Hv9UjO5tVFy0uEr-Yd;{bG=$oY?{xTiwB;pj=aTj_RgmGg$K`h z9KZZ+Ior(aupXwv)2^n^*I#HmYr!<{bTh%~bw?j<Y`dWsYksVEM(peap-2<2=7@Uv zzjv(Eg=OuMcO5P=F;e7D`@y1TROl!+-DlDV#<Z<{j7>eJ*=}yWtpDU4k6I)++{&9N z{6DogF7L`0oh8L(&4TWX;_ve_LWEg%__<Ez%zv*SB~ks`yRUiG!tJ-O<n3iX^Q2fs zKx$!d&W?`xl9RK!#qR8L|C8@?_LiaSvP(<rg>EZ%&UQSO^(yr(&y}dgNsIk?m&BQ5 zEZn(ScS8PxORL^X_nfc2y|78#-k?d`8lLu;nHde6#I+5Y#MR*m7&P`ME@99lF2cmf z3~t+SBBgkPayD-0ASI^&Bg=vemNbJDrs?}EITY&U3<b8cyS<hAU;Tb(<FupJAN;*o zzNy>|&QY+Ges$s83nl@#X*$7zLO%ua=ddlBp5eAig5Su%$k@=pz{t?p$k^C0YC)4Q zr$H0jA%iBCRnX=itIPV&Q|5A5F57?GKK^N<7;@SMHUE-fjWKZZFWTC`64dl!7B<4x z@rKrXpuV<|shI+3Z*Oo(Vs1fZUb=#_Be>ybY+!C^0&n;kn;05^+y?60Pk(O3;l*eS z>6kALc5Rn!?u%Yy7qVIT!TI^upI&+%yO59bj=sm@=~dQRbJFi5iAEe;IazS|*;Sje z?h0sj$t5LcUXGY!TDae8`s*nH{W1!#j?c2zpO*GG^LggK=)>2v6=V)hpR#3XK;x(L zr`eYoWSnYty7i}?Q)SAMCaGIlyKY#YioGW((fZr<RXuNF&fI^6aYxu@*?c&vSIIA( z7WDYUHM{s*&X-%hUO4{ELpRQ~bXw`Zy8;WPn-A`I7BqFM`}GP<%j^dgk<%Z$XnS3q zdhR`k_^YNA-~Y;wPqn?<vP3bZ;Pus~3vMNE)_ckNZq+xHud;h)%WT>nfB(a~vRcEL zsqUe3y;StqXiwiazy8VJ>S8;icR?n<uk3z(Wr2>#?8o==QY6{U87K0~Yz;iS$|tS4 zBO__|9!Kd4$=oM5`5#0${=TtM=V9RbEo(*DL|!Fv2w%>Wt4Z;l%YXme#kihTs{=$& zZa%f=`Vs34m&Hr1o&FZrzProyztTjYZdnXhgb#yVYi8;3=9FutXZwZf%fgnb{JMT5 zTXEM5d6OCXR<E)dH+=uC)%K=3$YSLT&V_}Wathbm?Z}^Y^`U_9zeIPgo_`;<9lv_~ zUXIF#{Z37%78KgfnKYSYOJ;#OumAR~W*1M!b1W%X{D$kJpkB&@(@NT>K57UndIr|9 zrCqk(_v`gUiyMLLr>1Ow6tM8K)#Wb1=F<+<(3Tuyw?PwQ`}71G4)b~iNE1lXKpfuB zWisGq181SOzd7uTC=I?{VmEVrTlI@I%Vz19_GBsa&pVNCfN1b7-S%Gi`TMgMQWjnf zTbXLO_}<mWo(54M8{}Dn4FV1P7x*slZu11qrCI6gCl}=yPyemUA!ZG4Lj^&GmV!MT zjZDpu6T7n`xV_gn0oDKmwac0f8XKmAM*$*W!UjxjKHzqlG#)djv)ggVftq5CQrGS+ zSh;nE_@07Z|1O)1IX6`QpVoPD_EoIXq&GcEOe=SsZ&-2j`QxK+)tb5r^(F55ZM&Cq z{b9l!?YD1jJ^FTJ@2ZL2dnnO7!?S$x>j|rbuB*3x?vtBz>yU%R{MZu<^i(TU=W4N5 zwP?=R7GBwZTP;j`!{_CD&3SIjDD$rm+Zl9d+gyv4jn8u(V|p?#?$kbVtor<%Ulorg zOO-9kEWI4?#6@VI0`I()E*E}0^(^OzQarll{EVqmA-i_&IhZNA>%7>fW^<Fg4UTGe z??p}bH}1XCTV7l0x^QWPS{AeGy_*4B1A5kn?e#hO(Cw(k<+ab984B*5nK4hYllj$^ ziRSh1eS<!qOi(-$=Kl7Upm&ea;f`k!kG9>m`x(E%>019|@rf5#9SD8gwttPfj^l+{ z#$GGTuIwzDRyV!U!Xy6Fp*yxl_e-ytrAKxC__qA`Q-4z%hQ0gdXysHg-nr%S%<7(n zHG7<8#Fv_4!_Wl{f~Q4z>elV~x8!wY>Z*)uN~f$}&#G@S4c8Dmo%zXV)}~80tafa4 zYs=mx{`W|Ej%d!h)$5C`UU<4~zgmB0o5g_}Z)Co1Te!nn=f0m$tz1UIfpV@ZOb=ob zc5D2%cp4OSZH>5+vfr0Cm&JbvWdCO`moJ>|;&^h0+vOainh5=L_tdA-#oK27%+_IZ zd+#Xs;Y0j`+c(!vFmG^K-yq=FWzfX7&Y+298npCgH#6U^5>j)+ea&BuG_AO3^wK+t zlxZj<BLib2V?^0(ZeVO=1nZP1g9l!1C@KFTCHt{9Q#Q}d2W^Wy14ECiG9URg(R}6f zz=hW?HD8?PvnY4LhBM7SqrM3)bP;umU()e8<5%tHIi1|~bLHpp8_Nd>bE_3k%l#3) zf~oee^Olxdf**@FZhoiT(9)$OasTx#+au!jt0lGVobIIey$ZDba4qc0a}C|smp5)L zeJ;<I+B-$F{_@Q?nfGr_Xm?|%zU|`Jd8Z~Tyy}B_<^0$+r(d+BYzg{Q=KejgS@LfD zmJn{mj68G2-41KwH{J89J@?g8DE&R((&U^c%Z|#PHRFxB`b>Jo!ITn*<p+w6?(&o0 zxHZDJ^56CT;>l}tEFUfPxb|U#q43IZ&1vd-U)z`U`<01?suk4FP^(`c<*wlT*g3hO zx-?H+b;1lQ3&G9bzRi1P9sQ>9o|4GTCavR>_Aj{i*ltnrujlenIa59bO%>FRC~?qO zUF>}BzSlyTY>T6spHHotR_v59f1BIpxmJs>GC$b=VUf)#r#liJ^&%$cFZrx~Kil>n z-;NZmU!@u<j&Ggzv(8EL45|<K68PE7)3;mUl1{j3rS^)?t_gdTdn3NzNxV1tpXGs{ zn+%rvTz@&kE5hzFbH~5U{g>ms%Y*_apX}kWj_y)gaZrupr-*<Mb8Wox?v%&L50*W& z`*x^glf4{g*_+j|Zl#YB7DsS0YB2D%guFZVGWJBAfzV#Jd0Q`+?YzX7J(K5>pz)To z8(}4TtU(iFB>Ipm)>2y@R4n5ka#a!JFrfONs~WUmh7Zr?7+|Y|rrS6}%IMn2z5|oD z<<D5@qQqF2cI}3u)58rCdIG+}=M93-?U(p{JRtUwx90DHF5Xp|nSU}5o|k2RX_s)~ z2KUpL=<B)dzgiSjO$^h|ZWEf8e<Z*sNtTDBX@%I{m0{;ai+dTBRL@P#w0AH6T~s1+ z{r_tJE}g2?t!JI%-zIEZ<v%g4exA;}2VHBP{_WY5qSl@>Y46;c3k6&??^o<8_1_is zeWk#r*q8q`LOMTO?J6uwy>;e8(PHIa2h^Kf*3DFxUacahc5wSWt=He?ZLFNxxHznB zHJ9tj`$u{gJfHFV_p-S~>yI2icrdH*<}u+0&Li9ApKWhf+3mmBb7y(l#E(UDUV1YH z)h{=%n;g8xT9(6;f67_Qs=NPHlV_^y*xF|=|Cn~z@vQ$ghuMmX4i~lytDL<fTVeHN z-rA=og_EwUWk0bfUcHRbf3LlD#af@WzmH6<e#;eaY}xKuQDyOR&cnOPe`Pf;AOHE{ z<Ba&<+BfPxxy>!rkyF=EyPYpuEhpJ+wqx>@XP?CDXGWeX_+Y+&2E%;?F@N>n3F%@B z({|krJz%BTwqeEs?YC1Mw_9Bmong2oiIbmeZ{tnjfBTnQ{2YFB56iEndq($JIzKR+ zjXm`9f^t0r_meUvwVNMO%bb>JwsX2`KdYBo(#rp5#<XvtA=>f{zYcuj(|&sG_ey;i zQLpF1e6qLAEu@SWYJYost>%wG6Kk(Q6H6(yjOLpy(f9L$?(_Gz10HcWNJJr*(LB=+ zYH{Ss85w~V03b?ULqkIYOIXPZDZ@t>0E{jGAZ7u8BVqwS6Qh+u6QddCA^=1a7~7=( z^m&dPO8jUG1*ZRS<f!3t1(m|`EOrJq(|0>@*wzbz_zEms1{?-#Y%HO&3MfM(Jgf}N zO^l2T1q=2&$Amt&h+nX{MA~+n*!A!G!`b)FTC=cS=S^$eN~zsSKiZ`-LzLbw=_t?L zD<$$p*sDrkce};=FaH~M{#f|^Q_($@JwePT{4QwS`=uLp{^ytPYYeJpb#JPVyK?@b zv&(E}#n;n{7J6)%d3vt@ayDk+a&?z0&+A`AuK2KDpL^NMPbM~RzB3<hUvbIDLDJMM zD>G!nj)h@;Z<buOeX;S*Uzr<U%A;aJdh*{d46yxE#+lJFKmXKig<jJH87Ah_3LDl$ zEZ}oUJ~~6`;HJp0q1orvSLc+S%U9O@QfFS6rJSwwUuZ{&u6o@KtD7ITwNLvSeKBT@ z#9`n0#oHNI&JSM|r}1d#6vHOwGJ_`OBG3R@xdEgp<wr?Vib(*y-#-1L3x@+YQfGg< zjVp(gYuX2GqeF*I@;AkvTh(>)n7`zl^9}~+!)br|S>h!1_bixXS>V68Gsl1K_uy4$ zJn}2rH*E|nbCu7VKHHT;vi{PyC%JD+l+Ikd;t-zUXqMm9bt`n%I%Bc*zEZQU@Kk6Z zmut{bG0nGK0s_9#fA4a#Uie($CYo|~%B4TA`Xt$p?93_7JRkQ@<D)F^)3vE{j3@R) zD~m8MKXB%6*`-W&x${%5y3Rc!{$<^vdFF;S-_l<lxL99xI3euv!FB5ISG=BfVqf~c z%NrI|uh3w${`Fu1f6L$BpQr0Ql)tkpkNv^_q}j34IapjjMV*VC8JX&8c;wneFM02z z&fVQNa=Z#}`OMhRV)buI>Y0-ajS?IdPM$ONU#nhcIlthB!Odlv)}0ftYwh0kLgeDA z<dlz&60;si25M>SURR%!k{QnWc&Gf0IL=O%V{C_FwwT)dd9}^0qfO<F+Xe=&1!-6J zIXozgpX916z_e%1Hjl%Zf$N$Bc6z*3-R1uGYnS||mf+**vmbh7&A5J_(eKoUSu;5d z0~(u83;SN1m^Vw8@%WLQcNX0KS6-uUdt8b8+SJo;vfK8(NIsk`Jg0Y_e0|x1{C~zP zd^ZIwR^EIww6rxcs&O*cEa&;_B$<3BNC_`e_^WJs@L5=gensJ-gGCP*r<H0glHRuB z*3AWn!dBQQHJ$d9FMr69w&T|CbJsYQy)fA>9Lk)eB(-QoY{YltbMqQ*X}yY^abnLV z(MuodSgyAvO-;J|tTOT2*@&on##;)1*}8uEC;4XGwW<&0Wh_-9*J2MTMm$*1J5wdt o(<eXv%+^Z^^^a$1c+W4c3VAzIP@rUAed4i#XStvQP8k>&08eq<eE<Le literal 542440 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%0Dn<;nW} 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	N?(A|51{l1D9tee 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%0D@Z`dgZT*cp<r+oP5uI$KWiokoP_hi%0rLB`C#LI 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ʐ}Ha=x)%x@_h@wo)Et~?2;Ke2 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 MyvbT{cXtN^0Q&xjMgRZ+ diff --git a/env/pyvenv.cfg b/env/pyvenv.cfg index 57023682..a82a846c 100644 --- a/env/pyvenv.cfg +++ b/env/pyvenv.cfg @@ -1,3 +1,5 @@ -home = C:\Users\eldir\AppData\Local\Programs\Python\Python39 +home = C:\Python312 include-system-site-packages = false -version = 3.9.6 +version = 3.12.0 +executable = C:\Python312\python.exe +command = C:\Python312\python.exe -m venv D:\PPL\a4-logistik\env diff --git a/project_a4_logistik/urls.py b/project_a4_logistik/urls.py index 703657ec..69fa3f0e 100644 --- a/project_a4_logistik/urls.py +++ b/project_a4_logistik/urls.py @@ -20,5 +20,6 @@ urlpatterns = [ path('', include('example_app.urls')), path('admin/', admin.site.urls), path('example_app/', include('example_app.urls')), - path('pr/', include('purchase_requisition.urls')) + path('pr/', include('purchase_requisition.urls')), + path('detail_item/', include('detail_item.urls')) ] -- GitLab